Spring的IOC容器實(shí)例化bean的方式總結(jié)
IOC容器實(shí)例化bean的三種方式:構(gòu)造方法、靜態(tài)工廠、實(shí)例工廠。 本文章涉及工程目錄如下:
IOC容器實(shí)例化bean的三種方式
構(gòu)造方法
對(duì)象在new的時(shí)候通過構(gòu)造方法完成實(shí)例化。bean本質(zhì)是對(duì)象,也可以通過構(gòu)造方法完成實(shí)例化。
涉及代碼片
。
// applicationContext.xml <bean id="flowService" class="com.lwb.services.impl.FlowServiceImpl">
// FlowServiceImpl.java public class FlowServiceImpl implements FlowService { private FlowServiceImpl(){ System.out.println(this.getClass() + "-----進(jìn)入FlowServiceImpl" + "無參構(gòu)造器"); } @Override public void saveService() { System.out.println(this.getClass() + "-----進(jìn)入FlowServiceImpl"); } }
// App.java public class App { public static void main(String[] args){ ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContext.xml"); } }
執(zhí)行后返回結(jié)果:
思考:
1、構(gòu)造方法底層是通過反射機(jī)制實(shí)現(xiàn)的。注意上面無參構(gòu)造方法是private,只有反射才能訪問到私有方法。
2、底層使用的是無參構(gòu)造方法??梢詫懸粋€(gè)帶參的構(gòu)造方法進(jìn)行驗(yàn)證,會(huì)報(bào)錯(cuò)。
靜態(tài)工廠
涉及代碼片
。
// applicationContext.xml <!--靜態(tài)工廠實(shí)例化方法 class為靜態(tài)工廠類路徑,factory-method 為方法名 --> <bean id="flowDao1" class="com.lwb.factory.FlowDaoStaticFactory" factory-method="getFlowDao"/>
// FlowDaoStaticFactory.java //注意getFlowDao是static的,所以叫靜態(tài)工廠 public class FlowDaoStaticFactory { public static FlowDao getFlowDao(){ System.out.println("-----進(jìn)入靜態(tài)工廠方法StaticFactory"); return new FlowDaoImpl(); } }
// App.java public class App { public static void main(String[] args){ ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContext.xml"); } }
執(zhí)行后返回結(jié)果:
思考:
1、為什么使用靜態(tài)工廠方法,而不直接去new? 靜態(tài)工廠方法在返回new的對(duì)象實(shí)例之前,可以實(shí)現(xiàn)一些業(yè)務(wù)邏輯,如代碼中的日志輸出。
實(shí)例工廠
涉及代碼片
。
// applicationContext.xml <bean id="flowDaoExFactory" class="com.lwb.factory.FlowDaoExFactory"/> <bean id="flowDao2" factory-method="getFlowDao" factory-bean="flowDaoExFactory"/>
// FlowDaoExFactory .java //注意getFlowDao是public的,對(duì)比靜態(tài)工廠 public class FlowDaoExFactory { public FlowDao getFlowDao(){ System.out.println(this.getClass() + "------進(jìn)入實(shí)例工廠類FlowDaoExFactory"); return new FlowDaoImpl(); } }
// App.java public class App { public static void main(String[] args){ ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContext.xml"); } }
執(zhí)行后返回結(jié)果:
思考:
1、靜態(tài)工廠和實(shí)例工廠的區(qū)別?
靜態(tài)工廠方法是static的,是在類加載的時(shí)候就創(chuàng)建了,可以直接使用,不需要實(shí)例化工廠類。實(shí)例工廠是public的,需要先實(shí)例化,才能使用。靜態(tài)工廠適合實(shí)時(shí)性很高的場(chǎng)景。實(shí)際場(chǎng)景中大部分使用實(shí)例工廠。
2、實(shí)例工廠的簡(jiǎn)單寫法——FactoryBean
涉及代碼片。
// applicationContext.xml <bean id="flowDao3" class="com.lwb.factory.FlowDaoFactoryBean"/>
// FlowDaoFactoryBean .java public class FlowDaoFactoryBean implements FactoryBean<FlowDao> { //返回實(shí)例化對(duì)象 @Override public FlowDao getObject() throws Exception{ System.out.println(this.getClass() + "------進(jìn)入實(shí)例工廠FlowDaoFactoryBean,getObject"); return new FlowDaoImpl(); } //返回class對(duì)象 @Override public Class<?> getObjectType() { System.out.println(this.getClass() + "------進(jìn)入實(shí)例工廠FlowDaoFactoryBean,getObjectType"); return FlowDao.class; } }
// App.java public class App { public static void main(String[] args){ ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContext.xml"); } }
思考:
1、為什么只輸出了getObject()里面的內(nèi)容?getObject()重寫了返回實(shí)例化對(duì)象的方法。getObjectType()返回的是class對(duì)象,只有在調(diào)用的時(shí)候才會(huì)執(zhí)行(反射?)
2、FlowDaoFactoryBean可以通過重寫isSingleton()方法聲明是否是單例。
思考
1、上述例子中App.java為什么不獲取bean(執(zhí)行FlowDao flowDao = (FlowDao) ctx.getBean("flowDao3")),也能實(shí)例化?
IOC實(shí)例化bean對(duì)象的時(shí)機(jī):
(1)IOC初始化的bean對(duì)象默認(rèn)是單例的。單例+懶加載會(huì)在ioc容器初始化完成后直接實(shí)例化所有bean對(duì)象供使用。
(2)非單例和單例+非懶加載。在使用bean的時(shí)候才會(huì)去初始化。
以上就是Spring的IOC容器實(shí)例化bean的方式總結(jié)的詳細(xì)內(nèi)容,更多關(guān)于Spring IOC容器實(shí)例化bean的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
解決idea 拉取代碼出現(xiàn)的 “ Сannot Run Git Cannot identify version of
這篇文章主要介紹了解決idea 拉取代碼出現(xiàn)的 “ Сannot Run Git Cannot identify version of git executable: no response“的問題,需要的朋友可以參考下2020-08-08Java遠(yuǎn)程debug調(diào)試的操作步驟
日常項(xiàng)目中,通常我們的代碼都是部署到遠(yuǎn)程的服務(wù)器,有時(shí)線上出現(xiàn)了問題,經(jīng)常需要我們?cè)黾右恍┤罩緛砼挪閱栴},但是如果是測(cè)試環(huán)境的場(chǎng)景下或者我們能進(jìn)行遠(yuǎn)程調(diào)試的話,我們就可以使用遠(yuǎn)程的Debug方式進(jìn)行遠(yuǎn)程調(diào)試,下面給大家介紹一下Java遠(yuǎn)程debug調(diào)試的操作步驟2025-04-04Spring Boot CORS 配置方法允許跨域請(qǐng)求的最佳實(shí)踐方案
跨域請(qǐng)求在現(xiàn)代Web開發(fā)中非常重要,特別是在涉及多個(gè)前端和后端服務(wù)時(shí),本文詳細(xì)介紹了跨域請(qǐng)求的背景、重要性以及如何解決跨域問題,通過SpringBoot框架的CORS配置,可以有效地處理跨域請(qǐng)求,確保數(shù)據(jù)傳輸?shù)陌踩院陀脩趔w驗(yàn),感興趣的朋友跟隨小編一起看看吧2024-11-11java中的Io(input與output)操作總結(jié)(二)
這一節(jié)我們來討論關(guān)于文件自身的操作包括:創(chuàng)建文件對(duì)象、創(chuàng)建和刪除文件、文件的判斷和測(cè)試、創(chuàng)建目錄、獲取文件信息、列出文件系統(tǒng)的根目錄、列出目錄下的所有文件,等等,感興趣的朋友可以了解下2013-01-01Java中的非對(duì)稱加密算法原理與實(shí)現(xiàn)方式
在當(dāng)今的信息時(shí)代,數(shù)據(jù)安全已經(jīng)成為了一個(gè)至關(guān)重要的問題,加密技術(shù)作為保障信息安全的重要手段,受到了廣泛的應(yīng)用和關(guān)注,本篇文章將詳細(xì)介紹Java中的非對(duì)稱加密算法原理及其實(shí)現(xiàn)方式,需要的朋友可以參考下2023-12-12淺談為什么Java中1000==1000為false而100==100為true
這篇文章主要介紹了淺談為什么Java中1000==1000為false而100==100為true,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-09-09調(diào)用Process.waitfor導(dǎo)致的進(jìn)程掛起問題及解決
這篇文章主要介紹了調(diào)用Process.waitfor導(dǎo)致的進(jìn)程掛起問題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12java中g(shù)radle項(xiàng)目報(bào)錯(cuò)org.gradle?.api.plugins.MavenPlugin解決辦法
在使用Gradle時(shí)開發(fā)者可能會(huì)遇到org.gradle?.api.plugins.MavenPlugin報(bào)錯(cuò)提醒,這篇文章主要給大家介紹了關(guān)于java中g(shù)radle項(xiàng)目報(bào)錯(cuò)org.gradle?.api.plugins.MavenPlugin的解決辦法,需要的朋友可以參考下2023-12-12Spring事務(wù)失效的一種原因關(guān)于this調(diào)用的問題
這篇文章主要介紹了Spring事務(wù)失效的一種原因關(guān)于this調(diào)用的問題,本文給大家分享問題原因及解決辦法,通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2021-10-10