在 Java 中,与泛型方法交互时使用原始类型可能会导致意想不到的后果。
考虑以下代码片段:
ArrayList<String> a = new ArrayList<String>(); String[] s = a.toArray(new String[0]);
此代码在两个 JDK 中都能成功编译1.6 和 JDK 1.7。但是,如果我们将 List 引用声明为原始类型:
ArrayList a = new ArrayList(); String[] s = a.toArray(new String[0]);
我们遇到编译器错误,指示需要 String[],但找到了 Object[]。
This行为源于这样一个事实:对 List 引用使用原始类型会删除对该类型的实例成员使用泛型的能力。这不限于泛型方法,如以下示例所示:
public class MyContainer<T> { public List<String> strings() { return Arrays.asList("a", "b"); } } MyContainer container = new MyContainer<Integer>(); List<String> strings = container.strings(); // gives an unchecked warning!
Java 语言规范 (JLS) 中明确说明了此行为:
构造函数的类型 (§ 8.8)、实例方法 (§8.4、§9.4) 或非静态字段 (§8.3) M 的原始类型 C,不是从其超类或超接口继承的是原始类型,对应于 C 对应的泛型声明中其类型的擦除。
因此,应谨慎使用原始类型,因为它可能会导致意外的限制,甚至编译时错误当使用泛型方法或访问实例成员时。
以上是为什么在 Java 中使用泛型方法时原始类型会导致问题?的详细内容。更多信息请关注PHP中文网其他相关文章!