Spring相關(guān)知識點有什么,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
創(chuàng)新互聯(lián)提供網(wǎng)站設(shè)計、成都網(wǎng)站設(shè)計、網(wǎng)頁設(shè)計,成都品牌網(wǎng)站建設(shè),1元廣告等致力于企業(yè)網(wǎng)站建設(shè)與公司網(wǎng)站制作,十年的網(wǎng)站開發(fā)和建站經(jīng)驗,助力企業(yè)信息化建設(shè),成功案例突破上千家,是您實現(xiàn)網(wǎng)站建設(shè)的好選擇.
通過反射實現(xiàn)ioc(依賴注入)
一共有兩種方式 通過構(gòu)造器注入和set方法注入
1:通過set get 方法
2:通過注解方式
spring的循環(huán)依賴以及三級緩存
針對上面的源碼我做一個簡單的總結(jié):首先spring從單例池當中獲取x,前面說過獲取不到,然后判斷是否在正在創(chuàng)建bean的集合當中,前面分析過這個集合現(xiàn)在存在x,和y;所以if成立進入分支;進入分支spring直接從三級緩存中獲取x,根據(jù)前面的分析三級緩存當中現(xiàn)在什么都沒有,故而返回nll;進入下一個if分支,從二級緩存中獲取一個ObjectFactory工廠對象;根據(jù)前面分析,二級緩存中存在x,故而可以獲取到;跟著調(diào)用singletonFactory.getObject();拿到一個半成品的x bean對象;然后把這個x對象放到三級緩存,同時把二級緩存中x清除(此時二級緩存中只存在一個y了,而三級緩存中多了一個x);
問題1、為什么首先是從三級緩存中取呢?主要是為了性能,因為三級緩存中存的是一個x對象,如果能取到則不去二級找了;哪有人會問二級有什么用呢?為什么一開始要存工廠呢?為什么一開始不直接存三級緩存?這里稍微有點復(fù)雜,如果直接存到三級緩存,只能存一個對象,假設(shè)以前存這個對象的時候這對象的狀態(tài)為xa,但是我們這里y要注入的x為xc狀態(tài),那么則無法滿足;但是如果存一個工廠,工廠根據(jù)情況產(chǎn)生任意xa或者xb或者xc等等情況;比如說aop的情況下x注入y,y也注入x;而y中注入的x需要加代理(aop),但是加代理的邏輯在注入屬性之后,也就是x的生命周期周到注入屬性的時候x還不是一個代理對象,那么這個時候把x存起來,然后注入y,獲取、創(chuàng)建y,y注入x,獲取x;拿出來的x是一個沒有代理的對象;但是如果存的是個工廠就不一樣;首先把一個能產(chǎn)生x的工廠存起來,然后注入y,注入y的時候獲取、創(chuàng)建y,y注入x,獲取x,先從三級緩存獲取,為null,然后從二級緩存拿到一個工廠,調(diào)用工廠的getObject();spring在getObject方法中判斷這個時候x被aop配置了故而需要返回一個代理的x出來注入給y。當然有的讀者會問你不是前面說過getObject會返回一個當前狀態(tài)的xbean嘛?我說這個的前提是不去計較getObject的具體源碼,因為這塊東西比較復(fù)雜,需要去了解spring的后置處理器功能,這里先不討論,總之getObject會根據(jù)情況返回一個x,但是這個x是什么狀態(tài),spring會自己根據(jù)情況返回;
問題2、為什么要從二級緩存remove?因為如果存在比較復(fù)雜的循環(huán)依賴可以提高性能;比如x,y,z相互循環(huán)依賴,那么第一次y注入x的時候從二級緩存通過工廠返回了一個x,放到了三級緩存,而第二次z注入x的時候便不需要再通過工廠去獲得x對象了。因為if分支里面首先是訪問三級緩存;至于remove則是為了gc吧;
原文鏈接:https://blog.csdn.net/java_lyvee/article/details/101793774
AOP底層實現(xiàn)原理
spring獲取bean的幾種方式
通過在配置文件里面添加@Bean 然后獲取
也可以通過添加@component 來獲取
通過下面的方式完成對象的創(chuàng)建
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。