接上文java泛型
在上文中我们使类class GenDemo<T>
,持有者T的范围没有限制, 实际相当于Object.
但是我们有时需要传入的参数类型为某接口或类的实现或子类,而不是没有限制的Ojbect
所以使用限制泛型。再次我们让T为借口Collection的实现:
import java.util.collection;public class GenDemo<T extends Collection> { 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 extends Collection>
使用限制泛型, 决定了持有者T的类型只能是Collection的实现类,如果传入的是非Collection类,译时就会报错。
注意:<T extends Collection>
使用了关键字extends, 但是extends 后面也可以使用接口,也可以使用类, 此处的extends 并不是继承,此处应该理解为T的类型是实现xx接口的实现类,或者继承xx类的子类。
这里的例子仅演示了泛型方法的类型限定,对于泛型类中类型参数的限制用完全一样的规则,只是加在类声明的头部,如:
public class Demo<T extends Comparable & Serializable> { // T类型就可以用Comparable声明的方法和Seriablizable所拥有的特性了}
主要使用extends关键字, 此处的extends统一了原有的extends和implements的概念, 即实现接口和继承类都使用extends,但是,仍然遵循应用的体系,java只能继承一个类, 可以实现多个接口。也就是:
<T extends SomeClass & interface1 & interface2 & interface3>
接上文java泛型
在上文中我们使类class GenDemo<T>
,持有者T的范围没有限制, 实际相当于Object.
但是我们有时需要传入的参数类型为某接口或类的实现或子类,而不是没有限制的Ojbect
所以使用限制泛型。再次我们让T为借口Collection的实现:
import java.util.collection;public class GenDemo<T extends Collection> { 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 extends Collection>
使用限制泛型, 决定了持有者T的类型只能是Collection的实现类,如果传入的是非Collection类,译时就会报错。
注意:<T extends Collection>
使用了关键字extends, 但是extends 后面也可以使用接口,也可以使用类, 此处的extends 并不是继承,此处应该理解为T的类型是实现xx接口的实现类,或者继承xx类的子类。
这里的例子仅演示了泛型方法的类型限定,对于泛型类中类型参数的限制用完全一样的规则,只是加在类声明的头部,如:
public class Demo<T extends Comparable & Serializable> { // T类型就可以用Comparable声明的方法和Seriablizable所拥有的特性了}
主要使用extends关键字, 此处的extends统一了原有的extends和implements的概念, 即实现接口和继承类都使用extends,但是,仍然遵循应用的体系,java只能继承一个类, 可以实现多个接口。也就是:
<T extends SomeClass & interface1 & interface2 & interface3>
以上就是java之泛型深入的内容,更多相关内容请关注PHP中文网(www.php.cn)!