为什么使用泛型
1.解决元素存储安全性问题
1.解决元素存储安全性问题
2.解决获取元素时需要类型强转问题
首先举一个例子 没有使用泛型时候的Arrylist例子 不适用泛型的话 任何Object都可以传入Arraylist
加入传入三个int型和一个String型 输出的时候强转为int型就会抛出Classcastexception异常
代码如图:
package pers.Hx.day922;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set;
import org.junit.Test;
//泛型的使用
public class TestGeneric {
//1.在集合中没有使用泛型的情况下
@Test
public void test(){
List list = new ArrayList();
list.add(89);
list.add(99);
list.add(100);
//1.没有使用泛型任何Object及其子类都可以添加进来
list.add(new String("BB"));
for(int i = 0; i<list.size();i++){
//2.强转为int型时,可能报ClasscastException的异常
int score = (int)list.get(i);
System.out.println(score);
}
}
然后第二个例子如何在Arraylist中使用泛型
使用泛型后就只能够添加int型数组这样就解决了安全性和类型强转错误
//2.在集合中使用泛型
@Test
public void test2(){
List<Integer> list = new ArrayList<Integer>();
list.add(99);
list.add(92);
// list.add("AA"); //报错只能是int 类型
// for(int i = 0; i<list.size();i++){
// //2.强转为int型时,可能报ClasscastException的异常
// int score = list.get(i);
// System.out.println(score);
// }
Iterator<Integer> it = list.iterator(); //iterator java轻量级迭代器
while(it.hasNext()){
System.out.println(it.next());
}
}
3.最后再举一个在Map使用泛型的例子
//3.在Map中使用泛型
@Test
public void test3(){
Map<String,Integer> map = new HashMap<String,Integer>();
map.put("AA", 41);
map.put("BB", 42);
map.put("CC", 43);
Set<Map.Entry<String,Integer>> set = map.entrySet();
for(Map.Entry<String,Integer> o:set){
System.out.println(o.getKey()+o.getValue());
}
}