通过反射了解集合泛型的本质

本文通过实例演示了Java中泛型的实际应用与反射机制的工作原理。重点介绍了如何使用反射绕过泛型检查,并展示了编译后泛型的实际效果。

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

通过Class,Method来认识泛型的本质
直接上我写得代码吧,注释很详细:

package com.imooc.classdemo;

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



public class MethodDemo1 {
    public static void main(String[] args){

        ArrayList list = new ArrayList();

        ArrayList<String> list1 = new ArrayList<String>();
        list1.add("hello");
        //list1.add(20);这样是错误的
        Class c1=list.getClass();
        Class c2=list1.getClass();
        System.out.println(c1==c2);
        //反射的操作都是编译之后的操作

        /*
         * /c1==c2结果返回true说明编译之后的集合的泛型是去泛型化的
         * java中集合的泛型,是防止错误输入的,只在编译阶段有效,绕过编译就无效了
         * 验证:我们可以通过方法的反射来操作,绕过编译
         */

        try {
//          Method m1 = c1.getMethod("add", Object.class);
            Method m2 = c2.getMethod("add", Object.class);
            m2.invoke(list1, 20);//绕过编译操作就绕过了泛型
            System.out.println(list1.size());
            System.out.println(list1);
            /*
             * for(String string:list1){
             *  System.out.println(string);
            }
              现在不能这样遍历了,会抛异常
             */

        } catch (NoSuchMethodException | SecurityException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IllegalAccessException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IllegalArgumentException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (InvocationTargetException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

    }

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值