Spring循环依赖

AOP知识前倾概要

类的前两个字母大写 生成的beanName前两个也是大写的

那会打印zhouyuBefore吗?

答:不会

AOP是在初始化后执行的

如果传入的是AService对象那返回的就是AService的代理对象

没有开启AOP BeanPostProcessor有6个

开启AOP后

多了一个AnnotationAwareAspectJAutoProxyCreator

每个BeanPostProcessor都会调用这个初始化后方法postProcessAfterInitialization()

就是多的这个AnnotationAwareAspectJAutoProxyCreator去进行AOP,生成代理对象

什么是循环依赖?

spring创建bean的时候是串行去创建的,而不是并发的

循环依赖出现的场景

解决方法:

三级缓存,也就是3个Map

增加中间人(缓存)打破循环

解决方案

1.实例化完给他放到一个Map中,key是beanName,value是bean的原始对象(此时属性都没有值 除非提前用构造方法赋值了)

2.然后去单例池找BService,发现没有再去map中找,发现还没有,就去创建BService

2.B实例化完也放入到这个map中,然后去单例池中找AService,发现没有,于是去map中拿,发现可以正常拿到了,于是继续执行接下来的步骤

整个过程都是串行的。

因为一直操作的都是同一个对象,看似a对象的属性没有赋值,但是最后其实是会经历完整的赋值操作的。

因为操作的对象没有变过。

**那为什么需要第三个map?**其实是给代理用的

对于AService而言,假如需要进行AOP

那初始化后得到的就是AService的代理对象,然后放入单例池中

那此时填充给BService的a属性的对象是原始对象而不是代理对象

B依赖的A和最终的A不是同一个对象

解决方案【提前AOP】:

直接实例化后就执行AOP,无需增加一个map

但是对于bean的生命周期而言AOP应该是在初始化后进行的,不符合bean生命周期设计

那如何判断AService是否出现循环依赖?在哪判断?

填充AService属性的时候,通过这个set就能判断出AService是不是正在创建中,说明AService发生了循环依赖

只有AOP才需要把代理对象赋值给AService属性,否则还是赋值的原始对象

如果我再加个CService

此时就要填充CService的属性

这时同样判断出AService出现循环依赖,难道又要再次生成AService的代理对象??

所以这时候才引入了二级缓存的这个map,第一次AOP完生成代理对象就存入这个earlySingletonObjects的map中。

earlySingletonObjects

不管有没有进行AOP最后放入到earlySingletonObjects的不是原始对象就是代理对象

singletonObjects:单例池 存的是完整走过bean的生命周期的bean对象

earlySingletonObjects:存的是暂时还没经过完整生命周期的bean对象【保证单例】

总结:

A对象有个B对象的成员变量,B对象有个A对象的成员变量,此时A对象要进行属性填充,但B对象还没有创建好,此时就需要去创建B对象,但是此时A对象也没创建好,于是陷入循环。。。

这时候,就有个办法,A对象生成后马上把自己放入到一个map中,这样B对象就能从这个map里取到A对象执行后续操作,且操作的是同一个对象。但是有个问题,就是如果是要执行AOP,那此时填充给B对象的A属性的对象是原始对象而不是代理对象,所以B依赖的A和最终的A不是同一个对象

此时就引出了2级缓存earlySingletonObjects这个map。

在判断完有没有出现循环依赖以后,

相关推荐
明月_清风6 小时前
加密解密系统完全指南:原理剖析与 Go 实践
后端
方也_arkling6 小时前
【Java-Day08】static / final / 枚举
java·开发语言
橙淮6 小时前
Spring Bean作用域与生命周期全解析
java·spring
Chengbei116 小时前
一站式源码安全检测工具、云安全 / APP / 小程序源码敏感信息递归多层目录扫描AK、JWT、手机号、身份证等敏感信息
java·开发语言·安全·web安全·网络安全·系统安全·安全架构
llz_1126 小时前
web-第一次课后作业
java·开发语言·idea
秋96 小时前
Java项目运行5天左右自动宕机:系统性定位与解决方案
java·开发语言·python
小江的记录本6 小时前
【JVM虚拟机】垃圾回收GC:垃圾收集器:CMS:核心原理、回收流程、优缺点、废弃原因(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·面试·maven
DIY源码阁7 小时前
JavaSwing学生成绩管理系统 - MySQL版
java·数据库·mysql·eclipse
冬奇Lab7 小时前
每日一个开源项目(第105篇):Twenty - 跳出 Salesforce 的圈套,定义现代开源 CRM
前端·后端·开源
basketball6168 小时前
C++ NULL 和 nullptr 区别 以及 nullptr 的核心实现
java·开发语言·c++