首先看下面这个例子
public static void main(String[] args) {
ArrayList<Integer> al1 = new ArrayList<Integer>();
al1.add(1);
ArrayList<String> al2 = new ArrayList<String>();
al2.add("hello");
//int型链表和string型链表,结果为true
System.out.println(al1.getClass()==al2.getClass());
}
这说明编译器编译带参数说明的集合时会去掉类型的信息,转化为普通的链表,所以运行时,将不会受到泛型的影响。所以可以这样来绕开泛型的限制:
public static void main(String[] args) throws Exception {
//定义一个包含int的链表
ArrayList<Integer> al = new ArrayList<Integer>();
al.add(1);
al.add(2);
//获取链表的add方法,注意这里是Object.class,如果写int.class会抛出NoSuchMethodException异常
Method m = al.getClass().getMethod("add", Object.class);
//调用反射中的add方法加入一个string类型的元素,因为add方法的实际参数是Object
m.invoke(al, "hello");
System.out.println(al.get(2));
}