标签:
class A<T> {
}
?
A<String> a = new A<String>();
* 如果创建实例时,不给类型变量赋值,那么会有一个警告!
?
class A<T> {
public T fun(T t1) {}
}
fun()方法不是泛型方法!它是泛型类中的一个方法!
?
public <T> T fun(T t1) {} --> 它是泛型方法
?
* 泛型方法与泛型类没什么关系,泛型方法不一定非要在泛型类中!
?
* 泛型类中使用泛型:
> 成员类型
> 返回值和参数类型
> 局部变量的引用上
class A<T> {
private T bean;//泛型可在成员变量上使用
public T fun(T t) {}//泛型可以在类中的方法上(返回值和参数类型)使用!
?
public void fun2() {//泛型还可以在局部变量的引用类型上使用
T b = ...
new T();//不行的!
}
}
?
=========================================
?
class A<T> {}
?
class AA extends A<String> {} //不是泛型类,只是它爸爸是泛型类!
?
?
* 子类不是泛型类:需要给父类传递类型常量
> 当给父类传递的类型常量为String时,那么在父类中所有T都会被String替换!
* 子类是泛型类:可以给父类传递类型常量,也可以传递类型变量
?
class AA1 extends A<Integer> {}
?
class AA3<E> extends A<E> {}
?
=========================================
使用场景:方法中的形参!
优点: 使方法更加通用!
?
无界通配:?
子类限定:? extends Object 表示:通配 Object 类型的所有子类型
父类限定:? super Integer 表示:通配 Integer 类型以及其父类型
代码演示:
public class Demo2 { ????/** ???? * @function:演示泛型的由来 ???? */ ????@Test ????public void fun1() ????{ ????????Object[] objs = new Object[10]; ????????List list = new ArrayList(); ? ????????String[] strs = new String[10]; ????????List<String> strList = new ArrayList<String>(); ? ????????Object[] objArray = new String[10]; ????????objArray[0] = new Integer(100);// 会抛出ArrayStoreException ????????// List<Object> objList = new ArrayList<String>(); ????????// objList.add(new Integer(100)); ????????/* ???????? * 泛型引用和创建两端,给出的泛型变量必须相同! ???????? */ ????} ? ????/* ???? * 其中的?就是通配符 通配符只能出现在左边!即不能在new时使用通配符!!! List<?> list = new ???? * ArrayList<String>(); ???? */ ????/* ???? * ?它表示一个不确定的类型,它的值会在调用时确定下来 ???? */ ????public void print(List<?> list) ????{ ????????/* ???????? * 当使用通配符时,对泛型类中的参数为泛型的方法起到了副作用,不能再使用! ???????? */ ????????// list.add("hello"); ????????/* ???????? * 当使用通配符时,泛型类中返回值为泛型的方法,也作废了! ???????? */ ????????Object s = list.get(0); ????????/* ???????? * 通配符好处:可以使泛型类型更加通用!尤其是在方法调用时形参使用通配符! ???????? */ ????} ????/** ???? * @function:演示通配符 ? ???? */ ????public void fun2() ????{ ????????List<Integer> integerList = new ArrayList<Integer>(); ????????print(integerList); ? ????????List<String> stringList = new ArrayList<String>(); ????????print(stringList); ????} ? ????/* ???? * 给通配符添加了限定: 只能传递Number或其子类型 子类通配符对通用性产生了影响,但使用形参更加灵活 ???? */ ????public void print1(List<? extends Number> list) ????{ ????????/* ???????? * 参数为泛型的方法还是不能使用 ???????? */ ????????// list.add(new Integer(100)); ????????/* ???????? * 返回值为泛型的方法可用了! ???????? */ ????????Number number = list.get(0); ????} ? ????/** ???? * @function:演示 子类限定:? extends Object ???? */ ????public void fun3() ????{ ????????List<Integer> intList = new ArrayList<Integer>(); ????????print1(intList); ? ????????List<Long> longList = new ArrayList<Long>(); ????????print1(longList); ????} ? ????/* ???? * 给通配符添加了限定 只能传递Integer类型,或其父类型 ???? */ ????public void print2(List<? super Integer> list) ????{ ????????/* ???????? * 参数为泛型的方法可以使用了 ???????? */ ????????list.add(new Integer(100)); ????????/* ???????? * 返回值为泛型的方法,还是不能使用 ???????? */ ????????Object obj = list.get(0); ????} ????/** ???? * @function:演示 父类限定:? super Integer ???? */ ????public void fun4() ????{ ????????List<Integer> intList = new ArrayList<Integer>(); ????????print2(intList); ? ????????List<Number> numberList = new ArrayList<Number>(); ????????print2(numberList); ? ????????List<Object> objList = new ArrayList<Object>(); ????????print2(objList); ????} ? } |
?
使变量使用上不再方便
无界通配:参数和返回值为泛型的方法,不能使用!
子类限定:参数为泛型的方法不能使用
父类限定:返回值为泛型的方法不能使用
?
boolean addAll(Collection<E> c)
List<Number> numList = new ArrayList<Number>();
List<Integer> intList = new ArrayList<Integer>();
numList.addAll(intList);//addAll(Collection<Number> c), 传递的是List<Integer>
boolean addAll(Collection<? extends E> c)
List<Number> numList = new ArrayList<Number>();
List<Integer> intList = new ArrayList<Integer>();
numList.addAll(intList);//addAll(Collection<? extends Number> c), 传递的是List<Integer>
?
标签:
原文地址:http://www.cnblogs.com/Prozhu/p/5456645.html