【3月17日】通过反射机制了解泛型的本质

本文通过Java代码示例深入探讨了泛型的本质及其在编译后的表现形式,并利用反射机制展示了如何绕过泛型的类型检查限制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package com.tree.reflect;

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

public class MethodDemo01 {
	/**
	 * 通过反射机制了解泛型的本质
	 */
	public static void main(String[] args) {
		ArrayList list = new ArrayList();
		ArrayList<String> list1=new ArrayList<String>();
		list1.add("Trey");
		//list1.add(20);这个会报错,只能add String类型
		Class c1=list.getClass();
		Class c2 = list1.getClass();
		//输出的结果是"true",也就是说list和list1的类类型是一样的
		//说明编译之后集合的泛型是去泛型化的
		System.out.println(c1==c2);
		//反射的操作都是编译之后的操作
		//java中集合的泛型,是防止错误输入而存在的,只在编译阶段有效,绕过编译之后就无效了
		//验证:通过方法的反射绕过编译
		try{
			Method m = c2.getMethod("add",Object.class);
			Object o = m.invoke(list1,20);
			//输出2,list1的长度为2,之前不能add的Trey现在add进去了
			System.out.println(list1.size());
			//输出[Trey,20]
			//注意,此时的list1不能通过foreach遍历,会报错:java.lang.Integer cannot be cast to java.lang.String
			System.out.println(list1);
		}catch(Exception e){
			e.printStackTrace();
		}
		
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值