“ 泛型是Java SE 1.5的新特性,泛型的本质是参数化类型,也就是说所操作的数据类型被指定为一个参数。这种参数类型可以用在类、接口和方法的创建中,分别称为泛型类、泛型接口、泛型方法。”
1、泛型的类型参数只能是类类型(包括自定义类),不能是简单类型。
2、同一种泛型可以对应多个版本(因为参数类型是不确定的),不同版本的泛型类实例是不兼容的。
3、泛型的类型参数可以有多个。
4、泛型的参数类型可以使用extends语句,例如<T extends superclass>。习惯上成为“有界类型”。
5、泛型的参数类型还可以是通配符类型。例如Class<?> classType = Class.forName(java.lang.String);
泛型类:
T是一个泛型类
1 package generic; 2 3 public class Gen<T> { 4 5 private T t; 6 7 public Gen(T t) { 8 this.t = t; 9 } 10 11 public T getT() { 12 return t; 13 } 14 15 public void setT(T t) { 16 this.t = t; 17 } 18 19 }
我们可以看到T是一个不确定的类。我们在声明、实例化Gen的时候,可以使用:
Gen<String> gen1=new Gen<String>("");
Gen<Integer>gen2=new Gen<Integer>(1);
这样即方便地忽略了T的类型,不需要为gen来设置定义多种参数。
再看如下代码,对Gen进行改造,看看extends的用法
package generic; public class Gen<T, K extends Comparable<?>> { private T t; private K k; public K getK() { return k; } public void setK(K k) { this.k = k; } public Gen(T t) { this.t = t; } public Gen(T t, K k) { this.t = t; this.k = k; } public T getT() { return t; } public void setT(T t) { this.t = t; } }
声明、实例化该Gen
可以看到,Object并不是Comparable的子类,出现了错误,即是说,我们为K加入了一个限定“K必须为Comparable的子类”
继续改造Gen,看看super的用法
package generic; public class Gen<T, K extends Comparable<? super Double>> { private T t; private K k; public K getK() { return k; } public void setK(K k) { this.k = k; } public Gen(T t) { this.t = t; } public Gen(T t, K k) { this.t = t; this.k = k; } public T getT() { return t; } public void setT(T t) { this.t = t; } }
声明实例化该Gen
可以看到,String虽然实现自Comparable,但它并不是Double或者Double的父类。
所以也报错了。