JAVA泛型类的使用(二)

简介: 接上一篇继续介绍Java泛型的高级特性。3. **编译时类型检查**:尽管运行时发生类型擦除,编译器会在编译阶段进行严格类型检查,并允许通过`extends`关键字对类型参数进行约束,确保类型安全。4. **桥方法**:为保证多态性,编译器会生成桥方法以处理类型擦除带来的问题。5. **运行时获取泛型信息**:虽然泛型信息在运行时被擦除,但可通过反射机制部分恢复这些信息,例如使用`ParameterizedType`来获取泛型参数的实际类型。

接上一篇继续写

  1. 编译时类型检查
    虽然泛型类在运行时进行了类型擦除,但在编译阶段,Java 编译器会对泛型代码进行严格的类型检查。
    3-1 类型参数的约束
    在定义泛型类时,可以对类型参数进行约束,例如指定类型参数必须是某个类的子类。
class NumberBox<T extends Number> {
    private T number;

    public void setNumber(T number) {
        this.number = number;
    }

    public T getNumber() {
        return number;
    }
}

3-2 类型安全
通过编译时的类型检查,泛型类可以确保在使用时不会出现类型不匹配的问题。例如:

Box<Integer> integerBox = new Box<>();
// 编译错误,不能将 String 类型赋值给 Box<Integer>
// integerBox.setItem("hello");
  1. 桥方法(Bridge Methods)
    由于类型擦除的存在,在某些情况下,为了保证泛型类的多态性,编译器会生成桥方法。
    4-1 示例
    一个泛型类的子类:
class IntegerBox extends Box<Integer> {
    @Override
    public void setItem(Integer item) {
        super.setItem(item);
    }

    @Override
    public Integer getItem() {
        return super.getItem();
    }
}

桥方法:

class IntegerBox extends Box<Integer> {
    // 桥方法
    @Override
    public void setItem(Object item) {
        setItem((Integer) item);
    }

    @Override
    public Integer getItem() {
        return super.getItem();
    }

    public void setItem(Integer item) {
        super.setItem(item);
    }
}
  1. 运行时获取泛型信息
    虽然泛型类在运行时进行了类型擦除,但在某些情况下,仍然可以通过反射获取泛型信息。
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.util.ArrayList;
import java.util.List;

class GenericClass<T> {
    private List<T> list = new ArrayList<>();

    public Type getGenericType() {
        Type superclass = getClass().getGenericSuperclass();
        if (superclass instanceof ParameterizedType) {
            ParameterizedType parameterizedType = (ParameterizedType) superclass;
            return parameterizedType.getActualTypeArguments()[0];
        }
        return null;
    }
}

class StringGenericClass extends GenericClass<String> {}

public class Main {
    public static void main(String[] args) {
        StringGenericClass stringGenericClass = new StringGenericClass();
        Type genericType = stringGenericClass.getGenericType();
        System.out.println(genericType); 
    }
}
相关文章
|
3月前
|
Java 编译器 API
Java 密封类:精细化控制继承关系
Java 密封类:精细化控制继承关系
276 83
|
10天前
|
安全 Java 数据建模
Java记录类:简化数据载体的新选择
Java记录类:简化数据载体的新选择
162 101
|
10天前
|
安全 Java 开发者
Java记录类:简化数据载体的新方式
Java记录类:简化数据载体的新方式
179 100
|
2月前
|
安全 IDE Java
Java记录类型(Record):简化数据载体类
Java记录类型(Record):简化数据载体类
298 120
|
4月前
|
IDE Java 数据挖掘
Java 基础类从入门到精通实操指南
这份指南专注于**Java 17+**的新特性和基础类库的现代化用法,涵盖开发环境配置、数据类型增强(如文本块)、字符串与集合处理进阶、异常改进(如密封类)、IO操作及实战案例。通过具体代码示例,如CSV数据分析工具,帮助开发者掌握高效编程技巧。同时提供性能优化建议和常用第三方库推荐,适合从入门到精通的Java学习者。资源链接:[点此下载](https://pan.quark.cn/s/14fcf913bae6)。
184 35
|
5月前
|
存储 安全 Java
【高薪程序员必看】万字长文拆解Java并发编程!(7):不可变类设计指南
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发编程中Java不可变类设计指南,废话不多说让我们直接开始。
80 0
|
2月前
|
缓存 安全 Java
Java反射机制:动态操作类与对象
Java反射机制是运行时动态操作类与对象的强大工具,支持获取类信息、动态创建实例、调用方法、访问字段等。它在框架开发、依赖注入、动态代理等方面有广泛应用,但也存在性能开销和安全风险。本文详解反射核心API、实战案例及性能优化策略,助你掌握Java动态编程精髓。
|
7月前
|
Java 开发者
重学Java基础篇—Java类加载顺序深度解析
本文全面解析Java类的生命周期与加载顺序,涵盖从加载到卸载的七个阶段,并深入探讨初始化阶段的执行规则。通过单类、继承体系的实例分析,明确静态与实例初始化的顺序。同时,列举六种触发初始化的场景及特殊场景处理(如接口初始化)。提供类加载完整流程图与记忆口诀,助于理解复杂初始化逻辑。此外,针对空指针异常等问题提出排查方案,并给出最佳实践建议,帮助开发者优化程序设计、定位BUG及理解框架机制。最后扩展讲解类加载器层次与双亲委派机制,为深入研究奠定基础。
239 0
|
2月前
|
存储 安全 Java
Java集合框架(一):List接口及其实现类剖析
本文深入解析Java中List集合的实现原理,涵盖ArrayList的动态数组机制、LinkedList的链表结构、Vector与Stack的线程安全性及其不推荐使用的原因,对比了不同实现的性能与适用场景,帮助开发者根据实际需求选择合适的List实现。