有關(guān)松散耦合與接口的概念介紹
面向?qū)ο蟮能浖_(kāi)發(fā)和設(shè)計(jì)的目標(biāo)之一就是高聚合性和低耦合性。用簡(jiǎn)單直白的說(shuō)法,最大聚合就是指類(lèi)(模塊)的封裝性要好,功能緊湊而獨(dú)立;最小耦合就是指類(lèi)(模塊)之間的關(guān)聯(lián)和牽扯越少越好。
用術(shù)語(yǔ)解釋?zhuān)壕酆虾婉詈鲜桥c類(lèi)和服務(wù)相關(guān)聯(lián)的概念。聚合是類(lèi)(服務(wù))內(nèi)各條語(yǔ)句相互關(guān)聯(lián)程度的量度,程度(從高到低):功能、信息、通信、過(guò)程、時(shí)間、邏輯、偶然,聚合度越高越好。耦合是模塊(服務(wù))間關(guān)聯(lián)程度的量度。程度(從高到低):內(nèi)容、公共、控制、標(biāo)志、數(shù)據(jù)、無(wú)耦合,偶合度越低越好。
實(shí)際上在做開(kāi)發(fā)時(shí),無(wú)耦合是不可能的,理想的是數(shù)據(jù)耦合(通過(guò)接口傳遞數(shù)據(jù))。
以上所說(shuō)用一句話來(lái)說(shuō)就是實(shí)現(xiàn)松散耦合,而如何要實(shí)現(xiàn)松散耦合,不妨看下面的具體介紹
有關(guān)松散耦合與接口的使用
一個(gè)軟件,它具有許多類(lèi),類(lèi)與類(lèi)之間需要互相調(diào)用,一旦某個(gè)類(lèi)與另一個(gè)類(lèi)具有緊密耦合關(guān)系的時(shí)候,這個(gè)軟件的重用性就會(huì)大大降低。所以一個(gè)軟件的重用性的高低就取決于它的耦合程度的高低。
1.2 名詞解釋
1.2.1 耦合度:程序模塊之間的關(guān)聯(lián)、依賴(lài)程度。
1.3 關(guān)鍵詞
低耦合度;接口設(shè)計(jì);模塊重用;
松散耦合:?jiǎn)栴}的提出
2.1 在設(shè)計(jì)過(guò)程中提出
當(dāng)設(shè)計(jì)這個(gè)軟件的體系結(jié)構(gòu)的時(shí)候,就發(fā)現(xiàn)了這個(gè)軟件的邏輯運(yùn)行部分(SimpleRouter類(lèi))和輸出部分(SimpleRouterFrame類(lèi))不能很好的結(jié)合起來(lái)。即:我們不得不將程序界面的引用(reference to SimpleRouterFrame)一層一層的傳遞給程序的核心部分,以提供輸出功能。
2.2 在開(kāi)發(fā)過(guò)程中提出
當(dāng)我們對(duì)輸出界面(SimpleRouterFrame類(lèi))進(jìn)行了一些修改后,特別是某些方法名稱(chēng)修改后,相應(yīng)程序核心部分(SimpleRouter類(lèi))的代碼也需要重新修改以適應(yīng)這個(gè)新的輸出界面。
問(wèn)題的原因
類(lèi)與類(lèi)之間耦合的過(guò)于緊密,以至于每次需要修改一個(gè)類(lèi),它相應(yīng)的關(guān)聯(lián)類(lèi)都需要修改代碼來(lái)適應(yīng)這個(gè)修改過(guò)的類(lèi)。
比如說(shuō):某個(gè)類(lèi)A需要直接顯示的調(diào)用另一個(gè)類(lèi)B的public方法,一旦B不再支持這個(gè)方法,或者重寫(xiě)了這個(gè)方法名稱(chēng),A就需要重新編寫(xiě)代碼來(lái)適應(yīng)。另一種情況:某類(lèi)A需要用到具有某種特定方法的類(lèi)B,但B的形式并不確定,一旦B的內(nèi)部結(jié)構(gòu)改變,A就可能需要重寫(xiě)代碼。
松散耦合:?jiǎn)栴}的解決方案
為避免這種情況,需要降低A與B之間的耦合度,目的就在于,無(wú)論B的形式如何,只要B仍然能夠?qū)崿F(xiàn)A所需要的功能,A就不需要重寫(xiě)代碼,
解決方法:令B實(shí)現(xiàn)某種接口I,定義 I.Method(); 同時(shí)A在調(diào)用B的方法時(shí)候直接調(diào)用I的方法即可;而從前會(huì)將B當(dāng)作參數(shù)傳給A,然后A再調(diào)用B的方法的地方:
- {
- A.AMethod( B b ) {
- b.BMethod();
- /*….*/
- }
- }
修改成:
- {
- A.AMethod( I i ) {
- i.Method();
- }
- }
在這里,B只需要實(shí)現(xiàn)I.Method()方法即可,完全隱藏了實(shí)現(xiàn)細(xì)節(jié)。
按照這種方法,既實(shí)現(xiàn)了類(lèi)與類(lèi)之間的松散耦合,大大增強(qiáng)了類(lèi)的可重用性。回顧從前學(xué)過(guò)的設(shè)計(jì)模式,可以發(fā)現(xiàn),這與Observer模式有相似之處。
【編輯推薦】