Java中泛型的用法总结
本文实例总结了Java中泛型的用法。分享给大家供大家参考。具体如下:
1基本使用
publicinterfaceList<E>{ voidadd(E); Iterator<E>iterator(); }
2泛型与子类
Child是Parent的子类,List<Child>却不是List<Parent>的子类。
因此:List<Object>list=newArrayList<String>()是错误的。
如果上面是正确的,那么:
List<String>ls=newArrayList<String>();//1 List<Object>lo=ls;//2 lo.add(newObject());//3 Strings=ls.get(0);//4,将object转换为string将失败。
3wildcards
因为2的原因,下面的实现用于统配集合的输出是不行的
voidprintCollection(Collection<Object>c){ for(Objecto:c){ //dosomething } }
因此,需要通配符?:
voidprintCollection(Collection<?>c){ for(Objecto:c){//1 //dosomething } }//ok
此处的?表示类型未知,但是任何对象均是Object,因此上例的1是正确的。但下例却是错误的:
voidadd(Collection<?extendsMyClass>c){ c.add(newMyClass());//wrong }//ok
原因也很明确,?extendsMyClass说明类型是MyClass的子类,但是却并不知道具体类型
4.泛型方法
上例可以实现为:
<T>add(Collection<T>c,Tt){ c.add(t); }
编译器在保证语义的前提,会帮忙做类型的转换工作。
5.泛型运行时的对比
List<String>l1=newArrayList<String>(); List<Integer>l2=newArrayList<Integer>(); System.out.println(l1.getClass()==l2.getClass());//true
因为泛型类运行时时一样的。
6泛型数组(可能导致类型不安全)
List<String>[]lsa=newArrayList<String>[10];//error
如果可以的话,可能导致类型不安全。如:
Objecto=lsa; Object[]oa=(Object[])o; List<Integer>li=newArrayList<Integer>(); li.add(newInteger(3)); oa[1]=li; Strings=lsa[1].get(0);//runtimeerror
希望本文所述对大家的java程序设计有所帮助。