簡(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)求和處理分開。請(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è)示意方法是沒有傳入?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ì)象 * 如果沒有,則處理請(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ì)象卻沒有下家。然后客戶端將請(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生成指定隨機(jī)字符串的簡(jiǎn)單實(shí)現(xiàn)方法

PHP正則表達(dá)式函數(shù)preg_replace用法實(shí)例分析

PHP實(shí)現(xiàn)RSA簽名生成訂單功能【支付寶示例】