泛型在java5出现后很大一定的程度都是为了让集合能记住其元素的数据类型。
1 泛型的用处
定义一个集合,没有定义添加的元素类型,在添加元素是,不会检查每个添加的元素的类型。
List lst_01=new ArrayList();
lst_01.add("111");
lst_01.add(5);
System.out.println(((String)lst_01.get(2)).length());
执行代码时将会出现
java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.String
在添加元素时,不会对添加的元素进行类型检查,这将会为程序造成一定的忧患。
改为下面,将不会出现问题。
List<String> lst_01=new ArrayList<String>();
lst_01.add("111");
lst_01.add("222");
System.out.println(((String)lst_01.get(1)).length());
在集合类后添加类型声明,表示只想保存字符串类型的List集合。如果出现添加了其它类型的集合,将发出警报。
在java7之后,在调用构造器创建对象时构造器的后面可不带泛型。
如上的代码可写成:
List<String> lst_01=new ArrayList<>();
在java中根本不存在List这个类。List和List和List均为同一个类。
2 类型通配符之定义类
2.1 设置通配符的上限
public static void main(List<? extends Object> lst){
}
List
public class Text_02<T entends Integer & java.io.Serializable>{
3 类型通配符之泛型方法
public static <T> void main(T str){
}
无需传递类型,编译器自动根据实参判断类型形参的值。
4 类型通配符和泛型方法:
/**
* 类型通配符
*/
class interface Collection<E>{
boolean containsAll(Collection<?> c);
boolean addAll(Collection<? extends E> c);
}
将类型通配符转为泛型方法
/**
* 泛型方法
*/
class interface Collection<E>{
<T> boolean containsAll(Collection<T> c);
<T extends E>boolean addAll(Collection<T> c);
}
5 设定通配符下限
public static T <T> copy(Collection<? super T> dest,Collection<T> src){
}