通過ArrayList集合來進行測試:
import java.util.ArrayList;
public class FanXingTest {
public static void main(String[] args) {
ArrayList list1 = new ArrayList();
ArrayList<String> list2 = new ArrayList<String>();
list2.add("hello");
// list2.add(20); //編譯時期由於泛型的作用,這條語句會報錯
// 運行時刻動態加載類
Class c1 = list1.getClass();
Class c2 = list2.getClass();
System.out.println(c1 == c2); // true
}
}
反射操作都是編譯之後的操作(變成字節碼之後),是運行時期的操作。
從上面的結果可以看出編譯之後集合的泛型是去泛型化的
下面通過反射來驗證:泛型繞過編譯無效
import java.lang.reflect.Method;
import java.util.ArrayList;
public class FanXingTest {
public static void main(String[] args) throws Exception {
ArrayList list1 = new ArrayList();
ArrayList<String> list2 = new ArrayList<String>();
list2.add("hello");
// 運行時刻動態加載類
Class c1 = list1.getClass();
Class c2 = list2.getClass();
Method m = c2.getMethod("add", Object.class); // 方法名以及參數類型(寫爲Object類型,這樣所有類型都可以添加)
// 通過invoke方法調用目標類的方法 將20添加進list2中
m.invoke(list2, 20);
System.out.println(list2.size()); // 2
System.out.println(list2); // [hello, 20]
}
}
經過上面的測試,說明Java中集合的泛型是防止錯誤輸入的,只在編譯階段有效,在運行時期就會失效。