一、代理对象的创建过程:

AbstractAutowireCapableBeanFactory#initializeBean

protectedObjectinitializeBean(StringbeanName,Objectbean,@NullableRootBeanDefinitionmbd){
if(System.getSecurityManager()!=null){
AccessController.doPrivileged((PrivilegedAction<Object>)()->{
invokeAwareMethods(beanName,bean); return null; },getAccessControlContext()); }
else{ invokeAwareMethods(beanName,bean); } ObjectwrappedBean=bean;
if(mbd==null||!mbd.isSynthetic()){ //
执⾏所有的BeanPostProcessor#postProcessBeforeInitialization 初始化之前 的处理器⽅法
wrappedBean=applyBeanPostProcessorsBeforeInitialization(wrappedBean,beanName);
} try{ // 这⾥就开始执⾏afterPropertiesSet(实现了InitializingBean接⼝)⽅法和 initMethod
invokeInitMethods(beanName,wrappedBean,mbd); } catch(Throwableex){
thrownewBeanCreationException((mbd!=null?
mbd.getResourceDescription():null),beanName,"Invocationofinitmethodfailed",ex);
} if(mbd==null||!mbd.isSynthetic()){ // 整个Bean初始化完成,执⾏后置处理器⽅法
wrappedBean=applyBeanPostProcessorsAfterInitialization(wrappedBean,beanName); }
return wrappedBean; }
可以看到有初始化前执行的方法、初始化时执行的方法、初始化之后执行的方法,我们从初始化之后执行的方法入手。

 

二、applyBeanPostProcessorsAfterInitialization

applyBeanPostProcessorsAfterInitialization()方法的流程如下:

AbstractAutowireCapableBeanFactory#applyBeanPostProcessorsAfterInitialization
->AbstractAutoProxyCreator#postProcessAfterInitialization
applyBeanPostProcessorsAfterInitialization中会检查下该类是否已经暴露过了
(可能已经创建了,⽐如A依赖B时,创建A时候,就会先去创建B。当真正需要创建B时,就没必要再代理⼀次已经代理过的对象),避免重复创建。
->AbstractAutoProxyCreator#wrapIfNecessary
得到所有候选Advisor,对Advisors和bean的⽅法双层遍历匹配,最终得到⼀个List<Advisor>,即specificInterceptors
->AbstractAutoProxyCreator#createProxy
(1)创建代理的⼯作交给ProxyFactory

(2)把指定和通⽤拦截对象合并, 并都适配成Advisor

(3)上⾯准备做完就开始创建代理
->proxyFactory.getProxy()
⽤ProxyFactory创建AopProxy, 然后⽤AopProxy创建Proxy,
所以这⾥重要的是看获取的AopProxy对象是什么,然后进去看怎么创建动态代理, 提供了两种:jdk proxy, cglib

 

总结:简要流程

 

技术
下载桌面版
GitHub
Microsoft Store
SourceForge
Gitee
百度网盘(提取码:draw)
云服务器优惠
华为云优惠券
京东云优惠券
腾讯云优惠券
阿里云优惠券
Vultr优惠券
站点信息
问题反馈
邮箱:[email protected]
吐槽一下
QQ群:766591547
关注微信