可理解为 适配广泛的类型,即参数化类型,可以把类型像方法的参数那样进行传递。
// 以ArrayList为示例
// 泛型T可以是任意类
public class ArrayList<T> {
private T[] array;
//...
}
// 通过泛型的使用,就可创建多种类型的ArrayList
// 1. 可存储String的ArrayList:
ArrayList<String> strList = new ArrayList<String>();
// 相当于
public class ArrayList<String> {
private String[] array;
//...
}
// 2. 可存储Float的ArrayList:
ArrayList<Float> floatList = new ArrayList<Float>();
// 相当于
public class ArrayList<Float> {
private Float[] array;
//...
}
通过定义一种模板方式结构,从而保证类型安全 & 匹配。下面将用ArrayList为示例作为说明。
ArrayList的本质:一个可变的Object类型数组
public class ArrayList {
private Object[] array;
// ...
}
在使用ArrayList存储不同类型时,需要强转类型,不然容易出现ClassCastException异常。如存储String类型:
// 获取到ArrayList里的Object类型时,必须强制转型为String
// 不然容易出现ClassCastException异常
ArrayList list = new ArrayList();
list.add("carson ho");
String first = (String) list.get(0);
使用泛型将ArrayList变成一种模板:ArrayList,就可以创建任意类型的ArrayList。即:
// 泛型T可以是任意类
public class ArrayList<T> {
private T[] array;
//...
}
// 多种类型
// 1. 可存储String的ArrayList:
ArrayList<String> strList = new ArrayList<String>();
// 相当于
public class ArrayList<String> {
private String[] array;
//...
}
// 2. 可存储Float的ArrayList:
ArrayList<Float> floatList = new ArrayList<Float>();
// 相当于
public class ArrayList<Float> {
private Float[] array;
//...
}
基于 类型擦除。即即 使用泛型时加上的类型参数,会在编译器在编译时去掉所以,在生成的 Java 字节码中,不包含泛型中的类型信息。这里需要特别说明的是:
同时需要特别注意的是:
不能。具体描述如下:
// 代码1和代码2相同
// 代码1
List<String> strings = new LinkedList<String>( );
List<Integer> ints = new LinkedList<Integer>( );
// 代码2
List strings = new LinkedList( );
List ints = new LinkedList( );
// 转换方式可以是如下:
List ss=strings;
List<Object> objects=ss;
至此,关于Java中的泛型讲解完毕。