在集合中使用泛型自定义泛型结构泛型在继承上的体现通配符的使用泛型应用举例
在集合中使用泛型① 集合接口或集合类在jdk5.0时都修改为带泛型的结构。
② 在实例化集合类时,可以指明具体的泛型类型
③ 指明完以后,在集合类或接口中凡是定义类或接口时,内部结构(比如:方法、构造器、属性等)使用到类的泛型的位置,都指定为实例化的泛型类型。
比如:add(E e) —>实例化以后:add(Integer e)
④ 注意点:泛型的类型必须是类,不能是基本数据类型。需要用到基本数据类型的位置,拿包装类替换
⑤ 如果实例化时,没有指明泛型的类型。默认类型为java.lang.Object类型。]
泛型类、泛型接口;泛型方法。见 GenericTest
泛型在继承上的体现通配符的使用泛型在继承方面的体现
虽然类A是类B的父类,但是G 和 G二者不具备子父类关系,二者是并列关系。
补充:类A是类B的父类,A
是 B 的父类
这里是引用通配符的使用
通配符:?
类A是类B的父类,G和G是没有关系的,二者共同的父类是:G>
添加(写入):对于List>就不能向其内部添加数据。除了添加null之外。
获取(读取):允许读取数据,读取的数据类型为Object。
有限制条件的通配符:
泛型应用举例? extends A:
G extends A> 可以作为G和G的父类,其中B是A的子类 <= (-∞, A] 不能加比A小的子类B,有可能比B小
? super A:
G super A> 可以作为G和G的父类,其中B是A的父类 >=. [A, +∞)
Map
map.put(“Aobama”, 43);
//遍历value
Collection values = map.values();
Iterator iterator = values.iterator();
while (iterator.hasNext()){
System.out.println(iterator.next());
}
//遍历key-value
Set
Iterator
while (iterator1.hasNext()){
Map.Entry
String string = entry.getKey();
Integer value = entry.getValue();
System.out.println(string +" ,"+ value);
}



