이 기사는 위의 "Reflection Method Reflection의 기본 작업"에서 이어집니다. Java 컬렉션에서 제네릭의 본질을 이해하려면 리플렉션을 사용하세요
1. 두 개의 컬렉션을 초기화합니다. 하나는 제네릭을 사용하고 다른 하나는
1 ArrayList list1 = new ArrayList();2 ArrayList<String> list2 = new ArrayList<String>();
2. 정의된 유형이 있는 경우 int 유형을 list2에 추가하면 오류가 보고됩니다
1 list2.add("Hello");2 list2.add(20); //报错
3. 비교를 위해 두 개체의 클래스 유형을 가져옵니다
1 Class c1 = list1.getClass();2 Class c2 = list2.getClass();3 System.out.println(c1 == c2);
c1==c2 결과가 true를 반환하여 이를 나타냅니다. Java에서 컬렉션의 제네릭은 잘못된 입력을 방지하기 위한 것입니다. 컴파일 단계에서만 유효합니다. 4. 확인: 메소드 리플렉션을 통해 컴파일을 우회합니다.
1 try {2 Method m = c2.getMethod("add", Object.class);3 m.invoke(list2,20);4 System.out.println(list2);5 } catch (Exception e) {6 e.printStackTrace();7 }
6, 전체 코드
1 package com.format.test; 2 3 import java.lang.reflect.Method; 4 import java.util.ArrayList; 5 6 /** 7 * Created by Format on 2017/6/4. 8 */ 9 public class Test2 {10 public static void main(String[] args) {11 ArrayList list1 = new ArrayList();12 ArrayList<String> list2 = new ArrayList<String>();13 list2.add("Hello");14 // list2.add(20); //报错15 Class c1 = list1.getClass();16 Class c2 = list2.getClass();17 System.out.println(c1 == c2);18 /**19 * 反射操作都是编译之后的操作20 * c1==c2结果返回true,说明编译之后集合的泛型是去泛型化的21 * java中集合的泛型是为了防止错误输入的,只在编译阶段有效,绕过编译就无效了22 * 验证:通过方法的反射来绕过编译23 */24 try {25 Method m = c2.getMethod("add", Object.class);26 m.invoke(list2,20);27 System.out.println(list2);28 } catch (Exception e) {29 e.printStackTrace();30 }31 }32 }
위 내용은 Reflection: 리플렉션을 통한 컬렉션 제네릭의 본질 이해의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!