一.接口概述与生活举例
二.接口的定义基本格式
* 接口就是多个类的公共规范
* 接口是一种引用数据类型,最重要的内容就是其中的,抽象方法。
抽象方法可参考该链接:java基础之抽象的概念(全网最详细)-CSDN博客
* 如何定义一个接口的格式:
public interface 接口名称 {
//接口内容
}
如果是java7,那么接口中可以包含的内容有:
1.常量
2.抽象方法
如果是java8,还可以额外包含有:
3.默认方法
4.静态方法
如果是java9,还可以额外包含有:
5.私有方法
三.接口的抽象方法定义与使用
在任何版本的java中,接口都能定义抽象方法
注意事项:
1.接口当中的抽象方法,修饰符必须是两个固定的关键字,public abstract
2.这两个关键字修饰符,可以选择性地省略
3.方法的三要素,可以随意选择
4.如果实现类并没有覆盖重写接口中所有的抽象方法,那么这个实现类自己就必须是抽象类
接口使用步骤:
1.接口不能直接使用,必须有一个“实现类”来“实现”该接口
格式:
public class 实现类名称 implements 接口名称{
//…
}
2.接口的实现类必须覆盖重写(实现)接口中所有的抽象方法
实现:去掉abstract关键字,加上方法体大括号
3.创建实现类的对象,进行使用
再day01包中创建一个接口MyInterfaceAbstract
代码示例
package cn.itcase.day10.day01; /** * @description:接口定义抽象方法 * @author: Admin * @create: 2023/12/12 9:54 */ public interface MyInterfaceAbstract { //这是一个抽象方法 public abstract void methodAbs1(); //这是一个抽象方法 public void methodAbs2(); //这是一个抽象方法 abstract void methodAbs3(); //这是一个抽象方法 void methodAbs4(); }再day01包中创建一个类MyInterfaceAbstractImpl
package cn.itcase.day10.day01; /** * @description * @author: Admin * @create: 2023/12/12 10:11 */ public class MyInterfaceAbstractImpl implements MyInterfaceAbstract{ @Override public void methodAbs1() { System.out.println("这是第一个方法"); } @Override public void methodAbs2() { System.out.println("这是第二个方法"); } @Override public void methodAbs3() { System.out.println("这是第三个方法"); } @Override public void methodAbs4() { System.out.println("这是第四个方法"); } }再day01包中创建一个主类Demo01Interface.java
package cn.itcase.day10.day01; /** * @description:接口 * 接口就是多个类的公共规范 * 接口是一种引用数据类型,最重要的内容就是其中的,抽象方法。 * 如何定义一个接口的格式: * public interface 接口名称{ * //接口内容 * } * @author: Admin * @create: 2023/12/11 15:39 */ public class Demo01Interface { public static void main(String[] args){ //错误写法!!!不能直接new接口对象使用 // MyInterfaceAbstract inter=new MyInterfaceAbstract(); //创建实现类的对象使用 MyInterfaceAbstractImpl impl=new MyInterfaceAbstractImpl(); impl.methodAbs4(); impl.methodAbs1(); } }运行主类
四.接口的默认方法定义与用法
从Java 8开始,接口里允许定义默认方法。
格式:
public default 返回值类型 方法名称(参数列表) {
方法体
}
备注:接口当中的默认方法,可以解决接口升级的问题。
再day01中新建MyInterfaceDefault接口
代码示例:
package cn.itcase.day10.day01; /** * @description * @author: Admin * @create: 2023/12/13 9:32 */ public interface MyInterfaceDefault { // 抽象方法 public abstract void methodAbs(); }再day01中新建MyInterfaceDefaultA类
代码示例:
package cn.itcase.day10.day01; /** * @description * @author: Admin * @create: 2023/12/13 9:36 */ public class MyInterfaceDefaultA implements MyInterfaceDefault{ @Override public void methodAbs() { System.out.println("实现了抽象方法,AAA"); } }再day01中中新建MyInterfaceDefaultB类代码示例:
package cn.itcase.day10.day01; /** * @description * @author: Admin * @create: 2023/12/13 9:36 */ public class MyInterfaceDefaultB implements MyInterfaceDefault{ @Override public void methodAbs() { System.out.println("实现了抽象方法,BBB"); } }思考一个问题:如果再给MyInterfaceDefault接口增加一个抽象方法,那么MyInterfaceDefaultA类和MyInterfaceDefaultB类已经在很多地方调用了,那么这样就会很麻烦修改,这样就推出默认方法
接口的默认方法的使用:
1. 接口的默认方法,可以通过接口实现类对象,直接调用。
2. 接口的默认方法,也可以被接口实现类进行覆盖重写。
引入默认方法:
再day01中新建主类Demo02Interface
package cn.itcase.day10.day01; /** * @description * 1. 接口的默认方法,可以通过接口实现类对象,直接调用。 * 2. 接口的默认方法,也可以被接口实现类进行覆盖重写。 * @author: Admin * @create: 2023/12/13 10:45 */ public class Demo02Interface { public static void main(String[] args) { // 创建了实现类对象 MyInterfaceDefaultA a = new MyInterfaceDefaultA(); a.methodAbs(); // 调用抽象方法,实际运行的是右侧实现类。 // 调用默认方法,如果实现类当中没有,会向上找接口 a.methodDefault(); // 这是新添加的默认方法 System.out.println("=========="); MyInterfaceDefaultB b = new MyInterfaceDefaultB(); b.methodAbs(); b.methodDefault(); // 实现类B覆盖重写了接口的默认方法 } }运行结果:
总结:接口的抽象方法必须覆盖重写,接口的默认方法可重写也可不重写
五.接口的静态方法定义与使用
从Java 8开始,接口当中允许定义静态方法。
格式:
public static 返回值类型 方法名称(参数列表) {
方法体
}
提示:就是将abstract或者default换成static即可,带上方法体。
注意事项:不能通过接口实现类的对象来调用接口当中的静态方法。
正确用法:通过接口名称,直接调用其中的静态方法。
格式:接口名称.静态方法名(参数);
再day01中创建MyInterfaceStatic接口
代码示例
package cn.itcase.day10.day01; /** * @description * @author: Admin * @create: 2023/12/13 11:09 */ public interface MyInterfaceStatic { //public是灰色,说明可以省略 public static void methodStatic() { System.out.println("这是接口的静态方法!"); } }再day01中创建MyInterfaceStaticImpl类
代码示例
package cn.itcase.day10.day01; /** * @description * @author: Admin * @create: 2023/12/13 11:13 */ public class MyInterfaceStaticImpl implements MyInterfaceStatic{ }再day01中创建主类Demo03Interface
代码示例
package cn.itcase.day10.day01; /** * @description * 注意事项:不能通过接口实现类的对象来调用接口当中的静态方法。 * 正确用法:通过接口名称,直接调用其中的静态方法。 * 格式: * 接口名称.静态方法名(参数); * @author: Admin * @create: 2023/12/13 11:13 */ public class Demo03Interface { public static void main(String[] args) { // 创建了实现类对象 MyInterfaceStaticImpl impl = new MyInterfaceStaticImpl(); // 错误写法! // impl.methodStatic(); // 直接通过接口名称调用静态方法 //静态方法与对象没有关系,与类有关系,所以也不需要创建对象 MyInterfaceStatic.methodStatic(); } }运行结果:
六.接口的私有方法定义与使用
再day01包中创建接口MyInterfacePrivateA(思考图中的问题描述)
解决方案:
从Java 9开始,接口当中允许定义私有方法。
1. 普通私有方法,解决多个默认方法之间重复代码问题
格式:
private 返回值类型 方法名称(参数列表) {
方法体
}
2. 静态私有方法,解决多个静态方法之间重复代码问题
格式:
private static 返回值类型 方法名称(参数列表) {
方法体
}
修改MyInterfacePrivateA接口(因为是默认方法,所以使用普通私有方法即可)
注意:静态私有方法的应用,自己举一反三即可;
package cn.itcase.day10.day01; /** * @description * @author: Admin * @create: 2023/12/13 13:14 */ public interface MyInterfacePrivateA { public default void methodDefault1() { System.out.println("默认方法1"); methodCommon(); } public default void methodDefault2() { System.out.println("默认方法2"); methodCommon(); } //私有方法,把重复的代码,放在私有方法里 private void methodCommon() { System.out.println("AAA"); System.out.println("BBB"); System.out.println("CCC"); } }七.接口的常量定义与使用
接口当中也可以定义“成员变量”,但是必须使用public static final三个关键字进行修饰。
从效果上看,这其实就是接口的常量。
格式:
public static final 数据类型 常量名称 = 数据值;
备注:
一旦使用final关键字进行修饰,说明不可改变。
注意事项:
1. 接口当中的常量,可以省略public static final,注意:不写也照样是这样。
2. 接口当中的常量,必须进行赋值;不能不赋值。
3. 接口中常量的名称,使用完全大写的字母,用下划线进行分隔。(推荐命名规则)
再day01包中创建接口MyInterfaceConst代码示例
package cn.itcase.day10.day01; /** * @description * @author: Admin * @create: 2023/12/13 13:37 */ public interface MyInterfaceConst { // 这其实就是一个常量,一旦赋值,不可以修改 public static final int NUM_OF_MY_CLASS = 12; }再day01包中创建主类Demo05Interface
package cn.itcase.day10.day01; /** * @description * @author: Admin * @create: 2023/12/13 13:52 */ public class Demo05Interface { public static void main(String[] args) { // 访问接口当中的常量 System.out.println(MyInterfaceConst.NUM_OF_MY_CLASS); } }运行结果:
八.继承父类并实现多个接口
使用接口的时候,需要注意:
1. 接口是没有静态代码块或者构造方法的。
2. 一个类的直接父类是唯一的,但是一个类可以同时实现多个接口。
格式:
public class MyInterfaceImpl implements MyInterfaceA, MyInterfaceB {
// 覆盖重写所有抽象方法
}
3. 如果实现类所实现的多个接口当中,存在重复的抽象方法,那么只需要覆盖重写一次即可。
4. 如果实现类没有覆盖重写所有接口当中的所有抽象方法,那么实现类就必须是一个抽象类。
5. 如果实现类实现的多个接口当中,存在重复的默认方法,那么实现类一定要对冲突的默认方法进行覆盖重写。
6. 一个类如果直接父类当中的方法,和接口当中的默认方法产生了冲突,优先用父类当中的方法。
格式
public class Zi extends Fu implements MyInterface {
}
针对第一到第三点举例
(第四点省略,较简单)
再day02包中创建接口MyInterfaceA
代码示例:
package cn.itcase.day10.day02; /** * @description * @author: Admin * @create: 2023/12/13 14:34 */ public interface MyInterfaceA { // 错误写法!接口不能有静态代码块 // static { // // } // 错误写法!接口不能有构造方法 // public MyInterfaceA() { // // } public abstract void methodA(); public abstract void methodAbs(); }再day02包中创建接口MyInterfaceB
代码示例:
package cn.itcase.day10.day02; /** * @description * @author: Admin * @create: 2023/12/13 14:34 */ public interface MyInterfaceB { public abstract void methodB(); public abstract void methodAbs(); }再day02包中创建类MyInterfaceImpl
代码示例
package cn.itcase.day10.day02; /** * @description * @author: Admin * @create: 2023/12/13 14:38 */ public class MyInterfaceImpl implements MyInterfaceA,MyInterfaceB{ @Override public void methodA() { System.out.println("覆盖重写了A方法"); } @Override public void methodB() { System.out.println("覆盖重写了B方法"); } //MyInterfaceA接口和MyInterfaceB接口都有methodAbs方法, // 实现类只需要覆盖重写一次即可; @Override public void methodAbs() { System.out.println("覆盖重写了AB接口都有的抽象方法"); } }针对第五点举例
如果实现类实现的多个接口当中,存在重复的默认方法,那么实现类一定要对冲突的默认方法进行覆盖重写
修改MyInterfaceA代码
修改MyInterfaceB代码
修改实现类MyInterfaceImpl代码
九.接口之间的多继承
1. 类与类之间是单继承的。直接父类只有一个。
2. 类与接口之间是多实现的。一个类可以实现多个接口。
3. 接口与接口之间是多继承的。
格式:
public interface MyInterface extends MyInterfaceA, MyInterfaceB{
}
注意事项:
1. 多个父接口当中的抽象方法如果重复,没关系。
2. 多个父接口当中的默认方法如果重复,那么子接口必须进行默认方法的覆盖重写,【而且带着default关键字】。
十.小结
在Java 9+版本中,接口的内容可以有:
1. 成员变量其实是常量,格式:
[public] [static] [final] 数据类型 常量名称 = 数据值;
注意:
常量必须进行赋值,而且一旦赋值不能改变。
常量名称完全大写,用下划线进行分隔。
2. 接口中最重要的就是抽象方法,格式:
[public] [abstract] 返回值类型 方法名称(参数列表);
注意:实现类必须覆盖重写接口所有的抽象方法,除非实现类是抽象类。
3. 从Java 8开始,接口里允许定义默认方法,格式:
[public] default 返回值类型 方法名称(参数列表) { 方法体 }
注意:默认方法也可以被覆盖重写
4. 从Java 8开始,接口里允许定义静态方法,格式:
[public] static 返回值类型 方法名称(参数列表) { 方法体 }
注意:应该通过接口名称进行调用,不能通过实现类对象调用接口静态方法
5. 从Java 9开始,接口里允许定义私有很乏,格式:
普通私有方法:private 返回值类型 方法名称(参数列表) { 方法体 }
静态私有方法:private static 返回值类型 方法名称(参数列表) { 方法体 }
注意:private的方法只有接口自己才能调用,不能被实现类或别人使用。
Java程序员如今深陷技术迭代放缓与行业需求收缩的双重困境,职业发展空间正被新兴技术浪潮持续挤压。面对当前Java程序员可能面临的“发展瓶颈”或行业挑战,更积极的应对策略可以围绕技术升级、方向转型、能力拓展三个核心展开,而非被动接受“不行”的标签,通过调查对比,我发现人工智能大模型是个很好的出路。
技术升级与转型机会
突破传统Java开发边界:大模型技术的普及为Java开发者提供了新的机遇,使他们能够突破传统企业级开发的局限,进入人工智能这一高增长领域。通过学习大模型集成,Java开发者可以转型为AI应用开发者,拓展职业发展空间。
技术栈升级:Java社区积极拥抱大模型技术,推出了多个开源项目和框架,如Deeplearning4j、DJL(Deep Java Library)等。这些工具为Java开发者提供了丰富的资源,使他们能够更方便地构建和部署基于大模型的应用。
发挥Java在企业级应用中的优势
稳定性与可靠性:Java作为企业级应用的主流语言,其稳定性和可靠性在大模型应用中同样得到体现。Java的强类型系统和严谨的工程化特性,在构建可靠的大模型应用时提供了额外保障。
跨平台性:Java的“一次编写,到处运行”特性使其能够轻松部署到不同操作系统和硬件环境中。这一特性在大型模型的部署和集成中尤为重要,可以降低部署复杂性和成本。
多线程处理能力:Java强大的多线程处理能力特别适合大模型的推理部署场景,可以高效处理并发请求,提升系统性能。
说真的,这两年看着身边一个个搞Java、C++、前端、数据、架构的开始卷大模型,挺唏嘘的。大家最开始都是写接口、搞Spring Boot、连数据库、配Redis,稳稳当当过日子。
结果GPT、DeepSeek火了之后,整条线上的人都开始有点慌了,大家都在想:“我是不是要学大模型,不然这饭碗还能保多久?”
先给出最直接的答案:一定要把现有的技术和大模型结合起来,而不是抛弃你们现有技术!掌握AI能力的Java工程师比纯Java岗要吃香的多。
即使现在裁员、降薪、团队解散的比比皆是……但后续的趋势一定是AI应用落地!大模型方向才是实现职业升级、提升薪资待遇的绝佳机遇!
如何学习AGI大模型?
作为一名热心肠的互联网老兵,我决定把宝贵的AI知识分享给大家。 至于能学习到多少就看你的学习毅力和能力了 。我已将重要的AI大模型资料包括AI大模型入门学习思维导图、精品AI大模型学习书籍手册、视频教程、实战学习等录播视频免费分享出来。
因篇幅有限,仅展示部分资料,需要点击下方链接即可前往获取
2025最新版CSDN大礼包:《AGI大模型学习资源包》免费分享**
一、2025最新大模型学习路线
一个明确的学习路线可以帮助新人了解从哪里开始,按照什么顺序学习,以及需要掌握哪些知识点。大模型领域涉及的知识点非常广泛,没有明确的学习路线可能会导致新人感到迷茫,不知道应该专注于哪些内容。
我们把学习路线分成L1到L4四个阶段,一步步带你从入门到进阶,从理论到实战。
L1级别:AI大模型时代的华丽登场
L1阶段:我们会去了解大模型的基础知识,以及大模型在各个行业的应用和分析;学习理解大模型的核心原理,关键技术,以及大模型应用场景;通过理论原理结合多个项目实战,从提示工程基础到提示工程进阶,掌握Prompt提示工程。
L2级别:AI大模型RAG应用开发工程
L2阶段是我们的AI大模型RAG应用开发工程,我们会去学习RAG检索增强生成:包括Naive RAG、Advanced-RAG以及RAG性能评估,还有GraphRAG在内的多个RAG热门项目的分析。
L3级别:大模型Agent应用架构进阶实践
L3阶段:大模型Agent应用架构进阶实现,我们会去学习LangChain、 LIamaIndex框架,也会学习到AutoGPT、 MetaGPT等多Agent系统,打造我们自己的Agent智能体;同时还可以学习到包括Coze、Dify在内的可视化工具的使用。
L4级别:大模型微调与私有化部署
L4阶段:大模型的微调和私有化部署,我们会更加深入的探讨Transformer架构,学习大模型的微调技术,利用DeepSpeed、Lamam Factory等工具快速进行模型微调;并通过Ollama、vLLM等推理部署框架,实现模型的快速部署。
整个大模型学习路线L1主要是对大模型的理论基础、生态以及提示词他的一个学习掌握;而L3 L4更多的是通过项目实战来掌握大模型的应用开发,针对以上大模型的学习路线我们也整理了对应的学习视频教程,和配套的学习资料。
二、大模型经典PDF书籍
书籍和学习文档资料是学习大模型过程中必不可少的,我们精选了一系列深入探讨大模型技术的书籍和学习文档,它们由领域内的顶尖专家撰写,内容全面、深入、详尽,为你学习大模型提供坚实的理论基础。(书籍含电子版PDF)
三、大模型视频教程
对于很多自学或者没有基础的同学来说,书籍这些纯文字类的学习教材会觉得比较晦涩难以理解,因此,我们提供了丰富的大模型视频教程,以动态、形象的方式展示技术概念,帮助你更快、更轻松地掌握核心知识。
四、大模型项目实战
学以致用,当你的理论知识积累到一定程度,就需要通过项目实战,在实际操作中检验和巩固你所学到的知识,同时为你找工作和职业发展打下坚实的基础。
五、大模型面试题
面试不仅是技术的较量,更需要充分的准备。
在你已经掌握了大模型技术之后,就需要开始准备面试,我们将提供精心整理的大模型面试题库,涵盖当前面试中可能遇到的各种技术问题,让你在面试中游刃有余。
因篇幅有限,仅展示部分资料,需要点击下方链接即可前往获取
2025最新版CSDN大礼包:《AGI大模型学习资源包》免费分享