Spring核心——Bean的定義與控制

来源:https://www.cnblogs.com/AIPAOJIAO/archive/2018/07/14/9311078.html
-Advertisement-
Play Games

在Sring核心與設計模式的文章中,分別介紹了Ioc容器和Bean的依賴關係。如果閱讀過前2文就會知道,Spring的整個運轉機制就是圍繞著IoC容器以及Bean展開的。IoC就是一個籃子,所有的Bean都向裡面扔。除了提供籃子功能創建並存放Bean之外,IoC還要負責管理Bean與Bean之間的關 ...


在Sring核心與設計模式的文章中,分別介紹了Ioc容器和Bean的依賴關係。如果閱讀過前2文就會知道,Spring的整個運轉機制就是圍繞著IoC容器以及Bean展開的。IoC就是一個籃子,所有的Bean都向裡面扔。除了提供籃子功能創建並存放Bean之外,IoC還要負責管理Bean與Bean之間的關係——依賴註入。之前也提到Bean是Spring核心容器的最小工作單元,Spring一些更高級的功能(例如切麵、代理)都是在Bean的基礎上實現。

除了管理Bean與Bean之間的關係,IoC還提供了對Bean自身進行控制的各項功能,本文將介紹Bean的生命周期功能以及狀態定義功能。

 


前置依賴

Bean與Bean之間存在依賴關係,可以是強依賴(通過XML和註解直接聲明依賴)、也可以是弱依賴(ApplicationContextAware等方式獲取)。當一個Bean需要另外一個Bean完成初始化後自身才能工作時,例如一個Bean依賴DataSoruce,但是DataSource的初始化需要較長時間。這個時候用depends-on聲明前置依賴即可:

 

延遲載入

通常情況下,所有的 singleton 類型的Bean都會在容器創建後進行初始化,簡單的說就是啟動Jvm就開始創建(實際上是創建ApplicationContext的某個實現類實例之後)。

IoC支持所有的 singleton Bean在使用時再載入,這樣做的好處是可以大大節省初始化的時間。但是如果你的應用對啟動時間的長短並不敏感,建議讓所有的 singleton 都啟動時載入。這樣可以在啟動時就發現一些問題,而不是在運行很久直到使用時才由用戶去觸發這個問題。或者可以根據場景來使用決定是否延遲,例如開發時使用延遲載入,而在集成測試或上生產時關閉。

可以設置全局延遲載入,也可以設置某個Bean延遲載入:

 

 

需要註意的是,在設置某個單獨的Bean延遲載入時,如果有某個沒有延遲載入的Bean要依賴他,那實際上也會在初始化的時候就載入。

 


還要強調一下,這裡的“載入”僅僅是為了表示一個類被Ioc創造並放置容器中,和classLoad方法將class文件中的位元組碼載入到方法區的載入是兩個概念。

延遲載入在設計模式上是單例模式一種延伸,通常也被稱為懶漢模式。單例通常有雙重鎖+volatile、靜態類和枚舉三種方式實現。在Effective Java一書中對三種模式都有深入的解析。而對於Spring容器而言,枚舉的方式肯定不好用了,靜態類由於屬於自身代碼級別應該也不會用,所以雙重鎖的實現方式較為可信。不過我沒去看過源碼,僅屬於猜測。

 


生命周期方法

一個Bean的創建、使用再到最後銷毀稱為"Bean的生命周期"。Spring框架為Bean的生命周期各個階段提供了多種回掉方法來處理各種狀態或者數據。

 


初始化方法

當一個Bean完成初始化並註入各項參數之後,初始化回掉方法會被調用,簡單的說就是完成創建之後會被調用。實現初始化回調方法有2個路徑:1.繼承org.springframework.beans.factory.InitializingBean介面,然後實現afterPropertiesSet方法。2.在Bean的XML配置上使用init-method屬性來制定要調用的初始化:

繼承實現:

 

配置實現:

 

2種方法都等效,實際使用是我們應該使用哪一種方法呢?

