LindDotNetCore~职责链模式的应用
职责链模式
它是一种设计模块,主要将操作流程与具体操作解耦,让每个操作都可以设置自己的操作流程,这对于工作流应用是一个不错的选择!
下面是官方标准的定义:责任链模式是一种设计模式。在责任链模式里,很多对象由每一个对象对其下家的引用而连接起来形成一条链。请求在这个链上传递,直到链上的某一个对象决定处理此请求。发出这个请求的客户端并不知道链上的哪一个对象最终处理这个请求,这使得系统可以在不影响客户端的情况下动态地重新组织和分配责任。
职责链模式组成
- 三大对象
- 命令处理
- 处理流程
- 命令上下文
- 命令只负责组织各个流程的次序,对流程实现细节没兴趣
- 具体流程只实现自己关注的代码,对下一个流程未知
在具体代码中的体现
抽象命令
public interface ICommand
{
void Execute(CommandParameters parameters);
}
抽象流程
/// <summary>
/// 工作流-抽象处理者
/// </summary>
public abstract class WorkFlow
{
protected WorkFlow Next; // 定义后继对象
protected object SharedObj; // 共享对象
// 设置后继者
public WorkFlow SetNext(WorkFlow next)
{
Next = next;
return next;
}
// 抽象请求处理方法
public virtual void ProcessRequest(CommandParameters command)
{
if (Next != null)
Next.ProcessRequest(command);
}
}
命令需要把参数传递给每个工作流程
public class CommandParameters
{
public string CommandType { get; set; }
public string JsonObj { get; set; }
public CommandParameters(string type, string jsonObj)
{
CommandType = type;
JsonObj = jsonObj;
}
}
下面看一个职责链模式里的具体命令和具体流程(步骤),每个步骤可以设置它下一步是什么
public class CommandInsert : ICommand
{
public void Execute(CommandParameters parameters)
{
WorkFlow workFlow = new WorkFlow_InsertLogger();
workFlow.SetNext(new WorkFlow_InsertAudit());
workFlow.ProcessRequest(parameters);
}
}
public class CommandUpdate : ICommand
{
public void Execute(CommandParameters parameters)
{
WorkFlow workFlow = new WorkFlow_InsertAudit();
workFlow.SetNext(new WorkFlow_InsertLogger());
workFlow.ProcessRequest(parameters);
}
}
public class WorkFlow_InsertLogger : WorkFlow
{
public override void ProcessRequest(CommandParameters command)
{
System.Console.WriteLine("WorkFlow1");
ProcessRequest(command);
}
}
public class WorkFlow_InsertAudit : WorkFlow
{
public override void ProcessRequest(CommandParameters command)
{
System.Console.WriteLine("WorkFlow2");
ProcessRequest(command);
}
}
public class ChainResponsibility
{
[Fact]
public void Test1()
{
var command = new CommandInsert();
command.Execute(new CommandParameters("test", "OK"));
}
[Fact]
public void Test2()
{
var command = new CommandUpdate();
command.Execute(new CommandParameters("test", "OK"));
}
}
待续……
回到目录
合集:
DotNetCore
, 设计模式
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· 【.NET】调用本地 Deepseek 模型
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
2013-01-10 将不确定变为确定~对象被new后什么时候会抛System.NullReferenceException
2013-01-10 EF架构~性能高效的批量操作(Update篇)