非常早的时候我就接触了泛型,可是那个时候并不了解泛型有什么优点,在抽象的过程中使用泛型,后来接触到了gxpt系统,这个系统框架中,用的是泛型方法.那个时候仅仅是知道这么用,说是能够解决反复写代码的问题,可是我并没有体会到,后来接触了Itoo 这个框架,这个里面用的是泛型类,同一时候我正在的參与到这个系统中,在跟gxpt相比,我体会到了使用泛型的优点.
一.介绍
泛型是Java SE 1.5的新特性。泛型的本质是參数化类型。也就是说所操作的数据类型被指定为一个參数。
这样的參数类型能够用在类、接口和方法的创建中,分别称为泛型类、泛型接口、泛型方法。
二.解决这个问题
在JDK1.5 还没有泛型的时候,通过使用类型Object的来实现參数的”随意化”.实现參数随意化须要对显式进行强制类型转换.并且这样的强制转换要求开发人员对实际參数类型是预知的.对于强制类型转换错误的情况,编译器可能不提示错误,在执行的时候才出现异常,这是一个非常大的安全隐患.假设使用泛型,就能够在编译阶段就发现这个错误,并且全部的强制转换都是自己主动和隐式的,再一次提高了代码的复用率.总结一句话就是泛型解决抽象过程中须要显式强制转换的问题,把主动变成被动,再次提高代码的复用率.
三.实例
无泛型,使用Object+强制转换实现抽象:
<span style="font-size:18px;">/** * 使用Object 类型,显示须要强制转换 * @author huan * */ public class NoGen { private Object ob; //定义泛型成员变量 public NoGen(Object ob){ this.ob=ob; } public Object Getob(){ return ob; } public void setOb(Object ob){ this.ob=ob; } public void showType(){ System.out.println("T的实际类型是:" +ob.getClass().getName()); } } public class GenDemo2 { public static void main(String[] args) { //定义泛型类NoGen 的一个Integer版本号 NoGen intOb=new NoGen(new Integer(88)); intOb.showType(); int i=(int) intOb.Getob(); System.out.println("Value="+i); System.out.println("------------------"); //定义泛型类Gen的一个String版本号 NoGen strOb=new NoGen("Hello Gen!"); strOb.showType(); String s=(String) strOb.Getob(); System.out.println("value="+s); } } </span>
相应类图:
使用泛型实现抽象:
<span style="font-size:18px;">public class Gen<T> { private T ob; //定义泛型成员变量 public Gen(T ob){ this.ob=ob; } public T Getob(){ return ob; } public void setOb(T ob){ this.ob=ob; } public void showType(){ System.out.println("T的实际类型是:" +ob.getClass().getName()); } } /** * 使用泛型 * @author huan * */ public class GenDemo { public static void main(String[] args) { //定义泛型类Gen 的一个Integer版本号 Gen<Integer> intOb=new Gen<Integer>(88); intOb.showType(); int i=intOb.Getob(); System.out.println("Value="+i); System.out.println("------------------"); //定义泛型类Gen的一个String版本号 Gen<String> strOb=new Gen<String>("Hello Gen!"); strOb.showType(); String s=strOb.Getob(); System.out.println("value="+s); } } </span>
相应类图:
从两张类图能够看出,Object+强制转换实现的抽象是被动的,使用泛型事项的抽象是主动的.使用主动替换被动,让封装的代码侵入性更小.
四.泛型类与泛型方法的差别
从作用域来说,泛型类的作用域要比泛型方法要小一些.使用泛型类所受到的限制要大一些.
从载入的情况来看,泛型类推迟了载入时间,属于懒载入.
五.总结
1.使用泛型,泛型的中的參数是地址传值还是按值传递.
答案:是地址传值
2.从复用性的角度来说,泛型类和泛型方法那个更好.gxpt运用的是泛型方法,itoo使用的泛型类.itoo使用泛型类是为了把底层进行进一步的封装.提高代码的复用率.
3.使用集合的时候都会用上泛型,那么容器是集合+方法,在容器中,泛型也是经常使用的。所以学习容器的时候,应该先理解泛型的思想.