You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
59 lines
2.7 KiB
59 lines
2.7 KiB
一、使用 AI 工具解决问题:Java 泛型擦除后如何通过反射获取泛型信息?
|
|
**我向 AI 提出的问题:**
|
|
Java 泛型在编译后会进行类型擦除,为什么还能通过反射获取泛型信息?具体如何实现?
|
|
|
|
**AI 给出的解答:**
|
|
Java 的泛型在运行时会被擦除,但**类、方法、字段上定义的泛型签名信息会被保留在字节码文件中**,以便编译器和反射 API 使用。
|
|
我们可以通过以下反射 API 获取泛型信息:
|
|
- **ParameterizedType**:表示参数化类型(如 List<String>、Map<K,V>)
|
|
- **getGenericSuperclass()**:获取带泛型的父类
|
|
- **getGenericInterfaces()**:获取带泛型的接口
|
|
- **getGenericReturnType()**:获取带泛型的返回值类型
|
|
|
|
**AI 提供的示例思路:**
|
|
通过反射获取泛型的实际类型参数,再从中拿到真实类型。
|
|
|
|
---
|
|
|
|
## 二、使用 AI 工具审查代码(泛型缓存类 Cache)
|
|
我将自己编写的 **Cache<K, V> 泛型缓存代码**交给 AI 进行审查,AI 给出以下评价与建议:
|
|
|
|
**AI 代码审查结果:**
|
|
1. **代码结构规范**:泛型定义正确,使用<K,V>实现了通用缓存。
|
|
2. **功能完整**:实现了缓存的存、取、删除、清空、判断存在等功能。
|
|
3. **使用 HashMap 合理**:适合作为缓存底层存储,读写效率高。
|
|
4. **线程安全问题**:当前版本未考虑多线程环境,若在多线程中使用可能出现并发问题。
|
|
5. **无内存管理机制**:不会自动清理过期数据。
|
|
|
|
**AI 总结:**
|
|
代码满足课程作业要求,泛型使用规范,逻辑正确,可以正常运行。
|
|
|
|
---
|
|
|
|
## 三、AI 学习总结(我学到了什么)
|
|
通过本次 AI 协同学习,我掌握了以下内容:
|
|
1. 了解**泛型擦除**并不代表泛型信息完全消失,反射仍可获取。
|
|
2. 学会**ParameterizedType**的作用与使用场景。
|
|
3. 知道如何借助 AI 检查代码错误、优化逻辑。
|
|
4. 加深了对**泛型类、泛型方法、类型安全**的理解。
|
|
5. 明白泛型的意义:让代码更通用、更安全、更易复用。
|
|
|
|
为什么 Java 泛型不支持基本类型?
|
|
Java 泛型不支持 int、char、boolean、double 等基本类型,核心原因只有 3 点
|
|
1. 泛型底层是 类型擦除
|
|
Java 泛型在编译后会把所有泛型类型变成 Object例如:
|
|
plaintext
|
|
Pair<K,V> → 编译后变成 Pair<Object, Object>
|
|
2. 基本类型 不是 Object 的子类
|
|
int、char、boolean 不属于对象
|
|
它们不能被 Object 接收
|
|
所以泛型无法存储基本类型
|
|
3. 只能用 包装类 代替
|
|
Java 提供了对应的包装类:
|
|
int → Integer
|
|
char → Character
|
|
boolean → Boolean
|
|
double → Double
|
|
这些是对象,继承自 Object,可以被泛型接收。
|
|
|
|
|
|
|