---------------------- Android培训、java培训、期待与您交流! ----------------------
泛型:
jdk1.5后出现了泛型,没有使用泛型是,只要是对象,不管什么类型的对象,都可存储进同一个集合中。
使用泛型集合,可以将一个集合中的元素限定为一个特定类型,集合中只能存储同一类型的对象,这样更安全,
并且从集合获取一个对象时,编译器也可以知道这个对象的类型,不需要对对象进行强制类型转换。
泛型的?通配符:
Collection<?> collection ;
collection.add(1);//报错
collection.size();
collection = new HashSet<Date>();
注:使用?通配符可以引用其他各种参数化的类型,?通配符定义的变量主要用做引用,只能用与参数化无关的方法。
?通配符的扩展:
1,限定通配符的上边界:
Vector <? extends Number> x = new Vector<Integer>();
Vector<? super Integer> x = new Vector<Number>();//报错
2,限定通配符的下边界:
Vector<? super Integer> x = new Vector<Number>();
Vector<? super Integer> x = nrw Vector<Byte>();//报错
注:限定通配符总是包括自己。
泛型的综合练习,HashMap集合的操作:
HashMap<String,Integer> maps = new HashMap<String,Integer>();
maps.put("a",10);
maps.put("b",20);
maps.put("c",30);
Set<Map.Entry<String,Integer>> entrySet = maps.entrySet();
for(Map.Entry<String,Integer> entry : entrySet){
System.out.println(entry.getKey()+":"+entry.getValue());
}
定义泛型方法:
java中的泛型类似于c++的模板,jvm指令集的限制使java泛型仅限于表面,java泛型完全是编译器中实现的,是一种擦除技术。
public static <T> T add(T x, T y){ //返回值前加上<T>
return null;
}
Integer a1 = add(3,5);
Number a2 = add(3.5,5); //T取两个参数类型交集。
Object a3 = add(3,"abc");
public static <T> void swap(T[] a, int i, int j){
T tmp = a[i];
a[i] = a[j];
a[j] = tmp;
}
swap(new String[]{"abc","xyz","opq"},1,2);
swap(new int[]{1,2,3,4},2,3}; //报错,只有引用类型才能作为泛型方法的实际参数。
定义泛型类:
1,类中的泛型方法要保持同一个实际类型时,这时候就要采用泛型类的方式进行定义,也就是类级别的泛型。
格式:
public class <E> GenericDao{
private T field1;
public void save(T obj){}
public T getByld(int id){}
}
2,类级别的泛型根据引用该类名时指定的类型信息来参数化类型变量的:
GenericDao<String> dao = null;
new GenericDao<String>();
注:
1,在对泛型类进行参数化时,参数必须是引用类型,不能是基本数据类型。
2,静态方法不能有类级别的泛型参数。
}
---------------------- Android培训、java培训、期待与您交流! ----------------------