泛型
1.不使用泛型会出现的问题
在同一个数组中能够输入不同类型的值,会造成数据类型不统一,从而会出现类型转换失败等问题
public void test1(){
List list=new ArrayList();
list.add(89);
list.add(88);
//没有使用泛型,任何object及其子类的对象都可以添加进来
list.add("AA");
for (int i=0; i<list.size();i++){
//强转为int型时,可能报ClassCastException的异常
int score =(Integer)list.get(i);
System.out.println(score);
}
}
2.使用泛型
在输入类型的地方有了限制,也就不能输入其他类型的数据了,从而能够达到集合中类型统一的效果
List<Integer> list1=new ArrayList<>();
list1.add(87);
list1.add(55);
// list1.add("AA");
for (int i=0;i<list1.size();i++){
int score= (int) list1.get(i);
System.out.println(i);
}
定义泛型的写法
Map<String,Integer> map=new HashMap<String,Integer>();
jdk7.0以后
可以省略后面<>里的内容
List<Integer>list1=newArrayList<>();
自定义泛型类、泛型接口、泛型方法
1.当实例化泛型类的对象时,指明泛型的类型,指明以后对应的类中所有使用泛型的位置,都变为实例化中指定的泛型类型
public T getT() {
return t;
}
public void setT(T t) {
this.t = t;
}
private T t;
List<T> list=new ArrayList<>();
public void add(){
list.add(t);
}
2.如果自定义泛型类,但是实例化时没有使用,那么默认类型为Object
泛型方法:
public <E> E getE(E e){
return e;
}
使用泛型方法时,需要指明类型
3.泛型与继承的关系
若类A是类B的子类,那么List就不是List的子接口
4.通配符
?
List<?> list= null;
List<Object> list1=new ArrayList<Object>();
List<String> list2=new ArrayList<String>();
list=list1;
list=list2;
List<A> List<B>…….都是List<?>的子类
? extends A :可以存放A及其子类
? super A :可以存放A及其父类
注意:
不可以在 static 方法中使用泛型的声明
不可以在try-catch中使用类的泛型的声明
不允许向声明为通配符的集合类中写入对象( null 可以存入),可以读取