类型擦除示例:为什么 ArrayList<Integer> 与 ArrayList<Float> 相等
副标题 / 摘要 Java 泛型在运行时会被擦除,导致不同类型参数的 List 拥有相同 Class。本文解释原因与影响。 目标读者 使用 Java 泛型的开发者 想理解类型系统限制的人 进行 API 设计的工程师 背景 / 动机 Java 泛型是编译期特性。 在运行时,类型参数会被擦除,这会影响反射与类型判断。 核心概念 类型擦除:泛型信息在运行时消失 编译期检查:类型安全主要在编译期保证 运行时类型:只剩原始类型 实践指南 / 步骤 理解泛型只在编译期起作用 避免依赖运行时泛型信息 用显式 Class 参数传递类型 在反射场景保持谨慎 可运行示例 import java.util.ArrayList; public class ErasureDemo { public static void main(String[] args) { ArrayList<Integer> li = new ArrayList<>(); ArrayList<Float> lf = new ArrayList<>(); System.out.println(li.getClass() == lf.getClass()); // true } } 解释与原理 泛型类型参数在编译后被擦除为原始类型(如 ArrayList)。 因此运行时类对象相同。 常见问题与注意事项 这会影响类型安全吗? 编译期仍保证类型安全,但运行时反射可能不安全。 为什么 Java 设计成这样? 为了兼容旧版本与字节码格式。 ...