1、概念
泛型,即“参数化类型”。一提到参数,最熟悉的就是定义方法时有形参,然后调用此方法时传递实参。那么参数化类型怎么理解呢?顾名思义,就是将类型由原来的具体的类型参数化,类似于方法中的变量参数,此时类型也定义成参数形式(可以称之为类型形参),然后在使用/调用时传入具体的类型(类型实参)。
泛型的本质是为了参数化类型(在不创建新的类型的情况下,通过泛型指定的不同类型来控制形参具体限制的类型)。也就是说在泛型使用过程中,操作的数据类型被指定为一个参数,这种参数类型可以用在类、接口和方法中,分别被称为泛型类、泛型接口、泛型方法。
2、举例
List arrayList = new ArrayList();
arrayList.add("aaaa");
arrayList.add(100);
for(int i = 0; i< arrayList.size();i++){
String item = (String)arrayList.get(i);
Log.d("泛型测试","item = " + item);
}
运行结果,跟预想的差不多,编译貌似没有问题,运行依旧报错:
java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.String
3、问题原因:Integer类型不能强制转换为String类型。
4、问题解决:在声明List集合时,就确定集合元素的类型,不符合的类型在编译时就会报错。
List<String> arrayList = new ArrayList<String>(); ... //arrayList.add(100); 在编译阶段,编译器就会报错
通过泛型,完美解决类型转换异常。
5、拓展
泛型的有效周期:只在编译时有效,运行时无效。
List<String> stringArrayList = new ArrayList<String>();
List<Integer> integerArrayList = new ArrayList<Integer>();
Class classStringArrayList = stringArrayList.getClass();
Class classIntegerArrayList = integerArrayList.getClass();
if(classStringArrayList.equals(classIntegerArrayList)){
Log.d("泛型测试","类型相同");
}
运行结果:输出结果:D/泛型测试: 类型相同
。
6、泛型的使用:泛型类、泛型接口、泛型方法
泛型类:public class Student<T>{}
泛型接口:public interface Student<T>{
public T next();
}
泛型方法:
public T test(T t){
return t;
}