接上文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只能继承一个类, 可以实现多个接口。也就是:
立即学习“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只能继承一个类, 可以实现多个接口。也就是:
立即学习“Java免费学习笔记(深入)”;
<T extends SomeClass & interface1 & interface2 & interface3>
以上就是java之泛型深入的内容,更多相关内容请关注PHP中文网(www.php.cn)!
java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号