本文實(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)了類的可重用性?;仡檹那皩W(xué)過的設(shè)計(jì)模式,可以發(fā)現(xiàn),這與Observer模式有相似之處。
下面是一個(gè)完整的例子:
?php
interface 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ì)模式'...我是出來打醬油的......
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《PHP基本語法入門教程》、《PHP運(yùn)算與運(yùn)算符用法總結(jié)》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫操作入門教程》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- php設(shè)計(jì)模式 Delegation(委托模式)
- php設(shè)計(jì)模式之委托模式
- PHP設(shè)計(jì)模式之建造者模式定義與用法簡(jiǎn)單示例
- PHP設(shè)計(jì)模式之裝飾器模式定義與用法簡(jiǎn)單示例
- PHP設(shè)計(jì)模式之觀察者模式定義與用法示例
- PHP設(shè)計(jì)模式之適配器模式原理與用法分析
- PHP設(shè)計(jì)模式之原型設(shè)計(jì)模式原理與用法分析
- PHP設(shè)計(jì)模式之單例模式原理與實(shí)現(xiàn)方法分析
- PHP常用的三種設(shè)計(jì)模式匯總
- PHP設(shè)計(jì)模式之委托模式定義與用法簡(jiǎn)單示例