十年網(wǎng)站開發(fā)經(jīng)驗 + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊
量身定制 + 運營維護(hù)+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
spring框架為我們提供了三種注入方式,分別是set注入,構(gòu)造方法注入,接口注入。今天就和大家一起來學(xué)習(xí)一下
成都創(chuàng)新互聯(lián)成立十多年來,這條路我們正越走越好,積累了技術(shù)與客戶資源,形成了良好的口碑。為客戶提供做網(wǎng)站、成都做網(wǎng)站、網(wǎng)站策劃、網(wǎng)頁設(shè)計、域名申請、網(wǎng)絡(luò)營銷、VI設(shè)計、網(wǎng)站改版、漏洞修補等服務(wù)。網(wǎng)站是否美觀、功能強大、用戶體驗好、性價比高、打開快等等,這些對于網(wǎng)站建設(shè)都非常重要,成都創(chuàng)新互聯(lián)通過對建站技術(shù)性的掌握、對創(chuàng)意設(shè)計的研究為客戶提供一站式互聯(lián)網(wǎng)解決方案,攜手廣大客戶,共同發(fā)展進(jìn)步。
依賴注入的基本概念
依賴注入(Dependecy Injection),也稱為IoC(Invert of Control),是一種有別于傳統(tǒng)的面向?qū)ο箝_發(fā)的思想,主要用于對應(yīng)用進(jìn)行解耦。簡單的理解就是說,本來是由應(yīng)用服務(wù)自己創(chuàng)建的對象,數(shù)據(jù),交給第三方來負(fù)責(zé)創(chuàng)建,準(zhǔn)備,并且由第三方將對應(yīng)的內(nèi)容注入到應(yīng)用服務(wù)中來,從而實現(xiàn)了對象的創(chuàng)建于對象的應(yīng)用之間的解耦,通過這種方式,應(yīng)用服務(wù)可以最小程度地減少與對象實體之前的關(guān)聯(lián)(只需要使用即可,而不關(guān)心其來源,對應(yīng)的實現(xiàn)等等),從而保持了應(yīng)用服務(wù)與對象之間的弱耦合關(guān)系。
依賴注入的簡單實現(xiàn)
可能通過文字的表達(dá),對于依賴注入不是很好理解,不過,通過簡單的代碼實現(xiàn),就可以很輕松的理解了,下面通過原始的做法以及依賴注入的做法來進(jìn)行對比,來加深對依賴注入的理解
/** * 日志服務(wù) */ class LogService{ // 注意這里,這里是手動創(chuàng)建對應(yīng)的LogDao實例對象 private LogDao logDao = new DBLogDao(); public void save(){ logDao.save(); } } /** * 日志DAO接口 */ interface LogDao{ void save(); } /** * 日志DAO的具體實現(xiàn),將日志保存到數(shù)據(jù)庫中 */ class DBLogDao implements LogDao{ @Override public void save() { System.out.println("Save to Database"); } }
從上面的代碼中可以看到,當(dāng)需要LogDao對象的時候,是直接在服務(wù)中創(chuàng)建具體的實現(xiàn),也就是new DBLogDao(),這種方式雖然方便,但是存在一定的缺點,比如說,當(dāng)想要切換對應(yīng)的實現(xiàn),比如說XMLLogDao的時候,就需要打開對應(yīng)的代碼,創(chuàng)建XMLLogDao對象,并且將其交給LogService;而且,如果LogDao的創(chuàng)建過程比較繁瑣的時候,LogService在這種實現(xiàn)方式中,就需要知道LogDao的實現(xiàn)過程,而這顯然是不太合理的,因為LogService只需要知道LogDao的存在,以及使用方式即可,而并不需要知道它的創(chuàng)建過程。
接下來來看下依賴注入或者說控制反轉(zhuǎn)是怎么解決這些問題的。
class LogService{ // 注意這里,這里并沒創(chuàng)建對應(yīng)的對象 private LogDao logDao; // 通過屬性將LogDao注入到LogService中,這也就是依賴注入的來源 // 依賴別人講所需要的對象注入進(jìn)來 public void setLogDao(LogDao logDao) { this.logDao = logDao; } public void save(){ logDao.save(); } } // LogDao接口及其實現(xiàn)DBLogDao同上,這里省略 /** * 模擬的容器類,負(fù)責(zé)創(chuàng)建各個對象,并且將對應(yīng)的依賴對象注入進(jìn)去 */ class Container{ public void create(){ // 創(chuàng)建對象 LogService logService = new LogService(); LogDao logDao = new DBLogDao(); // 注入LogDao對象 logService.setLogDao(logDao); } }
可能這里你會覺得說,create方法中也是手動創(chuàng)建了DBLogDao對象,其實不然,對于create方法來說,它只是負(fù)責(zé)創(chuàng)建對象,并不管對象的用途,也就是說,這里create方法可以通過各種其他手段,比如利用反射技術(shù),再通過配置文件來配置對應(yīng)的類的信息,這樣,當(dāng)需要修改具體的實現(xiàn)的時候,只需要修改配置文件,create就會創(chuàng)建對應(yīng)的對象,并且將其注入到LogService中,而這個過程對于LogService來說是透明的,LogService只知道自己有一個LogDao的對象,而不知道,也不需要知道LogDao對象是怎么來的。也就是實現(xiàn)了創(chuàng)建與使用的解耦。
至于控制反轉(zhuǎn)名詞,其實也是很顯然的嘛,本來是LogService自己創(chuàng)建的對象,現(xiàn)在將其交給Container來創(chuàng)建了,那么創(chuàng)建對象的權(quán)限不就是反轉(zhuǎn)了嘛^_^
一般來說,依賴注入有三種方式,分別是屬性注入,也就是上面我們看到的內(nèi)容,還有一種是構(gòu)造器注入,也就是通過構(gòu)造器注入對應(yīng)的對象,還有一種不常用的接口注入,其實本質(zhì)上也是屬于屬性注入。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。