自定义泛型类
- 如果不指定该泛型的话,默认为它为Object类。
- 故如果定义了类是泛型的话,建议在实例化时要指明类的泛型。
public class Order<T>{
String orderName;
int orderId;
//类的内部结构就可以使用类的泛型
T orderT;
public Order(){};
public Order(String orderName,int orderID,T orderT){
this.orderName = orderName;
this.orderId = orderId;
this.orderT = orderT;
}
Order<String> order1 = new Order<String>("order1",1001,"order:AA")
注意
- 泛型类可能有多个参数,此时应将多个参数一起放在尖括号内,比如<E1,E2,E3>
- 泛型类的构造器不用声明这类泛型。
- 如果泛型结构是一个接口或者抽象类,则补课创建泛型类的对象。
- 泛型的简化操作:
ArrayList<Fruit> list = new ArrayList;
- 泛型的指定中不能使用基本数据类型,可以使用包装类替换。
- 静态方法中不能用类的泛型。
- 异常类不能是泛型。
泛型方法
在方法中出现了泛型的结构就算泛型方法,泛型参数与类的泛型参数没有任何关系。
换句话说,泛型方法所属的类是不是泛型类都没有关系。
public List copyFromArrayToList(E[] arr){
ArratList<E> list = new ArrayList<>();
for(E e:arr){
list.add(e);
}
return list;
}
泛型在继承方面的体现
类A是类B的父类,G和G二者不具备子父类关系,二者是并列关系。
而此时A
通配符
通配符:?
对声明了通配符的对象不能向其内部添加数据,除了null。
获取的时候可以用Object获取。
List<Object> list1 = null;
List<Object> list2 = null;
List<?> list = null;
print(list1);
print(list2);
写一个带通配符的方法
public void print(List<?> list){
Iterator<?> iterator = list.iterator();
}
有限制条件的通配符
上限extends:使用时指定的类型必须是继承某个类,或者实现某个接口,即<=
下限super:使用时指定的类型不能小于操作的类,即>=
记住子类可以作为父类,父类不能作为子类。
extends A
G<? extends A>可以作为G和G的父类,其中B是A的子类。
super A
G<? super A>可以作为G和G的父类,其中B是A的付父类。