此链接说明以下内容:
具有实际类型参数的泛型类型的实例化称为参数化类型。示例(参数化类型):
Collection<String> coll = new LinkedList<String>();
那么什么是参数化类型呢?
Collection<String>
或者LinkedList<String>
它们都是参数化类型:将其他类型作为参数的类型。
在表达式的两侧有不同类型的事实是无关紧要的,并且与多态行为有关,即因为LinkedList
是Collection
.
参数化类型通常是一个处理其他对象的类,而不关心它是什么类型。可以使用符号“名称”定义类型,然后在创建类实例时传递。
例如:
class MyClass<T> {
private T obj;
public MyClass<T>(T obj) {
this.obj = obj;
}
public int getId() {
return obj.hashCode();
}
}
在上面的示例中,MyClass
包装任何类型的对象并hashCode()
使用该方法始终存在的事实来执行其方法。
下面是如何使用这个类:
int sid = new MyClass<String>("aaaa").hashCode();
请注意,您不能说 new MyClass<String>(123)
:对象是用参数创建的这一事实String
决定了构造函数参数的类型。
回到你的例子Collection<String>
意味着“字符串的集合”。这意味着您不能将其他类型的对象添加到此集合中。
似乎泛型类型和参数化类型是同义词。但是调用泛型类型似乎是不对的,Box<Integer>
因为在这个词的意义上不再是泛型了。所以可能:
泛型类型是带有正式类型参数的声明
class Box<T> { .. }
Box<T>
是泛型类型
参数化类型是具有实际类型参数的声明
Box<Integer> b;
Box<Integer>
是参数化类型
原始类型是没有实际类型参数的泛型类型的声明。
class Box<T> { .. }
Box b;
Box
是原始类型
集合的两种用途
Collection<String>
LinkedList<String>
这里是参数化类型,String
是使用的类型。
这是术语的快速细分......
"<T>"
"<String>"
"List<T>"
"List<String>"
ParameterizedType 表示一个参数化类型,例如 Collection。
参数化类型在反射方法第一次需要时创建,如此包中所指定。创建参数化类型 p 时,解析 p 实例化的泛型类型声明,并递归创建 p 的所有类型参数。有关类型变量的创建过程的详细信息,请参阅 TypeVariable。重复创建参数化类型无效。
实现此接口的类的实例必须实现 equals() 方法,该方法等同于任何两个共享相同泛型类型声明并具有相同类型参数的实例。