java - 为什么在忽略参数类型时泛型会完全禁用?

标签 java generics

作为 this question 的后续行动, 先说背景

给定一个带有此声明的类:

public class SomeClass<T>

还有一个不使用泛型参数的子类:

public class SomeSubClass extends SomeClass

SomeClass 上的一个方法声明如下:

protected Map<String, Object> getMap(Object param) {
}

如果子类这样调用方法:

Map<String, Object> val = getMap(param);

编译器在本质上提示 getMap 返回一个普通的 Map 并且存在对通用 Map 的未经检查的分配。为什么会这样?这是对泛型的书面期望吗?有什么理由吗?

最佳答案

我不太清楚这样做的理由,但此行为在 Java Language Specification JLS S4.8 中指定。 :

The superclasses (respectively, superinterfaces) of a raw type are the erasures of the superclasses (superinterfaces) of any of its parameterized invocations.

鉴于在新代码中使用原始类型是非常不鼓励的,我猜他们想简化原始类型和参数化类型之间的交互规则。

关于java - 为什么在忽略参数类型时泛型会完全禁用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1040540/

相关文章:

java - TextField 中的负数错误

java - if 语句因未知原因返回 false

java - 一旦方法返回,传递给方法并反序列化的列表将变为空

c# - 如何存储对基于传递给方法的表达式创建的泛型类型的引用?

java - 防御路径遍历攻击的最佳方法是什么?

java - new Date().getTime() 不以毫秒为单位返回时间戳

java - Lotus Notes - 标记文档行(以不同颜色突出显示该行)

Java 泛型。如何正确扩展扩展通用抽象参数类型类的参数类型类

Java 泛型 - 什么时候需要参数化?

ios - 苹果 swift : Type Casting Generics