泛型就是把原來的類名進行了延長
一下是一個簡單的例子:
package javatribe.fts.generic;
import java.util.ArrayList;
public class GenericTest {
/**
* @param args
*/
public static void main(String[] args) throws Exception{
// TODO Auto-generated method stub
ArrayList collection=new ArrayList();
collection.add(1);
collection.add(1L);
collection.add("aaaaa");
//int i=(Integer)collection.get(1);
ArrayList<String> collection1=new ArrayList<String>();
//collection1.add(1);
//collection1.add(1L);
collection1.add("aaaaa");
String str=collection1.get(0);
System.out.println(str);
ArrayList<Integer> collection2=new ArrayList<Integer>();
collection2.add(1);
System.out.println(collection1.getClass()==collection2.getClass());
collection2.getClass().getMethod("add", Object.class).invoke(collection2, "abc");
System.out.println(collection2.get(1));
}
}
輸出結果爲:
aaaaa
true
abc
看如下代碼,定義一個類型爲整型集合,然後add一個整數進去,要是add一個字符串進去會提示錯誤。但是用反射機制傳入一個字符串反而可以的。因爲反射是在運行期起作用的,二泛型主要是給編譯器看的ArrayList<Integer> collection2=new ArrayList<Integer>();
collection2.add(1);
System.out.println(collection1.getClass()==collection2.getClass());
collection2.getClass().getMethod("add", Object.class).invoke(collection2, "abc");
System.out.println(collection2.get(1));
所以由以上例子輸出結果可以分析得到泛型是提供給javac編譯器使用的,可以限定集合中的輸入類型,讓編譯器擋住源程序中的非法輸入,編譯器編譯帶類型說明的集合時會去除掉“類型”信息,使程序運行效率不受影響,對於參數化的泛型類型,getClass()方法的返回值和原始類型完全一樣。由於編譯生成的字節碼會去掉泛型的類型信息,只要能跳過編譯器,就可以往某個泛型集合中加入其它類型的數據,例如,用反射得到集合,再調用其add方法即可。