二、什么是循环依赖
循环依赖直白点就是发生在两个类,你引用我,我引用你
的状态,如图:
三、如果不依赖于Spring自己解决循环依赖如何解决
以上图为例,假设,我们能够创建完成AService
之后,放置到到一个缓存中,再去注入属性!每次注入属性的时候,所需要的属性值都从缓存中获取一遍,缓存中没有再去创建不就解决了?如图所示:
总结一下上面的流程:
AService
创建完成后将自己加入到二级缓存,然后开始注入属性- 发现
AService
依赖BService
于是先查询一级缓存是否有数据一级缓存没有就查询二级缓存,有就返回,没有就创建BService
- 缓存中没有,开始实例化
BService
,然后注入内部属性! - 注入内部属性时发现依赖
AService
,于是先查询一级缓存是否有数据一级缓存没有就查询二级缓存,有就返回,没有就创建,很显然,二级缓存是有数据的。于是从二级缓存取出AService
注入到BService
。 BService
创建完成后将自己从二级缓存挪到一级缓存,并返回。AService
获取到BService
后,注入到自己的属性中并把自己从二级缓存挪的一级缓存,返回AService
!- 至此,循环依赖创建完成!
那么有了上面的思路,我们如何用代码实现一遍我们的逻辑呢?
写在最后
作为一名即将求职的程序员,面对一个可能跟近些年非常不同的 2019 年,你的就业机会和风口会出现在哪里?在这种新环境下,工作应该选择大厂还是小公司?已有几年工作经验的老兵,又应该如何保持和提升自身竞争力,转被动为主动?
就目前大环境来看,跳槽成功的难度比往年高很多。一个明显的感受:今年的面试,无论一面还是二面,都很考验Java程序员的技术功底。
最近我整理了一份复习用的面试题及面试高频的考点题及技术点梳理成一份“Java经典面试问题(含答案解析).pdf和一份网上搜集的“Java程序员面试笔试真题库.pdf”(实际上比预期多花了不少精力),包含分布式架构、高可扩展、高性能、高并发、Jvm性能调优、Spring,MyBatis,Nginx源码分析,Redis,ActiveMQ、Mycat、Netty、Kafka、Mysql、Zookeeper、Tomcat、Docker、Dubbo、Nginx等多个知识点高级进阶干货!
由于篇幅有限,为了方便大家观看,这里以图片的形式给大家展示部分的目录和答案截图!有需要的朋友可以戳这里免费获取
Java经典面试问题(含答案解析)
阿里巴巴技术笔试心得
心得
[外链图片转存中…(img-bik4YHwF-1626847248605)]