泛型的概念
1.所谓泛型,就是允许在定义类、接口时通过一个标识表示类中某个属性的类
型或者是某个方法的返回值及参数类型。这个类型参数将在使用时(例如,
继承或实现这个接口,用这个类型声明变量、创建对象时)确定(即传入实
际的类型参数,也称为类型实参)。
2. 从JDK1.5以后,Java引入了“参数化类型(Parameterized type)”的概念,
允许我们在创建集合时再指定集合元素的类型,正如:List,这表明
该List只能保存字符串类型的对象。
3. JDK1.5改写了集合框架中的全部接口和类,为这些接口、类增加了泛型支持,
从而可以在声明集合变量、创建集合对象时传入类型实参。
1.泛型类
1.由于子类在继承泛型的父类时,指明了泛型类型,则是实例化子类对象时,不需要指明泛型
public static void main(String[] args) {
SubOrder sub1=new SubOrder();
sub1.setOrderT(1212);
SubOrder1<Object> sub2 = new SubOrder1<>();
sub2.setOrderT(234);
}
public class SubOrder extends Order<Integer> {
//SubOrder不是泛型
}
class SubOrder1<T> extends Order<T>{
//SubOrder1是泛型
}
静态方法中不能使用类的泛型
而应该将该方法定义为泛型方法
原因:
1.在java中泛型只是一个占位符,必须在传递类型后才能使用
2.类的实例化时才能真正的传递类型参数,由于静态方法的加载优先于类的
实例化,也就是说类的泛型还没有传递真正的参数时
静态方法就已经加载完成了
public static T show(T temp){
return temp;
}
泛型方法
1.方法,也可以被泛型化,不管此时定义在其中的类是不是泛型类,在泛型方法中可以定义泛型参数,此时,参数的类型就是传入数据的2.泛型方法的格式.
[访问权限]<泛型>返回类型方法名([泛型标识参数名称])抛出的异常
public <E> List<E> COPY(E[]arr){
ArrayList<E> list=new ArrayList<>();
for(E e:arr){
list.add(e);
}
return list;
}
泛型方法在调用时,指明泛型参数的类型
public static void main(String[] args) {
Order<Object> order = new Order<>();
Integer[] arr = {1, 2, 3, 4};
List<Integer> copy = order.COPY(arr);
System.out.println(copy);
}
代码运行结果
[1, 2, 3, 4]
static 方法可以设计为泛型方法
因为T是实例化的时候传,而E和T没有关系
在for在调用时,已经指明泛型参数的类型
public static <E> List<E> COPY(E []arr){
ArrayList<E> list=new ArrayList<>();
for(E e:arr){
list.add(e);
}
return list;
}
泛型在继承上的体现
如果B是A的一个子类型(子类或者子接口),而G是具有泛型声明的
类或接口,G并不是G的子类型!
使用的时候要小心
向上造型的使用是对的