簡(jiǎn)單介紹PHP的責(zé)任鏈編程模式
概述
責(zé)任鏈模式是一種對(duì)象的行為模式。在責(zé)任鏈模式里,很多對(duì)象由每一個(gè)對(duì)象對(duì)其下家的引用而連接起來(lái)形成一條鏈。請(qǐng)求在這個(gè)鏈上傳遞,直到鏈上的某一個(gè)對(duì)象決定處理此請(qǐng)求。發(fā)出這個(gè)請(qǐng)求的客戶端并不知道鏈上的哪一個(gè)對(duì)象最終處理這個(gè)請(qǐng)求,這使得系統(tǒng)可以在不影響客戶端的情況下動(dòng)態(tài)的重新組織和分配責(zé)任
責(zé)任鏈模式的定義
使多個(gè)對(duì)象都有機(jī)會(huì)處理請(qǐng)求,從而避免了請(qǐng)求的發(fā)送者和接受者之間耦合關(guān)系,將這些對(duì)象連成一條鏈,并沿著這條鏈傳遞該請(qǐng)求,直到有對(duì)象處理它為止。
責(zé)任鏈模式的優(yōu)點(diǎn)
最為顯著的優(yōu)點(diǎn)就是將請(qǐng)求和處理分開(kāi)。請(qǐng)求者可以不用知道是誰(shuí)處理的,處理者可以不用知道請(qǐng)求的全貌,兩者解耦,提高系統(tǒng)的靈活性。
責(zé)任鏈模式的缺點(diǎn)
一是性能問(wèn)題,每個(gè)請(qǐng)求都是從鏈頭遍歷到鏈尾,特別是在鏈比較長(zhǎng)的時(shí)候,性能是一個(gè)問(wèn)題。二是調(diào)試不是很方便,特別是鏈條比較長(zhǎng)的,環(huán)節(jié)比較多的時(shí)候,由于采用了類似遞歸的方式 ,調(diào)試的時(shí)候邏輯可能比較復(fù)雜。
責(zé)任鏈模式涉及到的角色如下:
抽象處理者(Handler)角色:定義出一個(gè)處理請(qǐng)求的接口。如果需要,接口可以定義出一個(gè)方法以設(shè)定和返回對(duì)下家的引用。這個(gè)角色通常由一個(gè)php的抽象類或接口實(shí)現(xiàn)。上圖中Handler類的聚合關(guān)系給出了具體子類對(duì)下家的引用,抽象方法handleRequest()規(guī)范了子類處理請(qǐng)求的操作
具體處理者(ConcreateHandle)角色:具體處理者接到請(qǐng)求后,可以選擇將請(qǐng)求處理掉,或者將請(qǐng)求傳給下家。由于具體處理者持有對(duì)下家的引用,因此,如果需要,具體處理這可以訪問(wèn)下家
來(lái)看一個(gè)PHP的責(zé)任鏈模式編程實(shí)例:
<?php
/**
* 抽象處理者角色
* @author wzy
*
*/
abstract class Handle
{
/**
* 持有后繼的責(zé)任對(duì)象
*
* @var object
*/
protected $successor;
/**
* 示意處理請(qǐng)求的方法,雖然這個(gè)示意方法是沒(méi)有傳入?yún)⑺氐?
* 但實(shí)際是可以傳入?yún)?shù)的,根據(jù)具體需要來(lái)選擇是否傳遞參數(shù)
*/
public abstract function handleRequest ();
/**
* 取值方法
*
* @return object
*/
public function getSuccessor ()
{
return $this->successor;
}
/**
* 賦值方法,設(shè)置后繼的責(zé)任對(duì)象
*
* @param object $objsuccessor
*/
public function setSuccessor ($objsuccessor)
{
$this->successor = $objsuccessor;
}
}
/**
* 具體處理者角色
*
* @author wzy
*
*/
class ConcreateHandler extends Handle
{
/**
* 判斷是否有后繼的責(zé)任對(duì)象
* 如果有,就轉(zhuǎn)發(fā)請(qǐng)求給后繼的責(zé)任對(duì)象
* 如果沒(méi)有,則處理請(qǐng)求
*
* @see Handle::handleRequest()
*/
public function handleRequest ()
{
if ($this->getSuccessor() != null) {
echo "放過(guò)請(qǐng)求,將請(qǐng)求轉(zhuǎn)發(fā)給后繼的責(zé)任對(duì)象!<br>";
$this->getSuccessor()->handleRequest();
} else {
echo "處理請(qǐng)求,處理過(guò)程省略...<br>";
}
}
}
/**
* 客戶端代碼
*/
// 組裝責(zé)任鏈
$handle1 = new ConcreateHandler();
$handle2 = new ConcreateHandler();
$handle1->setSuccessor($handle2);
// 提交請(qǐng)求
$handle1->handleRequest();
?>
通過(guò)代碼可以看出,客戶端創(chuàng)建了兩個(gè)處理者對(duì)象,并指定第一個(gè)處理者對(duì)象的下家是第二個(gè)處理者對(duì)象,而第二個(gè)處理者對(duì)象卻沒(méi)有下家。然后客戶端將請(qǐng)求傳遞給第一個(gè)處理者對(duì)象
- php設(shè)計(jì)模式 Chain Of Responsibility (職責(zé)鏈模式)
- PHP設(shè)計(jì)模式之責(zé)任鏈模式的深入解析
- PHP實(shí)現(xiàn)基于狀態(tài)的責(zé)任鏈審批模式詳解
- PHP設(shè)計(jì)模式之觀察者模式(Observer)詳細(xì)介紹和代碼實(shí)例
- php設(shè)計(jì)模式 Proxy (代理模式)
- PHP常用的三種設(shè)計(jì)模式匯總
- php設(shè)計(jì)模式 Interpreter(解釋器模式)
- PHP經(jīng)典面試題之設(shè)計(jì)模式(經(jīng)常遇到)
- php設(shè)計(jì)模式之單例模式使用示例
- php 設(shè)計(jì)模式之 工廠模式
- php基礎(chǔ)設(shè)計(jì)模式大全(注冊(cè)樹模式、工廠模式、單列模式)
- php設(shè)計(jì)模式之職責(zé)鏈模式定義與用法經(jīng)典示例
PHP獲取網(wǎng)址的頂級(jí)域名函數(shù)代碼
基于PHP開(kāi)發(fā)中的安全防范知識(shí)詳解
PHP生成指定隨機(jī)字符串的簡(jiǎn)單實(shí)現(xiàn)方法
PHP正則表達(dá)式函數(shù)preg_replace用法實(shí)例分析
PHP實(shí)現(xiàn)RSA簽名生成訂單功能【支付寶示例】

