集合容器类在设计阶段/声明阶段不能确定这个容器到底实际存的是什么类型的对象, 所以在JDK1.5之前只能把元素类型设计为Object, JDK1.5之后使用泛型来解决。 因为这个时候除了元素的类型不确定, 其他的部分是确定的, 例如关于这个元素如何保存, 如何管理等是确定的, 因此此时把元素的类型设计成一个参数, 这个类型参数叫做泛型。 那为什么要使用泛型而不是直接用Object来存储数据呢?
使用泛型可以解决元素存储的安全性问题(只有指定类型才可以添加到集合中)使用泛型可以解决获取数据元素时,需要类型强转的问题Java泛型可以保证如果程序在编译时没有发出警告,运行时就不会产生ClassCastException异常(能够在编译时而不是在运行时检测错误)。同时,代码更加简洁、健壮。所谓泛型, 就是允许在定义类、 接口时通过一个标识表示类中某个属性的类型或者是某个方法的返回值及参数类型。 这个类型参数将在使用时(例如,继承或实现这个接口, 用这个类型声明变量、 创建对象时) 确定(即传入实际的类型参数, 也称为类型实参) 。从JDK1.5以后, Java引入了“参数化类型( Parameterized type) ” 的概念,允许我们在创建集合时再指定集合元素的类型, 正如: List, 这表明该List只能保存字符串类型的对象。JDK1.5改写了集合框架中的全部接口和类, 为这些接口、 类增加了泛型支持,从而可以在声明集合变量、 创建集合对象时传入类型实参。
下面看看两个在集合中使用泛型的例子
ArrayList<Integer> list = new ArrayList<>();//类型推断 list.add(78); list.add(88); list.add(77); list.add(66); //遍历方式一: //for(Integer i : list){ //不需要强转 //System.out.println(i); //} //遍历方式二: Iterator<Integer> iterator = list.iterator(); while(iterator.hasNext()){ System.out.println(iterator.next()); } Map<String,Integer> map = new HashMap<String,Integer>(); map.put("Tom1",34); map.put("Tom2",44); map.put("Tom3",33); map.put("Tom4",32); //添加失败 //map.put(33, "Tom"); Set<Entry<String,Integer>> entrySet = map.entrySet(); Iterator<Entry<String,Integer>> iterator = entrySet.iterator(); while(iterator.hasNext()){ Entry<String,Integer> entry = iterator.next(); System.out.println(entry.getKey() + "--->" + entry.getValue()); }