本文實(shí)例分析了PHP耦合設(shè)計(jì)模式。分享給大家供大家參考,具體如下:
一個(gè)軟件,它具有許多類,類與類之間需要互相調(diào)用,一旦某個(gè)類與另一個(gè)類具有緊密耦合關(guān)系的時(shí)候,這個(gè)軟件的重用性就會(huì)大大降低。所以一個(gè)軟件的重用性的高低就取決于它的耦合程度的高低。
耦合度:程序模塊之間的關(guān)聯(lián)、依賴程度。
在設(shè)計(jì)過程中提出:當(dāng)設(shè)計(jì)這個(gè)軟件的體系結(jié)構(gòu)的時(shí)候,就發(fā)現(xiàn)了這個(gè)軟件的邏輯運(yùn)行部分(SimpleRouter類)和輸出部分(SimpleRouterFrame類)不能很好的結(jié)合起來。即:我們不得不將程序界面的引用(reference to SimpleRouterFrame)一層一層的傳遞給程序的核心部分,以提供輸出功能。
在開發(fā)過程中提出:當(dāng)我們對(duì)輸出界面(SimpleRouterFrame類)進(jìn)行了一些修改后,特別是某些方法名稱修改后,相應(yīng)程序核心部分(SimpleRouter類)的代碼也需要重新修改以適應(yīng)這個(gè)新的輸出界面。
問題的原因:類與類之間耦合的過于緊密,以至于每次需要修改一個(gè)類,它相應(yīng)的關(guān)聯(lián)類都需要修改代碼來適應(yīng)這個(gè)修改過的類。 比如說:某個(gè)類A需要直接顯示的調(diào)用另一個(gè)類B的public方法,一旦B不再支持這個(gè)方法,或者重寫了這個(gè)方法名稱,A就需要重新編寫代碼來適應(yīng)。另一種情況:某類A需要用到具有某種特定方法的類B,但B的形式并不確定,一旦B的內(nèi)部結(jié)構(gòu)改變,A就可能需要重寫代碼。
為避免這種情況,需要降低A與B之間的耦合度,不論形式如何,只要B仍然能夠?qū)崿F(xiàn)A所需要的功能,A就不需要重寫代碼, 解決方法:令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)了類與類之間的松散耦合,大大增強(qiáng)了類的可重用性。回顧從前學(xué)過的設(shè)計(jì)模式,可以發(fā)現(xiàn),這與Observer模式有相似之處。
下面是一個(gè)完整的例子:
<?phpinterface Calculation { function compute($a, $b);}class Addition implements Calculation { function compute($a, $b) { return "加法運(yùn)算結(jié)果為:".($a+$b); }}class Subtraction implements Calculation { function compute($a, $b) { return "減法運(yùn)算結(jié)果為:".($a-$b); }}class Multiplication implements Calculation { function compute($a, $b) { return "乘法運(yùn)算結(jié)果為:".($a*$b); }}class Division implements Calculation{ function compute($a, $b) { return "除法運(yùn)算結(jié)果為:".($a/$b); }}class Modf implements Calculation { function compute($a, $b) { return "取模運(yùn)算結(jié)果為:".($a % $b); }}class Coupling implements Calculation { //這里直接:public $varl = new LazyDog(); 會(huì)出錯(cuò)。 public $varl = null; function __construct() { $this->varl = new LazyDog(); } function compute($a, $b) { return $this->varl->say(); }}/*也可以用繼承的方式實(shí)現(xiàn)喲:class Coupling extends LazyDog implements Calculation { function compute($a, $b) { return parent::say(); }}*/class LazyDog { function say() { return "我什么運(yùn)算都不做...只是為了實(shí)現(xiàn)'耦合設(shè)計(jì)模式'...我是出來打醬油的......"; }}class Test { private $one; private $two; public function __construct($x,$y) { $this->one=$x; $this->two=$y; echo "Class Test 初始化:屬性/$one=".$this->one.",屬性/$two=".$this->two."<hr />"; } function display(Calculation $a){ return "用PHP接口技術(shù)實(shí)現(xiàn)的運(yùn)算:".$a->compute($this->one,$this->two)."<hr />"; }}$t = new Test(96,12);$t1 = new Addition();$t2 = new Subtraction();$t3 = new Multiplication();$t4 = new Division();$t5 = new Modf();$dog = new Coupling();echo $t->display($t1);echo $t->display($t2);echo $t->display($t3);echo $t->display($t4);echo $t->display($t5);echo $t->display($dog);?>程序運(yùn)行結(jié)果:
Class Test 初始化:屬性$one=96,屬性$two=12
用PHP接口技術(shù)實(shí)現(xiàn)的運(yùn)算:加法運(yùn)算結(jié)果為:108
用PHP接口技術(shù)實(shí)現(xiàn)的運(yùn)算:減法運(yùn)算結(jié)果為:84
用PHP接口技術(shù)實(shí)現(xiàn)的運(yùn)算:乘法運(yùn)算結(jié)果為:1152
用PHP接口技術(shù)實(shí)現(xiàn)的運(yùn)算:除法運(yùn)算結(jié)果為:8
用PHP接口技術(shù)實(shí)現(xiàn)的運(yùn)算:取模運(yùn)算結(jié)果為:0
用PHP接口技術(shù)實(shí)現(xiàn)的運(yùn)算:我什么運(yùn)算都不做...只是為了實(shí)現(xiàn)'耦合設(shè)計(jì)模式'...我是出來打醬油的......
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
新聞熱點(diǎn)
疑難解答
圖片精選