通過反射認識泛型的本質

言曌發表於2018-03-03

通過 Class 和 Method 來認識泛型的本質,在編譯階段驗證是否有錯誤。

如果我們繞過編譯就繞過泛型。

 

來看一個demo

  1. package practice.Reflect;
  2. import java.lang.reflect.Method;
  3. import java.util.ArrayList;
  4. /**
  5.  * @Author: 言曌
  6.  * @Date: 2017/11/17
  7.  * @Time: 上午10:27
  8.  */
  9. public class MethodDemo2 {
  10.     public static void main(String args[]) {
  11.         //什麼型別都可以新增
  12.         ArrayList list = new ArrayList();
  13.         list.add("hello");
  14.         list.add(2017);
  15.         list.add(true);
  16.         System.out.println(list);
  17.         //只能新增String型別的元素
  18.         ArrayList<String> list1 = new ArrayList<String>();
  19.         list1.add("hello");
  20.         //list1.add(2017);//錯誤
  21.         Class c1 = list.getClass();
  22.         Class c2 = list1.getClass();
  23.         System.out.println(c1 == c2);//true
  24.         //反射的操作都是編譯之後的操作
  25.         /**
  26.          * c1==c2結果返回true說明編譯之後集合的泛型是去泛型化的
  27.          * Java中集合的泛型,是防止錯誤輸入的,只在編譯階段有效
  28.          * 繞過編譯就無效了
  29.          * 驗證:我們可以通過方法的反射來操作,繞過編譯
  30.          */
  31.         try {
  32.             Method m = c1.getMethod("add",Object.class);
  33.             m.invoke(list1,100);//繞過編譯就繞過了泛型
  34.             System.out.println(list1.size());
  35.             System.out.println(list1);
  36.         } catch (Exception e) {
  37.             e.printStackTrace();
  38.         }
  39.         //最終我們確定,Class,Method,Field,反射操作 都是繞過編譯的,都是在執行時刻來執行的
  40.     }
  41. }

 

最終我們得出結論,Class,Method,Field,反射操作 都是繞過編譯的,都是在執行時刻來執行的  。

相關文章