InitializingBean是Spring早期實現的一個生命周期回調方法。但是在JCP推出JSR-250和JSR-330規範之後,Spring的大神們開始意識到基於元編程思想和配置手段來實現非侵入式框架(Not Coupled)才是正道。所以現在都是推薦使用配置文件和JSR-250的@PostConstruct(關於各種Annotation的使用請關註後續的文章)。現在依然保留InitializingBean應該是考慮到相容問題。

 


銷毀方法

與創建方法相對應的是銷毀方法。當一個類將要被銷毀之前,對應的銷毀回調方法會被調用。銷毀方法也有一個繼承實現和配置+註解實現:

繼承實現:

 

配置實現:

 

依然建議銷毀手段也使用配置或@PreDestroy來設定銷毀方法。

 


全局配置初始化與銷毀方法

IoC容器還提供了全局配置初始化與銷毀方法的配置:

 

通過在<beans>標簽上使用

通過在<beans>標簽上使用default-init-methoddefault-destroy-method 屬性參數,可以為容器中所有的Bean統一指定初始化和銷毀的生命周期方法。

如果在<beans>上設定2個預設的生命周期方法,同時在<bean>上也指定了init-methoddestroy-method,回調方法會以<bean>上的配置為準。這樣就保證全局配置與單獨配置可以共存。

使用初始化或銷毀2個生命周期方法註意的要點:

  1. 初始化和銷毀都提供了3種手段:XML配置、註解、以及實現介面。系統的各個部分會交由不同的團隊開發,不遵循統一的規範,建議使用滿足JSR規範的註解——@PostConstruct、@PreDestroy。如果是統一的團隊,準訓一致的規範,建議使用<beans>的屬性統一名稱使用全局配置。

  2. 如果Bean設計到代理模式時(例如使用了AOP),那麼生命周期方法被調用時,有可能代理類還沒有被創建出來。因為生命周期方法是實體類完成對應工作之後就會被調用,而與代理類無關。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一,五大核心組件 1.DispatcherServlet 請求入口 2.HandlerMapping 請求派發,負責請求和控制器建立一一對應的關係 3.Controller 處理器 4.ModelAndView 封裝模型信息和視圖信息 5.ViewResolver 視圖處理器,定位頁面 二,Spri ...
  • JavaDay04總結 1、實現介面VS繼承類 : 1. 實現介面是繼承的補充 2. 實現介面可以在不打破繼承關係的前提下,對某個功能擴展 2、綁定 : 1. 前期綁定:在程式運行前進行綁定,由編譯器和連接程式實現,又叫靜態綁定 2. 後期綁定:在運行時根據對象的類型進行綁定,由方法調用機制實現,又 ...
  • 跟昨天那個自己寫的,沒有按照模板來的一看風格就不相類似,今天模擬賽的時候就是用的我的那個自己YY的代碼,才拿了10分。個人認為關鍵的問題應該在於對於數據的處理太過繁瑣了,所以回來之後,就拿了大佬的程式對照著改。在這裡不得不吐槽一下c++的讀入,cin40分,scanf滿分。還是模板的線段樹比較清晰, ...
  • 在Spring中通過註解@EnableScheduling 來開啟對計劃任務的支持,然後再執行集合任務的方法上註解@Scheduled,聲明這是一個計劃任務。 ...
  • 轉載請註明出處:https://www.cnblogs.com/funnyzpc/p/9190233.html 先來一段詩 ``` 就這樣吧 忍受折磨 然後,躺進醫院 然後,死去 化作一抔土 從此,這世界沒有煩惱 沒有病痛 沒有我 也沒有這個世界 ``` 以上是在半睡半醒中想到的,寫的不好,讀者可直 ...
  • 主要使用後端驗證,調用awt API ,會簡單調用即可,繪圖代碼已封裝到LoginVerifyUtils中。 界面展示: LoginVerifyUtils全部代碼 1 import java.awt.Color; 2 import java.awt.Font; 3 import java.awt.G ...
  • 本周大部分的時間都用在了使用JAVA語言進行編程之前的準備工作上,主要包括:JDK的安裝以及環境變數的配置,MyEclipse軟體的安裝以及熟悉界面。 下麵將詳細的介紹本周的收穫。 首先解決了第一個問題使用JAVA語言為什麼需要安裝JDK:JDK是 Java 語言的軟體開發工具包,主要用於移動設備、 ...
  • 最近一次迭代,參與了公司數據應用平臺的開發,其中負責的一塊功能早早的就完成了代碼的編寫工作,即將進入測試階段,因為有時間思考和總結代碼編寫中遇到的難題,便想著將代碼做一次重構:其中優化的一個功能就是關於數據平臺敏感欄位的收集 功能描述:數據平臺敏感欄位的收集: 開始的版本: 可以看出邏輯都散落在fo ...
