文章目录
- Java 中的泛型(Generics)
- 1. 泛型的概念
- 2. 泛型的优势
- 3. Java 泛型的使用
- (1) 泛型类
- 示例
- (2) 泛型方法
- 示例
- (3) 泛型接口
- 示例
- (4) 泛型的通配符
- (a) `?`(无界通配符)
- (b) `? extends T`(上界通配符)
- © `? super T`(下界通配符)
- (5) 泛型与类型擦除
- 示例
- 4. 泛型的限制
- 5. 总结
Java 中的泛型(Generics)
1. 泛型的概念
泛型(Generics)是 Java 5 引入的一种特性,允许编写类型安全、可复用的代码。泛型主要用于类、接口和方法,能够在编译时进行类型检查,而不需要在运行时进行强制类型转换。
2. 泛型的优势
- 类型安全(Type Safety):避免
ClassCastException,在编译阶段进行类型检查。 - 代码复用(Code Reusability):相同的代码可以适用于多种数据类型,减少代码冗余。
- 可读性和可维护性:减少了不必要的类型转换。
3. Java 泛型的使用
(1) 泛型类
泛型类是在类定义时指定一个或多个类型参数,以支持不同类型的数据。
示例
// 定义一个泛型类 class Box<T> { private T value; public void setValue(T value) { this.value = value; } public T getValue() { return value; } } // 使用泛型类 public class Main { public static void main(String[] args) { Box<Integer> intBox = new Box<>(); intBox.setValue(10); System.out.println(intBox.getValue()); // 输出:10 Box<String> strBox = new Box<>(); strBox.setValue("Hello"); System.out.println(strBox.getValue()); // 输出:Hello } }解释:
T是类型参数,实例化Box<Integer>时,T变为Integer,实例化Box<String>时,T变为String。setValue(T value)只能接收T类型的数据,确保了类型安全。
(2) 泛型方法
泛型方法可以在方法级别使用泛型,而不需要整个类都是泛型的。
示例
class Util { // 泛型方法,`<T>` 指定泛型类型 public static <T> void printArray(T[] array) { for (T element : array) { System.out.print(element + " "); } System.out.println(); } } public class Main { public static void main(String[] args) { Integer[] intArray = {1, 2, 3, 4, 5}; String[] strArray = {"A", "B", "C"}; Util.printArray(intArray); // 输出:1 2 3 4 5 Util.printArray(strArray); // 输出:A B C } }解释:
public static <T> void printArray(T[] array):<T>说明该方法是泛型方法,可以接受不同类型的数组。
(3) 泛型接口
泛型接口允许接口的方法使用泛型,在实现时可以指定具体的类型。
示例
// 定义泛型接口 interface Generator<T> { T next(); } // 实现泛型接口 class IntegerGenerator implements Generator<Integer> { private int value = 0; @Override public Integer next() { return value++; } } public class Main { public static void main(String[] args) { Generator<Integer> gen = new IntegerGenerator(); System.out.println(gen.next()); // 输出:0 System.out.println(gen.next()); // 输出:1 } }解释:
Generator<T>是一个泛型接口,IntegerGenerator具体实现时指定T为Integer。next()方法返回Integer,符合泛型约束。
(4) 泛型的通配符
Java 提供?作为泛型通配符,用于不确定具体类型的情况下,比如在方法参数中。
(a)?(无界通配符)
public static void printList(List<?> list) { for (Object obj : list) { System.out.println(obj); } }List<?>代表任意类型的List,但是方法内部只能当作Object处理。
(b)? extends T(上界通配符)
public static void printNumbers(List<? extends Number> list) { for (Number num : list) { System.out.println(num); } }List<? extends Number>允许List<Integer>、List<Double>等作为参数,但不能添加新元素。
©? super T(下界通配符)
public static void addNumber(List<? super Integer> list) { list.add(10); // 允许添加 Integer 或其父类 }List<? super Integer>允许List<Integer>、List<Number>或List<Object>作为参数。
(5) 泛型与类型擦除
Java 泛型是编译时特性,JVM 并不存储具体的泛型类型,所有泛型类型信息在编译后都会被类型擦除(Type Erasure)。
示例
List<String> list1 = new ArrayList<>(); List<Integer> list2 = new ArrayList<>(); System.out.println(list1.getClass() == list2.getClass()); // 输出:true解释:
- 在运行时,
List<String>和List<Integer>的类型信息都会被擦除,实际的List<T>变成List<Object>,所以list1和list2具有相同的Class。
4. 泛型的限制
Java 泛型有一些限制:
- 不能使用基本数据类型(必须使用包装类,如
List<int>是非法的,应该用List<Integer>)。 - 不能创建泛型数组(
T[] array = new T[10]会报错)。 - 不能在静态方法或静态变量中使用泛型类型参数(因为泛型类型参数是实例级的)。
- 不能直接实例化泛型类型(
T obj = new T();是非法的,应该使用Class<T>来实例化)。
5. 总结
| 特性 | 说明 |
|---|---|
| 泛型类 | class Box<T> { T value; } |
| 泛型方法 | <T> void print(T item) {} |
| 泛型接口 | interface Generator<T> { T next(); } |
| 通配符 | ?(无界)、? extends T(上界)、? super T(下界) |
| 类型擦除 | 编译后泛型信息会被擦除,变为Object |
| 限制 | 不能使用基本类型、不能创建泛型数组、不能实例化泛型 |
Java开发的就业市场正在经历结构性调整,竞争日益激烈
传统纯业务开发岗位(如仅完成增删改查业务的后端工程师)的需求,特别是入门级岗位,正显著萎缩。随着企业技术需求升级,市场对Java人才的要求已从通用技能转向了更深入的领域经验(如云原生、微服务)或前沿的AI集成能力。这也导致岗位竞争加剧,在一、二线城市,求职者不仅面临技术内卷,还需应对学历与项目经验的高门槛。
大模型为核心的AI领域正展现出前所未有的就业热度与人才红利
2025年,AI相关新发岗位数量同比激增543%,单月增幅最高超过11倍,大模型算法工程师位居热门岗位前列。行业顶尖人才的供需严重失衡,议价能力极强,跳槽薪资涨幅可达30%-50%。值得注意的是,市场并非单纯青睐算法研究员,而是急需能将大模型能力落地于复杂业务系统的工程人才。这使得具备企业级架构思维和复杂系统整合经验的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大模型学习资源包》免费分享