首页  >  文章  >  Java  >  为什么在 Java 中使用泛型方法时原始类型会导致问题?

为什么在 Java 中使用泛型方法时原始类型会导致问题?

Barbara Streisand
Barbara Streisand原创
2024-11-12 08:10:02933浏览

Why Do Raw Types Cause Problems When Working with Generic Methods in Java?

理解原始类型和泛型方法之间的联系

在 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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn