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