通過反射了解集合泛型本質

通過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中集合的泛型是防止錯誤輸入的,只在編譯階段有效,在運行時期就會失效。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章