当前位置: 首页 > article >正文

13 责任链(Chain of Responsibility)模式

责任链模式

1.1 分类

(对象)行为型

1.2 提出问题

开发一款故障报修系统,不同的业务员处理的故障不同,如何确保客户的维修请求得到妥善的处理。

1.3 解决方案

使多个对象都有机会处理请求,从而避免请求的发送者和接受者之间的耦合关系。将这些对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它为止。

1.4 实现类图

在这里插入图片描述

  1. 处理者(Handler)声明了所有具体处理者的通用接口。
  2. 基础处理者(Base Handler)是一个可选的类,你可以将所有处理者共用的样本代码放置在其中。
  3. 具体处理者(Concrete Handlers)包含处理请求的实际代码。 每个处理者接收到请求后,都必须决定是否进行处理,以及是否沿着链传递请求。
  4. 客户端(Client)可根据程序逻辑一次性或者动态地生成链请求可发送给链上的任意一个处理者。

1.5 示例代码

#include <iostream>
#include <string>
#include <list>

//class Handler {
//public:
//    virtual Handler* setNext(Handler* handler) = 0;
//    virtual std::string handle(std::string request) = 0;
//};

class BaseHandler/*:public Handler*/{
private:
    BaseHandler* m_nextHandler;
public:
    BaseHandler* setNext(BaseHandler* handler) {
        m_nextHandler = handler;
        return m_nextHandler;
    }
    virtual std::string handle(std::string request) {
        if (m_nextHandler) {
            return m_nextHandler->handle(request);
        }
        return "";
    }
};

class RobotAI : public BaseHandler {
public:
    std::string handle(std::string request) override {
        if (request == "使用向导") {
            return "RobotAI:我来处理-" + request + "-。\n";
        } else {
            return BaseHandler::handle(request);
        }
    }
};
class TelOperator : public BaseHandler {
public:
    std::string handle(std::string request) override {
        if (request == "常见问题") {
            return "TelOperator:我来处理-" + request + "-。\n";
        } else {
            return BaseHandler::handle(request);
        }
    }
};
class Expert : public BaseHandler {
public:
    std::string handle(std::string request) override {
        if (request == "疑难杂症") {
            return "Expert:我来处理-" + request + "-。\n";
        } else {
            return BaseHandler::handle(request);
        }
    }
};

void clientCode(BaseHandler& handler) {
    std::list<std::string> problems = { "疑难杂症","常见问题","使用向导","常见问题","扯淡的问题" };
    for (const std::string& problem : problems) {
        std::string result = handler.handle(problem);
        std::cout << "Client:谁来处理" << problem<<":\n";
        if (result.empty()) {
            std::cout << "处理结果:" << "没人能够处理。\n";
        } else {
            std::cout << "处理结果:" << result;
        }
    }
}
int main()
{
    RobotAI robot;
    TelOperator telOperator;
    Expert expert;
    robot.setNext(&telOperator)->setNext(&expert);
    std::cout << "Chain:机器人AI->话务员->专家\n";
    clientCode(robot);

    //clientCode(telOperator);
}

1.6 举个栗子

责任链模式负责为活动的 GUI 元素显示上下文帮助信息。
在这里插入图片描述

1.7 总结

1.7.1 优点

  1. 你可以控制请求处理的顺序。
  2. 单一职责原则。你可对发起操作和执行操作的类进行解耦。
  3. 开闭原则。你可以在不更改现有代码的情况下在程序中新增处理者。

1.7.2 缺点

部分请求可能未被处理。


http://www.kler.cn/a/550462.html

相关文章:

  • 【医学影像AI】50个眼科影像数据集--1.分类任务
  • Julia语言的物联网
  • 电脑ip如何手动切换?多种方法详解‌
  • Floyd 算法 A * 算法
  • 什么是AJAX,AJAX的优缺点是什么?
  • 数据结构:顺序表(Sequence List)及其实现
  • 【音视频】RTSP拉流: RTP负载H264详解(四)
  • TCP/UDP协议与OSI七层模型的关系解析| HTTPS与HTTP安全性深度思考》
  • ping6 命令介绍和 IPv6 常见的网段划分
  • 算法——结合实例了解Minimax算法(极小化极大算法)
  • MYSQL中的性能调优方法
  • DeepSeek 为我赋能 Python 编程能力
  • Chrome多开终极形态解锁!「窗口管理工具+IP隔离插件
  • rv1103b编译opencv
  • 跨平台数字内容整合策略:提升全域用户体验的关键路径
  • 【在时光的棋局中修行——论股市投资的诗意哲学】
  • VSCode 接入DeepSeek V3大模型,附使用说明
  • Linux安全与密钥登录指南
  • 下载安装运行测试开源vision-language-action(VLA)模型OpenVLA
  • 计算机网络之路由算法的详细层次算法