Spring的InitializingBean接口解析
Spring的InitializingBean接口解析
之前知道spring的InitializingBean,但是沒(méi)怎么關(guān)注,最近在一次代碼改造的使用工廠模式和策略模式的情況下,發(fā)現(xiàn)InitializingBean。
InitializingBean是spring為bean的初始化提供了一種新的方式,里面只有一個(gè)方法afterPropertiesSet,作用就是實(shí)現(xiàn)這個(gè)接口或者實(shí)現(xiàn)了繼承InitializingBean的方法的bean都要執(zhí)行這個(gè)方法。
舉個(gè)例子:
@Component
import org.springframework.beans.factory.InitializingBean;
public class TestInitializingBean implements InitializingBean{
@Override
public void afterPropertiesSet() throws Exception {
System.out.println(" 張鵬真的很帥 InitializingBean");
}
public void testInit(){
System.out.println("張鵬真的很帥");
}
}
調(diào)起spring程序會(huì)打印出
張鵬真的很帥 InitializingBean
這個(gè)單個(gè)看起來(lái)沒(méi)啥用,但是結(jié)合實(shí)際情況就不一樣 比如說(shuō)我想在下面這個(gè)工廠類(lèi)里面的map添加值
@Component
public class ValidAssetByTypeFactory {
private static Map<String,ValidateAssetService> validAssetTypeMap = new HashMap<>();
/**
* 用來(lái)維護(hù)根據(jù)類(lèi)型驗(yàn)證資產(chǎn)的規(guī)則的map
* @param type
* @return
*/
public static ValidateAssetService getInvokeStrategyMap(String type){
return validAssetTypeMap.get(type);
}
}
實(shí)際上這個(gè)validAssetTypeMap ,這個(gè)map是靜態(tài)的你要是真要想往里面塞值的話(huà),只能在這個(gè)類(lèi)下面寫(xiě)個(gè)靜態(tài)方法或者一個(gè)一個(gè)靜態(tài)塊往這個(gè)map里面塞值,類(lèi)似這樣:
static
{
validAssetTypeMap.put ("A","AStragey");
validAssetTypeMap.put ("B","BStragey");
validAssetTypeMap.put ("C","CStragey");
}
但是有了這個(gè)InitializingBean,可以這么玩:
(1)我先實(shí)現(xiàn)一個(gè)InitializingBean的接口
public interface ValidateAssetService extends InitializingBean {
Result<List<DetailsAppAsset>> validateAssetByType(List<AssetDO> assetDOList,String type);
}
(2)我在這個(gè)工廠類(lèi)里面添加一個(gè)靜態(tài)的方法,用來(lái)往這個(gè)靜態(tài)map添加值
注意這個(gè)register方法
public class ValidAssetByTypeFactory {
private static Map<String,ValidateAssetService> validAssetTypeMap = new HashMap<>();
/**
* 用來(lái)維護(hù)根據(jù)類(lèi)型驗(yàn)證資產(chǎn)的規(guī)則的map
* @param type
* @return
*/
public static ValidateAssetService getInvokeStrategyMap(String type){
return validAssetTypeMap.get(type);
}
/**
* 注冊(cè)(創(chuàng)建實(shí)現(xiàn)類(lèi)直接注冊(cè)即可,不需要在該類(lèi)放進(jìn)策略map里面)
* @param type
* @param validateAssetService
*/
public static void register(String type, ValidateAssetService validateAssetService){
if(StringUtil.isEmpty(type)||null == validateAssetService){
return;
}
validAssetTypeMap.put(type,validateAssetService);
}
}
(3)由于上一步給我們往靜態(tài)map添加值留了一個(gè)口子,我們要利用InitializingBean初始化會(huì)執(zhí)行afterPropertiesSet的特性在spring執(zhí)行起來(lái)的時(shí)候直接調(diào)用這個(gè)方法往靜態(tài)map里面塞值。
注意這個(gè)afterPropertiesSet方法的實(shí)現(xiàn):
@Component
public class RepairAssetValidate implements ValidateAssetService {
@Override
public Result<List<DetailsAppAsset>> validateAssetByType(List<AssetDO> assetDOList, String type) {
if( CollUtil.isEmpty(assetDOList) ){
return resultCreator.create(AssetErrorCode.ASSET_NOT_EXISTS, EntityConverter.convertList(assetDOList, DetailsAppAsset.class));
}
for(AssetDO assetDO : assetDOList){
if( assetDO.getQuoteOrderId() != null ){
return resultCreator.create(AssetValidErrorCode.ASSET_IN_OTHER_OPERATOR,"資產(chǎn)已被"+ QuoteOrderType.getQuoteOrderType(assetDO.getQuoteOrderType())+"引用" ,EntityConverter.convertList(assetDOList, DetailsAppAsset.class));
}
}
return resultCreator.create(ErrorCode.SUCCESS, EntityConverter.convertList(assetDOList, DetailsAppAsset.class));
}
@Override
public void afterPropertiesSet() throws Exception {
ValidAssetByTypeFactory.register(AssetValidateType.REPAIR.getValue(),this);
}
@Autowired
private ResultCreator resultCreator;
}
這樣我們就可以在別的地方借用spring的InitializingBean來(lái)給別的靜態(tài)數(shù)據(jù)結(jié)構(gòu)塞值,整個(gè)過(guò)程可以方便我們擴(kuò)展代碼,感覺(jué)這種方式寫(xiě)代碼更符合開(kāi)閉原則。
到此這篇關(guān)于Spring的InitializingBean接口解析的文章就介紹到這了,更多相關(guān)InitializingBean接口內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
MyBatis-Plus中實(shí)現(xiàn)自定義復(fù)雜排序邏輯的詳細(xì)步驟
這篇文章主要介紹了MyBatis-Plus中實(shí)現(xiàn)自定義復(fù)雜排序邏輯,通過(guò)使用MyBatis-Plus的QueryWrapper和SQL原始片段,我們可以靈活地實(shí)現(xiàn)復(fù)雜的數(shù)據(jù)排序邏輯,這種方法尤其適用于需要對(duì)數(shù)據(jù)進(jìn)行特定規(guī)則排序的場(chǎng)景,需要的朋友可以參考下2024-07-07
SpringBoot定時(shí)任務(wù)兩種(Spring Schedule 與 Quartz 整合 )實(shí)現(xiàn)方法
本篇文章主要介紹了SpringBoot定時(shí)任務(wù)兩種(Spring Schedule 與 Quartz 整合 )實(shí)現(xiàn)方法,詳細(xì)的介紹了Spring Schedule 與 Quartz 整合的兩種方法,有興趣的可以了解一下。2017-03-03
淺談java object對(duì)象在heap中的結(jié)構(gòu)
本文主要介紹了淺談java object對(duì)象在heap中的結(jié)構(gòu),感興趣的同學(xué),可以參考下。2021-06-06
使用Backoff策略提高HttpClient連接管理的效率
這篇文章主要為大家介紹了Backoff策略提高HttpClient連接管理的效率使用解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10
詳解JavaEE 使用 Redis 數(shù)據(jù)庫(kù)進(jìn)行內(nèi)容緩存和高訪問(wèn)負(fù)載
本篇文章主要介紹了JavaEE 使用 Redis 數(shù)據(jù)庫(kù)進(jìn)行內(nèi)容緩存和高訪問(wèn)負(fù)載,具有一定的參考價(jià)值,有興趣的可以了解一下2017-08-08
使用java實(shí)現(xiàn)Xmodem協(xié)議
這篇文章主要介紹了使用java實(shí)現(xiàn)Xmodem協(xié)議的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12

