接上文java泛型
一、限制泛型 在上文中我们使类class GenDemo
,持有者T的范围没有限制, 实际相当于Object. 但是我们有时需要传入的参数类型为某接口或类的实现或子类,而不是没有限制的Ojbect 所以使用限制泛型。再次我们让T为借口Collection的实现:
import java.util.collection;
public class GenDemo {
private T t;
public GenDemo(T t) {
this.t = t;
}
public void setT(T t) {
this.t = t;
}
public T getT(){
return T;
}
}
class GenDemo
使用限制泛型, 决定了持有者T的类型只能是Collection的实现类,如果传入的是非Collection类,译时就会报错。
注意:使用了关键字extends, 但是extends 后面也可以使用接口,也可以使用类, 此处的extends 并不是继承,此处应该理解为T的类型是实现xx接口的实现类,或者继承xx类的子类。 这里的例子仅演示了泛型方法的类型限定,对于泛型类中类型参数的限制用完全一样的规则,只是加在类声明的头部,如:
public class Demo {
// T类型就可以用Comparable声明的方法和Seriablizable所拥有的特性了
}
二、多接口限制
主要使用extends关键字, 此处的extends统一了原有的extends和implements的概念, 即实现接口和继承类都使用extends,但是,仍然遵循应用的体系,java只能继承一个类, 可以实现多个接口。也就是:
三、通配符泛型