集合泛型的本质分析

package com.test.test;

import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.List;

/**
 * 集合泛型的本质
 * @author zengchaowang
 *
 */
public class Test4 {

	public static void main(String[] args) {
		List list1 = new ArrayList();
		List<String> list2 = new ArrayList<String>(10);
		list2.add("test1");
		// list2.add(2);编译报错
		Class c1 = list1.getClass();
		Class c2 = list2.getClass();
		System.out.println(c1 == c2);
		System.out.println("======================");
		try {
			Method m1 = c2.getMethod("add", Object.class);
			m1.invoke(list2, 20);
			System.out.println(list2.size());
			System.out.println(list2);
			/*
			 * for (String string : list1) 
			 * { 
			 *      System.out.println(string); 
			 * }
			 */// 遍历报错,类型不一致
		} catch (NoSuchMethodException e) {
			e.printStackTrace();
		} catch (SecurityException e) {
			e.printStackTrace();
		} catch (IllegalAccessException e) {
			e.printStackTrace();
		} catch (IllegalArgumentException e) {
			e.printStackTrace();
		} catch (InvocationTargetException e) {
			e.printStackTrace();
		}
	}

}
运行结果如下
true
======================
2
[test1, 20]

上面的代码可以看出:====》未指定类型的集合和指定类型的集合在编译后类类型是一致的;使用反射方式绕过编译操作可以将类型不相同的数据放入到集合中。

结论:

(1)反射操作都是编译之后的操作,即字节码操作;

(2)从使用上来说,java集合的泛型是防止错误输入的,只在编译阶段有效,绕过编译就无效了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值