Java内省——Introspector

本文探讨了Java的Introspector在JavaBean规范中的作用,以及不正确使用可能导致的内存泄露问题。当框架如Spring Boot使用Introspector且未清理缓存时,web应用停止可能导致bean及其classloader无法被垃圾回收。Spring为此提供了IntrospectorCleanupListener监听器以解决内存泄露,但在特定情况下可能无效。博主分享了个人见解,并邀请读者交流讨论。
摘要由CSDN通过智能技术生成

在JavaBean规范中有如下描述:

大意是java默认情况下jdk使用低级的反射机制来分析Bean,为了方便其他人分析bean,java提供了一个内省类Introspector,使用Introspector的getBeanInfo方法可以获取一个封装了bean信息(包括属性和方法)的BeanInfo对象。

Introspector使用不当导致内存泄露的风险

框架几乎都使用了Introspector类来实现灵活性,但是Introspector在获取beanInfo对象时,为了提高性能使用了缓存保存beanInfo:

public static BeanInfo getBeanInfo(Class<?> beanClass)
        throws IntrospectionException
    {
        if (!ReflectUtil.isPackageAccessible(beanClass)) {
            return (new Introspector(beanClass, null, USE_ALL_BEANINFO)).getBeanInfo();
        }
        ThreadGroupContext context = ThreadGroupContext.getContext();
        BeanInfo beanInfo;
        synchronized (declaredMethodCache) {
            beanInfo = context.getBeanInfo(beanClass);
        }
        if (beanInfo == null) {
            beanInfo = new Introspector(beanClass, null, USE_ALL_BEANINFO).getBeanInfo();
            synchronized (declaredMethodCache) {
                context.putBeanInfo(beanClass, beanInfo);
            }
        }
        return beanInfo;
    }

缓存使用ThreadGroupContext——线程组级别共享,类似与ThreadLocal。内部使用WeakHashMap——key为弱引用来保存beanInfo,其中使用class作为key,beanInfo作为value。同时使用WeakIdentityMap保存ThreadGroupContext对象(应该是ThreadGroupContext对象的hash值&

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值