引言
責(zé)任鏈模式是一種行為型設(shè)計模式,它通過一條由多個處理器組成的鏈來處理請求,每個處理器都有機會處理請求,如果一個處理器不能處理該請求,它會將請求傳遞給下一個處理器,直到請求被處理為止。
在實際應(yīng)用中,責(zé)任鏈模式常用于處理請求的分發(fā)、事件處理等場景,它的優(yōu)點在于可以動態(tài)地添加、刪除處理器,從而靈活地處理請求。
下面使用C#實現(xiàn)的簡單責(zé)任鏈模式的示例:
抽象處理器類
public abstract class Handler
{
protected Handler successor; //下一個處理器
public void SetSuccessor(Handler successor)
{
this.successor = successor;
}
public abstract void HandleRequest(int request);
}
處理器實現(xiàn)
//具體處理器類1
public class ConcreteHandler1 : Handler
{
public override void HandleRequest(int request)
{
if(request >= 0 && request < 10)
{
Console.WriteLine("{0} handled request {1}", this.GetType().Name, request);
}
else if(successor != null)
{
successor.HandleRequest(request);
}
}
}
//具體處理器類2
public class ConcreteHandler2 : Handler
{
public override void HandleRequest(int request)
{
if(request >= 10 && request < 20)
{
Console.WriteLine("{0} handled request {1}", this.GetType().Name, request);
}
else if(successor != null)
{
successor.HandleRequest(request);
}
}
}
//具體處理器類3
public class ConcreteHandler3 : Handler
{
public override void HandleRequest(int request)
{
if(request >= 20 && request < 30)
{
Console.WriteLine("{0} handled request {1}", this.GetType().Name, request);
}
else if(successor != null)
{
successor.HandleRequest(request);
}
}
}
客戶端調(diào)用
//客戶端程序
class Client
{
static void Main(string[] args)
{
//構(gòu)造處理器鏈
Handler h1 = new ConcreteHandler1();
Handler h2 = new ConcreteHandler2();
Handler h3 = new ConcreteHandler3();
h1.SetSuccessor(h2);
h2.SetSuccessor(h3);
//處理請求
int[] requests = { 2, 5, 14, 22, 18, 3, 27, 20 };
foreach (int request in requests)
{
h1.HandleRequest(request);
}
Console.ReadKey();
}
}
在這個示例中,我們定義了一個抽象處理器類Handler
和三個具體處理器類ConcreteHandler1
、ConcreteHandler2
和ConcreteHandler3
。在客戶端程序中,我們構(gòu)造了一個處理器鏈,將h1
的下一個處理器設(shè)置為h2
,將h2
的下一個處理器設(shè)置為h3
。然后我們循環(huán)處理請求數(shù)組中的每個請求,每個請求都從h1
開始處理。如果一個處理器能夠處理該請求,它就會處理該請求并結(jié)束;否則它會將請求傳遞給下一個處理器,直到請求被處理或者沒有更多的處理器為止。
結(jié)論
使用責(zé)任鏈模式的好處在于,我們可以隨時增加、刪除處理器,而不需要修改客戶端程序的代碼。文章來源:http://www.zghlxwxcb.cn/news/detail-548642.html
責(zé)任鏈模式也有一些缺點。例如,如果處理器鏈太長,會降低處理請求的效率;如果處理器之間的依賴關(guān)系不清楚,可能會導(dǎo)致處理器重復(fù)處理請求或者無法處理請求。因此,在使用責(zé)任鏈模式時需要慎重考慮,根據(jù)實際情況選擇合適的處理器鏈長度和處理器之間的依賴關(guān)系。文章來源地址http://www.zghlxwxcb.cn/news/detail-548642.html
到了這里,關(guān)于重溫設(shè)計模式 --- 責(zé)任鏈模式的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!