一、java泛型的好处
1,类型安全。 泛型的主要目标是提高 java 程序的类型安全。通过知道使用泛型定义的变量的类型限制,编译器可以在一个高得多的程度上验证类型假设。没有泛型,这些假设就只存在于程序员的头脑中(或者如果幸运的话,还存在于代码注释中)。
2,消除强制类型转换。 泛型的一个附带好处是,消除源代码中的许多强制类型转换。这使得代码更加可读,并且减少了出错机会。
3,潜在的性能收益。 泛型为较大的优化带来可能。在泛型的初始实现中,编译器将强制类型转换(没有泛型的话,程序员会指定这些强制类型转换)插入生成的字节码中。但是更多类型信息可用于编译器这一事实,为未来版本的 jvm 的优化带来可能。由于泛型的实现方式,支持泛型(几乎)不需要 jvm 或类文件更改。所有工作都在编译器中完成,编译器生成类似于没有泛型(和强制类型转换)时所写的代码,只是更能确保类型安全而已。
二、使用
普通版本
`public void write(integer i, integer[] ia);
public void write(double d, double[] da);`
泛型版本
<code>public <t> void write(t t, t[] ta);</code>
三、定义泛型
1,定义在类后面
<code>public class testclassdefine<t, s extends t>{}</code>
定义泛型 t, s, 且s 继承 t
2,定义在方法装饰符后面
<code>public <t, s extends t> t testgenericmethoddefine(t t, s s){}</code>
四、实例化泛型
1,实例化定义在类上的泛型
第一声明类变量或者实例化时。例如
第二继承类或者实现接口时。例如
<code>public class mylist<e> extends arraylist<e> implements list<e> {...}</code>
2,实例化定义方法上的泛型
当调用范型方法时,编译器自动对类型参数(泛型)进行赋值,当不能成功赋值时报编译错误
五、通配符(?)
上面有泛型的定义和赋值;当在赋值的时候,上面说赋值的都是为具体类型,当赋值的类型不确定的时候,我们用通配符(?)代替了:
如