說(shuō)說(shuō)依賴注入
在面向?qū)ο缶幊讨校覀兘?jīng)常處理處理的問(wèn)題就是解耦,程序的耦合性越低表明這個(gè)程序的可讀性以及可維護(hù)性越高。控制反轉(zhuǎn)(Inversion of Control或IoC)就是常用的面向?qū)ο缶幊痰脑O(shè)計(jì)原則,使用這個(gè)原則我們可以降低耦合性。其中依賴注入是控制反轉(zhuǎn)最常用的實(shí)現(xiàn)。
什么是依賴
依賴是程序中常見的現(xiàn)象,比如類Car中用到了GasEnergy類的實(shí)例energy,通常的做法就是在Car類中顯式地創(chuàng)建GasEnergy類的實(shí)例,并賦值給energy。如下面的代碼
interface Energy { } class GasEnergy implements Energy { } class Car { Energy energy = new GasEnergy();}存在問(wèn)題
類Car承擔(dān)了多余的責(zé)任,負(fù)責(zé)energy對(duì)象的創(chuàng)建,這必然存在了嚴(yán)重的耦合性。舉一個(gè)現(xiàn)實(shí)中的例子,一輛汽車使用哪種能源不是由汽車來(lái)決定,而是由汽車制造商(CarMaker)來(lái)決定,這是汽車制造商的責(zé)任。
可擴(kuò)展性,假設(shè)我們想修改能源為電動(dòng)力,那么我們必然要修改Car這個(gè)類,明顯不符合開放閉合原則。
不利于單元測(cè)試。
依賴注入
依賴注入是這樣的一種行為,在類Car中不主動(dòng)創(chuàng)建GasEnergy的對(duì)象,而是通過(guò)外部傳入GasEnergy對(duì)象形式來(lái)設(shè)置依賴。 常用的依賴注入有如下三種方式
構(gòu)造器注入
將需要的依賴作為構(gòu)造方法的參數(shù)傳遞完成依賴注入。
class Car { Energy mEnergy; public Car(Energy energy) { mEnergy = energy; }}Setter方法注入
增加setter方法,參數(shù)為需要注入的依賴亦可完成依賴注入。
class Car { Energy mEnergy; public void setEnergy(Energy energy) { mEnergy = energy; }}接口注入
接口注入,聞其名不言而喻,就是為依賴注入創(chuàng)建一套接口,依賴作為參數(shù)傳入,通過(guò)調(diào)用統(tǒng)一的接口完成對(duì)具體實(shí)現(xiàn)的依賴注入。
interface EnergyConsumerInterface { public void setEnergy(Energy energy);} class Car implements EnergyConsumerInterface { Energy mEnergy; public void setEnergy(Energy energy) { mEnergy = energy; }}接口注入和setter方法注入類似,不同的是接口注入使用了統(tǒng)一的方法來(lái)完成注入,而setter方法注入的方法名稱相對(duì)比較隨意。
框架取舍
依賴注入有很多框架,最有名的就是Guice,當(dāng)然Spring也支持依賴注入。Guice采用的是運(yùn)行時(shí)讀取注解,通過(guò)反射的形式生成依賴并進(jìn)行注入。這種形式不太適合Android移動(dòng)設(shè)備,畢竟這些操作都在運(yùn)行時(shí)處理,對(duì)性能要求較高。
Dagger則是Android開發(fā)適合的依賴注入庫(kù),其同樣采用類注解的形式,不同的是它是在編譯時(shí)生成輔助類,等到在運(yùn)行時(shí)使用生成的輔助類完成依賴注入。
用還是不用
其實(shí)注入框架用還是不用,是一個(gè)問(wèn)題,如若使用框架,則要求團(tuán)隊(duì)每一個(gè)人都要遵守說(shuō)明來(lái)編寫代碼解決依賴注入。而這些框架其實(shí)也并非很容易就能上手,學(xué)習(xí)系數(shù)相對(duì)復(fù)雜,難以掌握,這也是需要考慮的問(wèn)題。
個(gè)人觀點(diǎn)為不推薦也不反對(duì)使用這些框架,但是覺得有些時(shí)候我們寄希望于一個(gè)框架,不如平時(shí)注意這些問(wèn)題,人為避免何嘗不是對(duì)自己的一種基本要求呢?
依賴查找
依賴查找和依賴注入一樣屬于控制反轉(zhuǎn)原則的具體實(shí)現(xiàn),不同于依賴注入的被動(dòng)接受,依賴查找這是主動(dòng)請(qǐng)求,在需要的時(shí)候通過(guò)調(diào)用框架提供的方法來(lái)獲取對(duì)象,獲取時(shí)需要提供相關(guān)的配置文件路徑、key等信息來(lái)確定獲取對(duì)象的狀態(tài)。
以上就是對(duì)依賴注入的資料詳細(xì)介紹,后續(xù)繼續(xù)補(bǔ)充相關(guān)資料,謝謝大家對(duì)本站的支持!
新聞熱點(diǎn)
疑難解答
圖片精選