什么是泛型
类比于方法中的形参,约束了传递进入方法的参数类型,泛型就是一种约束,定义泛型后,约束了进入容器的类的类型:
List<String> arr=new ArrayList<String>();//“<>”里的就是泛型类型
List容器我们都知道,可以存放任何类型的元素,如下:
关于Java容器详见我的blog:Java容器
但是,像上面那样在list后面加上后,能够存入arr的元素就被限制为String类型,如果加上一段代码如下:
list.add(12);
在编译的时候就会报错:
java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.String
这里就要引入泛型的一个特性:
只在编译的时候对泛型进行有效判断,判断后就将泛型信息擦除,不会进入运行阶段
泛型的用法
泛型类
在前面我们讨论的List的泛型约束用法,因为List本身就是个泛型类,所以我们可以在实现实例时直接在<>中添加元素类型。
如果我们想用自己写的类来使用泛型,必须在类定义时定义为泛型类:
class A<T>{}
A<String> str=new A<String>();
其中,T叫做类型参数变量,String叫做实际类型参数。
泛型类也可以被继承,继承的两种方式,可以继续选择不限制类型:
class B<T> extends A<T>{
public<T> void outV(T t){}
}
也可以选择对传入类型进行限制:
class B extends A<String>{
public void outV(String str){}
}
注意两者区别
泛型方法
如果不想对进入容器的元素类型进行限制,可以不声明类型:
class A<T>{}
A str=new A();
这样,进入str的元素并不受泛型约束,
如果A中实现定义了一个泛型方法:
public <T> void outV(T t){
System.out.println(t);
}
那么str可以直接调用outV方法,并且传入的参数类型不受限制,传入什么类型,就输出什么类型
str.outV(123);
str.outV("qwe");
以上都是合法的