spring源码-BeanPostProcessor

1 大概介绍

1 BeanPostProcessor是bean的实例化之前和之后对bean做一些更改

2 BeanFactoryPostProcessor是在beandefinition的时候对它的一些修改,就是属于bean的初始化阶段

3 bean的生命周期是首先.java文件变成一个class文件 经过类加载器加到jvm中成为一个class对象,然后变成一个bd这就是初始化阶段 后面再进行实例化变成一个bean,中间还会有生命周期的回调 这伴随着实例化的过程就是通过一个个BeanPostProcessor来完成的,下面详细介绍

2 设计到BeanPostProcessor的地方列举

1 第一次是过滤掉不需要代理(例如aspect类型的类)或者已经被代理的类,有些类会提前aop,只是我一直还没找到应用场景,有知道的可以告诉我

try {
            beanInstance = this.resolveBeforeInstantiation(beanName, mbdToUse);
            if (beanInstance != null) {
                return beanInstance;
            }
        }

2 第二次是在创建的bean的时候需要推断用哪个构造器

 @Nullable
    protected Constructor<?>[] determineConstructorsFromBeanPostProcessors(@Nullable Class<?> beanClass, String beanName) throws BeansException {
        if (beanClass != null && this.hasInstantiationAwareBeanPostProcessors()) {
            Iterator var3 = this.getBeanPostProcessors().iterator();

            while(var3.hasNext()) {
                BeanPostProcessor bp = (BeanPostProcessor)var3.next();
                if (bp instanceof SmartInstantiationAwareBeanPostProcessor) {
                    SmartInstantiationAwareBeanPostProcessor ibp = (SmartInstantiationAwareBeanPostProcessor)bp;
                    Constructor<?>[] ctors = ibp.determineCandidateConstructors(beanClass, beanName);
                    if (ctors != null) {
                        return ctors;
                    }
                }
            }
        }

        return null;
    }

3 第三次是合并bd,因为bd之间有继承关系,要变成rootBeandifinition

protected void applyMergedBeanDefinitionPostProcessors(RootBeanDefinition mbd, Class<?> beanType, String beanName) {
        Iterator var4 = this.getBeanPostProcessors().iterator();

        while(var4.hasNext()) {
            BeanPostProcessor bp = (BeanPostProcessor)var4.next();
            if (bp instanceof MergedBeanDefinitionPostProcessor) {
                MergedBeanDefinitionPostProcessor bdp = (MergedBeanDefinitionPostProcessor)bp;
                bdp.postProcessMergedBeanDefinition(mbd, beanType, beanName);
            }
        }

    }

4 第四次是ioc的时候收集需要注入的元数据

PropertyValues pvsToUse = ibp.postProcessProperties((PropertyValues)pvs, bw.getWrappedInstance(), beanName);

5 第五次是在initializeBean方法里会调用所有beanpostprocessor前置处理方法

 if (mbd == null || !mbd.isSynthetic()) {
            wrappedBean = this.applyBeanPostProcessorsBeforeInitialization(bean, beanName);
        }

6 第六次是在initializeBean方法里会调用所有beanpostprocessor后置处理方法,比较经典的就是这里会生成aop(有的话)

if (mbd == null || !mbd.isSynthetic()) {
            wrappedBean = this.applyBeanPostProcessorsAfterInitialization(wrappedBean, beanName);
        }

具体应用场景

1 aop具体生成逻辑,@EnableAspectJAutoProxy注解里的AspectJAutoProxyRegistrar会生成这样一个bd

  if (registry.containsBeanDefinition("org.springframework.aop.config.internalAutoProxyCreator")) {
            BeanDefinition definition = registry.getBeanDefinition("org.springframework.aop.config.internalAutoProxyCreator");
            definition.getPropertyValues().add("proxyTargetClass", Boolean.TRUE);
        }

最终会实例化成一个AbstractAutoProxyCreator,这就是一个beanPostprocessor,在后置处理会生成aop对象

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值