一周排行
    -Advertisement-
    Play Games
  • C#TMS系統代碼-基礎頁面BaseCity學習 本人純新手,剛進公司跟領導報道,我說我是java全棧,他問我會不會C#,我說大學學過,他說這個TMS系統就給你來管了。外包已經把代碼給我了,這幾天先把增刪改查的代碼背一下,說不定後面就要趕鴨子上架了 Service頁面 //using => impo ...
  • 委托與事件 委托 委托的定義 委托是C#中的一種類型,用於存儲對方法的引用。它允許將方法作為參數傳遞給其他方法,實現回調、事件處理和動態調用等功能。通俗來講,就是委托包含方法的記憶體地址,方法匹配與委托相同的簽名,因此通過使用正確的參數類型來調用方法。 委托的特性 引用方法:委托允許存儲對方法的引用, ...
  • 前言 這幾天閑來沒事看看ABP vNext的文檔和源碼,關於關於依賴註入(屬性註入)這塊兒產生了興趣。 我們都知道。Volo.ABP 依賴註入容器使用了第三方組件Autofac實現的。有三種註入方式,構造函數註入和方法註入和屬性註入。 ABP的屬性註入原則參考如下: 這時候我就開始疑惑了,因為我知道 ...
  • C#TMS系統代碼-業務頁面ShippingNotice學習 學一個業務頁面,ok,領導開完會就被裁掉了,很突然啊,他收拾東西的時候我還以為他要旅游提前請假了,還在尋思為什麼回家連自己買的幾箱飲料都要叫跑腿帶走,怕被偷嗎?還好我在他開會之前拿了兩瓶芬達 感覺感覺前面的BaseCity差不太多,這邊的 ...
  • 概述:在C#中,通過`Expression`類、`AndAlso`和`OrElse`方法可組合兩個`Expression<Func<T, bool>>`,實現多條件動態查詢。通過創建表達式樹,可輕鬆構建複雜的查詢條件。 在C#中,可以使用AndAlso和OrElse方法組合兩個Expression< ...
  • 閑來無聊在我的Biwen.QuickApi中實現一下極簡的事件匯流排,其實代碼還是蠻簡單的,對於初學者可能有些幫助 就貼出來,有什麼不足的地方也歡迎板磚交流~ 首先定義一個事件約定的空介面 public interface IEvent{} 然後定義事件訂閱者介面 public interface I ...
  • 1. 案例 成某三甲醫預約系統, 該項目在2024年初進行上線測試,在正常運行了兩天後,業務系統報錯:The connection pool has been exhausted, either raise MaxPoolSize (currently 800) or Timeout (curren ...
  • 背景 我們有些工具在 Web 版中已經有了很好的實踐,而在 WPF 中重新開發也是一種費時費力的操作,那麼直接集成則是最省事省力的方法了。 思路解釋 為什麼要使用 WPF?莫問為什麼,老 C# 開發的堅持,另外因為 Windows 上已經裝了 Webview2/edge 整體打包比 electron ...
  • EDP是一套集組織架構,許可權框架【功能許可權,操作許可權,數據訪問許可權,WebApi許可權】,自動化日誌,動態Interface,WebApi管理等基礎功能於一體的,基於.net的企業應用開發框架。通過友好的編碼方式實現數據行、列許可權的管控。 ...
  • .Net8.0 Blazor Hybird 桌面端 (WPF/Winform) 實測可以完整運行在 win7sp1/win10/win11. 如果用其他工具打包,還可以運行在mac/linux下, 傳送門BlazorHybrid 發佈為無依賴包方式 安裝 WebView2Runtime 1.57 M ...