精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Spring 動態代理時是如何解決循環依賴的?為什么要使用三級緩存?

存儲 存儲軟件
在研究 『 Spring 是如何解決循環依賴的 』 的時候,了解到 Spring 是借助三級緩存來解決循環依賴的。

 [[379347]]

前言

在研究 『 Spring 是如何解決循環依賴的 』 的時候,了解到 Spring 是借助三級緩存來解決循環依賴的。

同樣在上一節留下了疑問:

  1. 循環依賴為什么要使用三級緩存?而不是使用二級緩存?
  2. AOP 動態代理對循環依賴的有沒有什么影響?

本篇文章也是圍繞上面的內容進行展開。

筆記也在不斷整理,之前可能會有點雜亂。

循序漸進,看一看什么是循環依賴?

先來回顧一下三級緩存的概念。

  • singletonObjects: 一級緩存,存儲單例對象,Bean 已經實例化,初始化完成。
  • earlySingletonObjects: 二級緩存,存儲 singletonObject,這個 Bean 實例化了,還沒有初始化。
  • singletonFactories: 三級緩存,存儲 singletonFactory。

Bean 的創建過程

  1. @Service 
  2. public class CircularServiceA { 
  3.     private String fieldA = "字段 A"

單例 Bean 的創建過程

 

通過上面的流程,可以看出 Spring 在創建 Bean 的過程中重點是在 AbstractAutowireCapableBeanFactory 中的以下三個步驟:

  1. 實例化 createBeanInstance: 其中實例化 Bean 并對 Bean 進行賦值,像例子中的 fieldA 字段在這里就會賦值。
  2. 屬性注入 populateBean: 可以理解為對 Bean 里面的屬性進行賦值。(會依賴其他 Bean)
  3. 初始化 initializeBean: 執行初始化和 Bean 的后置處理器。

實例化賦值源碼可以閱讀:

BeanUtils.instantiateClass(constructorToUse)

如果要依賴其他 Bean 呢?

那如果 CircularServiceA 依賴了其他 Bean 呢?

A 依賴了 B

 

當 A 依賴了 B 的時候,在 createBeanInstance 這一步,并不會對 B 進行屬性賦值。

而是在 populatedBean 這里查找依賴項,并創建 B。

循環依賴下的創建過程

循環依賴的場景,在上一篇文章已經有所講解,這里僅僅畫圖說明一下。

  1. @Service 
  2. public class CircularServiceA { 
  3.  
  4.     private String fieldA = "字段 A"
  5.  
  6.     @Autowired 
  7.     private CircularServiceB circularServiceB; 
  8.  
  9. @Service 
  10. public class CircularServiceB { 
  11.     @Autowired 
  12.     private CircularServiceA circularServiceA; 

 

 


A B 循環依賴

 

 

在 A 和 B 循環依賴的場景中:

B populatedBean 查找依賴項 A 的時候,從一級緩存中雖然未獲取到 A,但是發現 A 在創建中。

此時,從三級緩存中獲取 A 的 singletonFactory 調用工廠方法,創建 getEarlyBeanReference A 的早期引用并返回。

B 引用到 A ,B 就可以初始化完畢,然后 A 同樣也可以初始化完畢了。

二級緩存能否解決循環依賴

通過上面的圖,仔細分析一下,其實把二級緩存拿掉,在 B 嘗試獲取 A 的時候直接返回 A 的實例,是不是也是可以的?

答案是:可以的!

但是為什么還是用三級緩存呢?

網上的很多資料說是和動態代理有關系,那就從動態代理的方面繼續往下分析分析。

動態代理的場景

在 JavaConfig(配置類) 上添加 @EnableAspectJAutoProxy 注解,開啟 AOP ,通過 Debug 循序漸進看一看動態代理對循環依賴的影響。

動態代理下,Bean 的創建過程

  1. @Service 
  2. public class CircularServiceA { 
  3.     private String fieldA = "字段 A"
  4.  
  5.     public void methodA() { 
  6.  
  7.         System.out.println("方法 A 執行"); 
  8.  
  9.     } 
  10. @Aspect 
  11. @Component 
  12. public class AspectA { 
  13.  
  14.     @Before("execution(public void com.liuzhihang.circular.CircularServiceA.methodA())"
  15.     public void beforeA() { 
  16.         System.out.println("beforeA 執行"); 
  17.     } 

只有 A 的情況下,給 A 添加切面,開始 Debug。

前面的流程都相同,在 initializeBean 開始出現差異。

這一步需要初始化 Bean 并執行 Bean 的后置處理器。

 


執行后置處理器

 

 

其中有一個處理器為:AnnotationAwareAspectJAutoProxyCreator 其實就是加的注解切面,會跳轉到 AbstractAutoProxyCreator 類的 postProcessAfterInitialization 方法

 

 


postProcessAfterInitialization

 

 

如圖所示:wrapIfNecessary 方法會判斷是否滿足代理條件,是的話返回一個代理對象,否則返回當前 Bean。

后續調用 getProxy 、createAopProxy 等等,最終執行到下面一部分。

 

最終會執行到這里,AOP 代理相關的就不細看了。

一路放行,直到 initializeBean 執行結束。

A 被替換為了代理對象

 

此時發現:A 被替換為了代理對象。

所以 doCreateBean 返回,以及后面放到一級緩存中的都是代理對象。

紅框部分為差異

 

有循環依賴的動態代理

這一次把循環依賴打開:

  1. @Service 
  2. public class CircularServiceA { 
  3.  
  4.     private String fieldA = "字段 A"
  5.  
  6.     @Autowired 
  7.     private CircularServiceB circularServiceB; 
  8.  
  9.     public void methodA() { 
  10.  
  11.         System.out.println("方法 A 執行"); 
  12.  
  13.     } 
  14. @Aspect 
  15. @Component 
  16. public class AspectA { 
  17.  
  18.     @Before("execution(public void com.liuzhihang.circular.CircularServiceA.methodA())"
  19.     public void beforeA() { 
  20.  
  21.         System.out.println("beforeA 執行"); 
  22.  
  23.     } 
  24.  
  25. @Service 
  26. public class CircularServiceB { 
  27.  
  28.     @Autowired 
  29.     private CircularServiceA circularServiceA; 
  30.  
  31.     public void methodB() { 
  32.  
  33.     } 
  34. @Aspect 
  35. @Component 
  36. public class AspectB { 
  37.      
  38.     @Before("execution(public void com.liuzhihang.circular.CircularServiceB.methodB())"
  39.     public void beforeB() { 
  40.  
  41.         System.out.println("beforeB 執行"); 
  42.  
  43.     } 
  44.  

開始 Debug,前面的一些列流程,都和正常的沒有什么區別。而唯一的區別在于,創建 B 的時候,需要從三級緩存獲取 A。

此時在 getSingleton 方法中會調用:singletonObject = singletonFactory.getObject();

B 屬性賦值時,從三級緩存獲取 A

 

有時會比較疑惑 singletonFactory.getObject() 調用的是哪里?

 


三級緩存獲取對象

 

 

所以這一塊調用的是 getEarlyBeanReference,開始遍歷執行 BeanPostProcessor。

getEarlyBeanReference

 

 


getEarlyBeanReference

 

 

看到 wrapIfNecessary 就明白了吧!這塊會獲取一個代理對象。

也就是說此時返回,并放到二級緩存的是一個 A 的代理對象。

這樣 B 就創建完畢了!

到 A 開始初始化并執行后置處理器了!因為 A 也有代理,所以 A 也會執行到 postProcessAfterInitialization 這一部分!

 


判斷二級緩存

 

 

但是在執行 wrapIfNecessary 之前,會先判斷二級緩存是否有 A 了。

  1. this.earlyProxyReferences.remove(cacheKey) != bean 

但是這塊獲取到的是 A 的代理對象。肯定是 false 。所以不會再生成一次 A 的代理對象。

代理 - 循環依賴

 

總結

可以看到,循環依賴下,有沒有代理情況下的區別就在:

  1. singletonObject = singletonFactory.getObject(); 

在循環依賴發生的情況下 B 中的 A 賦值時:

  1. 無代理:getObject 直接返回原來的 Bean
  2. 有代理:getObject 返回的是代理對象

然后都放到二級緩存。

為什么要三級緩存?

假設去掉三級緩存

去掉三級緩存之后,Bean 直接創建 earlySingletonObjects, 看著好像也可以。

如果有代理的時候,在 earlySingletonObjects 直接放代理對象就行了。

但是會導致一個問題:在實例化階段就得執行后置處理器,判斷有 AnnotationAwareAspectJAutoProxyCreator 并創建代理對象。

這么一想,是不是會對 Bean 的生命周期有影響。

同樣,先創建 singletonFactory 的好處就是:在真正需要實例化的時候,再使用 singletonFactory.getObject() 獲取 Bean 或者 Bean 的代理。相當于是延遲實例化。

假設去掉二級緩存

如果去掉了二級緩存,則需要直接在 singletonFactory.getObject() 階段初始化完畢,并放到一級緩存中。

 


B 和 C 都依賴 A

 

 

那有這么一種場景,B 和 C 都依賴了 A。

要知道在有代理的情況下 singletonFactory.getObject() 獲取的是代理對象。

 

 


多次獲取代理對象不同

 

 

而多次調用 singletonFactory.getObject() 返回的代理對象是不同的,就會導致 B 和 C 依賴了不同的 A。

那如果獲取 B 到之后直接放到一級緩存,然后 C 再獲取呢?

 

一級緩存放的是已經初始化完畢的 Bean,要知道 A 依賴了 B 和 C ,A 這時候還沒有初始化完畢。

小結

循環依賴的場景有很多,本文只是通過 Debug ,來了解到循環依賴和 AOP 之間的關系,以及了解到為什么要用三級緩存。

當然,Spring 設計之初是什么樣子的?如何一步一步發展成現在這種的?

肯定是不能慢慢去研究了,所以只能以現在的版本,去揣測作者的意圖。

不足之處,多多指正。

本文轉載自微信公眾號「程序員小航」,可以通過以下二維碼關注。轉載本文請聯系程序員小航公眾號。

 

責任編輯:武曉燕 來源: 程序員小航
相關推薦

2023-12-12 17:44:13

三級緩存Bean

2023-02-26 11:15:42

緩存循環依賴

2020-12-29 08:34:08

spring循環依賴開發

2022-05-08 19:23:28

Spring循環依賴

2022-03-01 18:03:06

Spring緩存循環依賴

2022-12-02 12:01:30

Spring緩存生命周期

2019-11-26 14:30:20

Spring循環依賴Java

2024-03-04 08:47:17

Spring框架AOP

2023-11-28 08:00:00

SpringJava

2025-06-26 01:55:00

2023-10-07 08:40:57

緩存屬性Spring

2025-07-02 03:10:00

2022-08-17 07:52:31

Spring循環依賴單例池

2024-12-20 16:46:22

Spring三級緩存

2024-04-15 08:17:21

Spring依賴注入循環依賴

2023-08-09 10:43:21

源碼循環依賴getBean

2020-06-22 08:07:48

Spring依賴場景

2015-09-22 11:09:47

Java 8動態代理

2023-09-21 09:00:00

Merge Que開發工具Mergify

2020-11-27 06:28:55

Spring循環依賴
點贊
收藏

51CTO技術棧公眾號

欧美午夜在线播放| 伊人免费在线观看高清版| 精品午夜av| 亚洲蜜桃精久久久久久久| 7777奇米亚洲综合久久| 久久精品视频8| 亚洲第一二三区| 欧美日韩国产综合视频在线观看中文| 国产在线一区二区三区播放| 少妇一级淫片免费放中国| 亚洲裸色大胆大尺寸艺术写真| 日本韩国欧美一区| 日本黄色a视频| 成人午夜免费福利| 国产偷自视频区视频一区二区| 亚洲欧美激情在线视频| 午夜精品中文字幕| 国产丝袜在线观看视频| 久久精品视频在线免费观看| 91精品视频在线播放| 国产一级在线免费观看| 欧美日韩国产免费观看视频| 日韩一区二区三区免费看 | 国内精品久久久久久久久久 | 一区二区国产日产| 国产成人三级在线观看视频| 日韩网站在线| 色综合影院在线| 绯色av蜜臀vs少妇| 欧洲精品一区二区三区| 18成人在线观看| 久久久久免费网| 亚洲av无码一区二区乱子伦| 日韩精品一级中文字幕精品视频免费观看 | 国产午夜久久久| 日本一区二区免费高清| 日韩欧美高清在线| 国产高潮免费视频| 98色花堂精品视频在线观看| 国产精品久久久久aaaa| 99久热re在线精品996热视频| 欧美超碰在线观看| 激情久久婷婷| 久久夜色精品亚洲噜噜国产mv| 中文字幕 亚洲一区| 国产精品视频首页| 欧美在线视频全部完| 青青青免费在线| 日本动漫理论片在线观看网站| 国产精品三级av在线播放| 韩国成人av| 国产sm主人调教女m视频| 日韩福利电影在线| 欧美性视频精品| 国产一级黄色av| 91精品一区二区三区综合在线爱 | 亚洲国产aⅴ成人精品无吗| 超碰成人在线免费观看| av在线电影网| 久久精子c满五个校花| 99久久久久国产精品免费| 91中文字幕在线播放| 日韩av高清在线观看| 欧美一级bbbbb性bbbb喷潮片| 538精品在线观看| 亚洲欧美综合久久久| 日韩三级影视基地| 日韩av毛片在线观看| 亚洲欧洲美洲国产香蕉| 日韩av中文字幕在线免费观看| 国产ts在线观看| 中文字幕区一区二区三| 日韩一区二区三区观看| 97超碰免费在线观看| 亚洲综合资源| 欧美一区二区三区四区高清| 992tv人人草| 狂野欧美xxxx韩国少妇| 51精品久久久久久久蜜臀| 爱爱爱爱免费视频| 精品国产亚洲一区二区三区大结局| 欧美精品视频www在线观看 | 亚洲成色www久久网站| 国产精品一二三区视频| 欧美激情在线一区二区三区| 欧美激情第六页| 国产精品影院在线| 国产精品免费免费| www.午夜色| 永久免费网站在线| 天天综合网天天综合色| 97在线播放视频| 91成人在线| 91精品国产综合久久久久久漫画 | 国产高清一区二区三区| 亚洲三级黄色片| 欧美激情综合网| 一本一道久久a久久精品综合 | 波多野结衣黄色网址| 免费高清视频精品| 国产精品激情自拍| 国产精品女同一区二区| 国产iv一区二区三区| 国产精品区二区三区日本| 欧美女优在线| 国产精品嫩草99a| 欧美美女黄色网| 高清电影在线观看免费| 91国产免费观看| 欧美日韩久久婷婷| 日韩第一区第二区| 亚洲精品色婷婷福利天堂| 亚洲不卡的av| 夜间精品视频| 欧美亚洲在线播放| 在线视频欧美亚洲| 成人av综合一区| 最近中文字幕免费mv| 亚洲www免费| 精品国产三级电影在线观看| 狂野欧美性猛交| 天堂影院一区二区| 久久精品久久精品国产大片| 伊人手机在线| 欧美一区在线视频| 国产精品一区二区亚洲| 免费在线观看成人av| 国产伦精品一区二区三区照片| 黄色视屏免费在线观看| 欧美又粗又大又爽| 尤物视频最新网址| 国产精品社区| 久久精品美女| 亚洲校园激情春色| 日韩国产欧美精品在线| 97超碰人人干| 成人av在线一区二区| 欧美大黑帍在线播放| 57pao成人永久免费| 在线播放精品一区二区三区| 不卡av电影在线| 久久精品一区四区| 久章草在线视频| 国产免费av一区二区三区| 欧美一级电影在线| 日本午夜在线视频| 日韩欧美国产成人| 一区二区黄色片| 久久最新视频| 亚州欧美一区三区三区在线 | 日本一区二区在线免费播放| 中文字幕日韩综合| 中文字幕av一区二区三区人| 午夜精品一区二区三区在线视| 国产视频手机在线观看| 亚洲女厕所小便bbb| 无人码人妻一区二区三区免费| 成人jjav| 色诱亚洲精品久久久久久| 极品粉嫩小仙女高潮喷水久久| 1024成人| 久久久水蜜桃| 午夜av成人| 日韩最新在线视频| 国产麻豆91视频| 亚洲最新在线观看| 中文字幕在线播放视频| 久久婷婷久久| 婷婷五月色综合| www.久久热| 欧美黑人狂野猛交老妇| 少妇一级淫片免费看| 黑人与娇小精品av专区| 久久久久久亚洲中文字幕无码| 日本伊人精品一区二区三区观看方式 | 亚洲一卡二卡三卡四卡无卡网站在线看| 97欧美成人| 欧美精品在线免费| 日本中文字幕一区二区有码在线| 91黄色免费版| 免费网站看av| 久久理论电影网| 搡的我好爽在线观看免费视频| 亚洲激情自拍| 亚洲精品在线视频观看| 亚洲一区二区三区四区电影| 青青草原成人在线视频| 免费网站成人| 亚洲国产精品视频在线观看| 亚洲午夜在线播放| 亚洲国产一区二区在线播放| 波多野结衣片子| 国产美女精品人人做人人爽| 成年女人18级毛片毛片免费| 亚洲三级精品| 亚洲综合色av| 日本黄色一区| 91国内免费在线视频| 国产一二三区在线观看| 精品亚洲一区二区三区在线观看 | 欧美不卡高清一区二区三区| 欧美裸体xxxx极品少妇| 美女欧美视频在线观看免费 | 国产传媒一区二区| 成人精品国产亚洲| 热草久综合在线| 99视频免费在线观看| 国产亚洲精品一区二区| 免费看黄色一级视频| 欧美高清精品3d| 男人天堂av在线播放| 亚洲一线二线三线久久久| 日本高清黄色片| 日韩av视屏| 欧美性色欧美a在线播放| 国产在线观看99| 欧美a级大片在线| 亚洲地区一二三色| 在线小视频你懂的| 97久久精品人人做人人爽| 在线观看免费av网址| 久久久久久黄| 黄色免费福利视频| 黄色一区二区三区四区| 青青草原国产免费| 欧美日韩激情| 久久精品人人做人人爽电影| 国产精品极品国产中出| 91久久夜色精品国产网站| 99只有精品| 国产精品6699| 亚洲精品福利电影| 91精品国产色综合久久不卡98口| 婷婷色在线播放| www.99久久热国产日韩欧美.com| 国产精品一区在线看| 亚洲欧美日韩精品久久亚洲区| 高清一区二区三区四区| 日韩欧美国产精品一区| 精品国产无码一区二区| 日韩视频一区二区三区在线播放| 国产精品久久久久久久久久久久久久久久 | 日韩电影中文字幕一区| 黄色福利在线观看| 欧美va亚洲va| 草逼视频免费看| 日韩欧美一区电影| xxxx18国产| 精品久久人人做人人爰| 亚洲欧美激情另类| 亚洲黄色www| 亚洲三区在线播放| 亚洲色图18p| 成年网站在线| 久久精品影视伊人网| 成人video亚洲精品| 欧美美最猛性xxxxxx| 免费污视频在线观看| 午夜精品国产精品大乳美女| 爱啪视频在线观看视频免费| 992tv在线成人免费观看| 五月天av在线| 国产精品极品美女粉嫩高清在线| 久久久久久久性潮| 91国产丝袜在线放| 9l视频自拍蝌蚪9l视频成人| 国产精品免费一区二区三区在线观看 | 狠狠色狠狠色综合系列| 婷婷中文字幕在线观看| 国产高清精品久久久久| 国产大学生视频| 久久影视一区二区| www.xx日本| 亚洲一本大道在线| 亚洲欧美另类在线视频| 欧美日韩小视频| jizz中国女人| 日韩av在线看| 永久免费av在线| 久久免费国产精品1| 高清电影一区| 亚洲在线免费观看| 美女精品一区最新中文字幕一区二区三区 | 五月天亚洲精品| 亚洲性猛交富婆| 日韩欧美你懂的| 美女做暖暖视频免费在线观看全部网址91 | jizz中文字幕| 亚洲视频你懂的| 韩国av中文字幕| 欧美妇女性影城| 天天爽夜夜爽夜夜爽| 色狠狠久久aa北条麻妃 | 国产精品嫩草视频| 99这里只有精品视频| 亚洲第一导航| 亚洲乱码久久| 午夜免费一级片| 26uuu久久天堂性欧美| 国产美女久久久久久| 好吊成人免视频| 精品国产无码一区二区| 一本色道久久综合狠狠躁篇的优点| 麻豆蜜桃在线| 国产精品永久免费在线| 日韩av黄色在线| 免费看污污视频| 三级欧美在线一区| 性猛交╳xxx乱大交| 国产精品久久久久久久久免费樱桃| 久久婷婷国产麻豆91| 欧美视频一区二区三区在线观看| 熟妇人妻av无码一区二区三区| 久久亚洲精品成人| 欧美日韩女优| 久久影院理伦片| 影音国产精品| 少妇愉情理伦片bd| 一区在线中文字幕| 成人毛片一区二区三区| 亚洲国产精品久久久久秋霞蜜臀 | 亚洲一区二区在线免费| 亚洲欧美在线视频观看| 高潮毛片又色又爽免费| 亚洲成色www8888| 18av在线播放| 成人做爽爽免费视频| 日韩在线高清| 99草草国产熟女视频在线| 99久久精品国产一区二区三区 | eeuss一区二区三区| 91久久电影| 少妇一级淫免费播放| 国产日韩av一区| 特级西西444www高清大视频| 精品一区二区亚洲| 台湾佬中文娱乐网欧美电影| 国产女人水真多18毛片18精品 | 欧美日韩国产成人精品| 欧美日韩理论片| 日韩毛片高清在线播放| 亚洲中文字幕在线观看| 综合av色偷偷网| 日韩城人网站| 精品国产无码在线| 国产一区二区三区在线看麻豆| 精品一区二区在线观看视频| 欧美日韩免费在线视频| 调教视频免费在线观看| 国产一区二区在线免费| 99久久精品费精品国产| 欧美国产日韩另类| 亚洲欧美日韩久久精品| 99国产精品一区二区三区| 日韩资源在线观看| 日韩成人精品| 日韩一级性生活片| 91亚洲国产成人精品一区二三| 欧美一级视频免费观看| 亚洲精品中文字幕女同| 日本精品网站| 久久久久久久久久久久久国产| 国产黄色精品视频| 中文字幕一区二区三区手机版| 亚洲国产精品一区二区久| 欧美人与性动交xxⅹxx| 亚洲精品免费在线看| 国产一区二区调教| 青青草av在线播放| 国产亚洲欧洲在线| 精品一区二区三区中文字幕| 欧美国产日韩激情| 久久久国际精品| 这里只有精品6| 欧美激情小视频| 久久不见久久见免费视频7| 免费精品99久久国产综合精品应用| 亚洲另类在线制服丝袜| 亚欧洲精品视频| 国产精品色视频| 欧美日韩三级电影在线| av黄色免费网站| 91精品国产综合久久久久久| 超碰91在线观看| 天天爽天天狠久久久| 国产成人精品午夜视频免费| 亚洲天堂男人av| 久国内精品在线| 国产区精品区| 国产黄在线播放| 成人精品网站在线观看| 雨宫琴音一区二区在线| 免费黄色片网站| 日韩欧美国产综合在线一区二区三区| 天堂电影一区| 在线视频不卡一区二区三区| 99这里只有久久精品视频| 一区二区视频网站| 2020欧美日韩在线视频| 91中文字幕精品永久在线|