Spring提倡面向接口編程,來降低模塊耦合度,使代碼易維護孕似、重構(gòu)和測試。其核心技術(shù)是依賴注入和面向切面編程刮刑,然后基于這兩種核心技術(shù)實現(xiàn)了許多強大的功能喉祭。這里對依賴注入做一個理論上的梳理养渴。
1、基本原則--依賴倒置原則(Dependence Inversion Principle, DIP)
DIP是一種軟件設(shè)計的指導(dǎo)思想泛烙。傳統(tǒng)軟件設(shè)計中理卑,上層代碼依賴于下層代碼,當(dāng)下層出現(xiàn)變動時蔽氨, 上層代碼也要相應(yīng)變化藐唠,維護成本較高。而DIP的核心思想是上層定義接口鹉究,下層實現(xiàn)這個接口宇立, 從而使得下層依賴于上層,降低耦合度自赔,提高整個系統(tǒng)的彈性妈嘹。這種面向接口編程的思想,經(jīng)實踐證明是有效的策略绍妨。DIP只是一種理念润脸、思想,而IoC是一種實現(xiàn)DIP的方法他去。
2毙驯、控制反轉(zhuǎn)(Inversion of Control, IoC)
上層模塊只定義了接口,下層模塊只負責(zé)實現(xiàn)接口灾测,上層模塊不知道是哪個類實現(xiàn)了這個接口尔苦,甚至上層模塊中不應(yīng)該知道是哪個類實現(xiàn)了接口,因為當(dāng)代碼重構(gòu)或修改后行施,類名發(fā)生了變化允坚,仍舊需要修改上層代碼。所以在上層模塊中不應(yīng)該負責(zé)對其依賴的實例化蛾号,這個實例化的過程就需要交給第三方來實現(xiàn)稠项,也就是說不再負責(zé)其依賴的創(chuàng)建和生命周期,將其依賴對象的控制權(quán)交給第三方鲜结。 IoC的核心是將類(上層)所依賴的單元(下層)的實例化過程交由第三方來實現(xiàn)展运。 一個簡單的特征就是類中不對所依賴的單元有諸如 new Class() 的實例化語句。
3精刷、控制反轉(zhuǎn)容器(IoC Container)
當(dāng)項目比較大時拗胜,依賴關(guān)系可能會很復(fù)雜。 而IoC Container(即外部的第三方)提供了動態(tài)地創(chuàng)建怒允、注入依賴單元埂软,映射依賴關(guān)系等功能,減少了許多代碼量纫事。許多成熟的框架都實現(xiàn)了Container 來處理這些工作勘畔。
4所灸、依賴注入(Dependence Injection, DI)
DI是IoC的一種設(shè)計模式,是一種套路炫七,按照DI的套路爬立,就可以實現(xiàn)IoC,就能符合DIP原則万哪。 DI的核心是把類所依賴的單元的實例化過程侠驯,由第三方實現(xiàn),而在上層模塊創(chuàng)建時奕巍,第三方會自動將其依賴的單元實例化并通過某種方式注入到類的內(nèi)部來陵霉。上層模塊根本不知道注入的到底是哪個實體類,也不關(guān)心注入的過程伍绳,極大地降低了上層模塊和其依賴的耦合度。
5乍桂、服務(wù)定位器(Service Locator)
Service Locator是IoC的另一種實現(xiàn)方式冲杀, 其核心是把所有可能用到的依賴單元交由Service Locator進行實例化和創(chuàng)建、配置睹酌, 把類對依賴單元的依賴权谁,轉(zhuǎn)換成類對Service Locator的依賴。 DI 與 Service Locator并不沖突憋沿,兩者可以結(jié)合使用旺芽。 目前,Yii2.0把這DI和Service Locator這兩個東西結(jié)合起來使用辐啄,或者說通過DI容器采章,實現(xiàn)了Service Locator。而Spring把DI使用到了極致壶辜。