【C#设计模式(14)——责任链模式( Chain-of-responsibility Pattern)】

前言

责任链模式通过将请求和处理者解耦,关联多个处理者形成一个链条,使每个处理者都有机会处理请求,避免了将所有处理逻辑集中在一个对象中的复杂性。

代码

csharp 复制代码
//请求者
public class Requestor
{
    private string content;
    public string Content { get { return content; } }
    public Requestor(string content) 
    {
        this.content = content;
    }
}
//处理者
public abstract class Handler
{
    public abstract void SetNext(Handler handler);
    public abstract void HandleRequest(Requestor requestor);
}
//处理者:接收者A
public class ReceiverA : Handler
{
    private Handler nextHandler;
    public override void SetNext(Handler handler)
    {
        nextHandler = handler;
    }

    public override void HandleRequest(Requestor requestor)
    {
        if (requestor.Content.Equals("A")) 
        {
            Console.WriteLine("receiverA handle the request...");
        }
        else if(nextHandler!=null)
        {
            nextHandler.HandleRequest(requestor);
        }
    }
}
//处理者:接收者B
public class ReceiverB : Handler
{
    private Handler nextHandler;
    public override void HandleRequest(Requestor requestor)
    {
        if (requestor.Content.Equals("B"))
        {
            Console.WriteLine("receiverB hanlde the request...");
        }else if (nextHandler != null)
        {
            nextHandler.HandleRequest(requestor);
        }
    }
    public override void SetNext(Handler handler)
    {
        this.nextHandler = handler;
    }
}


/*
 * 行为型模式:Behavioral Pattern
 * 责任链模式: Chain-of-responsibility Pattern
 */
internal class Program
{
    static void Main(string[] args)
    {
        //创建接收请求
        Handler handlerA = new ReceiverA();
        Handler handlerB = new ReceiverB();

        //设置下一个请求处理者
        handlerA.SetNext(handlerB);

        //创建请求者A,并处理请求
        Requestor receiverA = new Requestor("A");
        handlerA.HandleRequest(receiverA);

        Requestor receiverB = new Requestor("B");
        handlerA.HandleRequest(receiverB);

        Requestor requestorC = new Requestor("C");
        handlerA.HandleRequest(requestorC);

        Requestor receiverA2 = new Requestor("A");
        handlerA.HandleRequest(receiverA2);

        Console.ReadLine();
    }
}

运行结果

相关推荐
唐宋元明清21885 小时前
.NET Win32磁盘动态卷/跨区卷触发“函数不正确”问题排查
windows·c#·存储
hez20105 小时前
Satori GC:同时做到高吞吐、低延时和低内存占用
c#·.net·.net core·gc·clr
刀法如飞14 小时前
AI时代,程序员都应该是算法思想工程师
人工智能·设计模式·程序员
在西安放羊的牛油果21 小时前
我把 2000 行下单代码,重构成了一套交易前端架构
前端·设计模式·架构
唐青枫1 天前
C#.NET Channel 深入解析:高性能异步生产者消费者模型实战
c#·.net
小峥降临2 天前
Rokid UXR 的手势追踪虚拟中更真实的手实战开发【含 工程源码 和 最终完成APK】
c#
寅时码2 天前
React 正在演变为一场不可逆的赛博瘟疫:AI 投毒、编译器迷信与装死的官方
前端·react.js·设计模式
willow5 天前
Axios由浅入深
设计模式·axios
晨星shine6 天前
GC、Dispose、Unmanaged Resource 和 Managed Resource
后端·c#