转载请注明:http://blog.csdn.net/uniquewonderq
通过Class,Method来认识泛型的本质
反射的操作都是编译之后的操作,即运行时刻进行操作
c1==c2结果返回true,说明编译之后,集合的泛型是去泛型化的
就是说编译之后这个集合没有泛型了。
java中集合的泛型是防止错误输入的,只在编译阶段有效,
过了编译就无效了。
验证:我们可以通过方法的反射来操作,绕过编译
package com.test; import java.lang.reflect.Method; import java.util.ArrayList; /** * * @author wonderq */ public class within { public static void main(String[] args) { ArrayList list=new ArrayList(); ArrayList<String> list1=new ArrayList<String>(); list1.add("hello"); // list1.add(5); 错误的 Class c1=list.getClass(); Class c2=list1.getClass(); System.out.println("c1==c2? "+(c1==c2)); System.out.println("c1和c2分别是:"+c1.getName()+","+c2.getName()); /* 反射的操作都是编译之后的操作,即运行时刻进行操作 c1==c2结果返回true,说明编译之后,集合的泛型是去泛型化的 就是说编译之后这个集合没有泛型了。 java中集合的泛型是防止错误输入的,只在编译阶段有效, 过了编译就无效了。 验证:我们可以通过方法的反射来操作,绕过编译 */ try { Method m=c2.getMethod("add", Object.class); m.invoke(list1, 100);//本来里面是加入String类型的对象,现在加入一个100 //我们看看能不能加进去。 System.out.println(list1.size()); System.out.println(list1); //是可以加进去的,现在就绕过了泛型,因为反射的操作都是编译之后的操作 for(String string:list1){ System.out.println(string); }//此时打印不出来里面的int 类型的100这个数 } catch (Exception e) { } } }
运行结果:
run:
c1==c2? true
c1和c2分别是:java.util.ArrayList,java.util.ArrayList
2
[hello, 100]
hello
可以看出来,反射的操作,class
,method 等,都是绕过编译,在运行时刻运行。
Java--Reflect(反射)专题6——通过反射了解集合泛型的本质
原文地址:http://blog.csdn.net/uniquewonderq/article/details/46592277