C++中的责任链模式

59 篇文章 0 订阅
52 篇文章 1 订阅

目录

责任链模式(Chain of Responsibility Pattern)

实际应用

日志记录器

技术支持系统

审批流程系统

总结


责任链模式(Chain of Responsibility Pattern)

责任链模式是一种行为设计模式,它允许多个对象有机会处理请求,从而避免请求的发送者与接收者之间的耦合。这些对象被连接成一条链,沿着这条链传递请求,直到有一个对象处理它为止。

实际应用

日志记录器

用责任链模式来创建一系列日志记录器,每个记录器处理特定级别的日志信息,并将其传递给下一个记录器。

#include <iostream>
#include <memory>

// 日志级别
enum LogLevel {
    INFO,
    WARNING,
    ERROR
};

// 抽象的日志处理器
class Logger {
protected:
    std::shared_ptr<Logger> next;
public:
    Logger() : next(nullptr) {}
    void setNext(std::shared_ptr<Logger> nextLogger) {
        next = nextLogger;
    }
    void logMessage(LogLevel level, const std::string& message) {
        if (this->canHandle(level)) {
            this->write(message);
        }
        if (next) {
            next->logMessage(level, message);
        }
    }
    virtual bool canHandle(LogLevel level) = 0;
    virtual void write(const std::string& message) = 0;
};

// 具体的日志处理器:信息日志处理器
class InfoLogger : public Logger {
public:
    bool canHandle(LogLevel level) override {
        return level == INFO;
    }
    void write(const std::string& message) override {
        std::cout << "InfoLogger: " << message << "\n";
    }
};

// 具体的日志处理器:警告日志处理器
class WarningLogger : public Logger {
public:
    bool canHandle(LogLevel level) override {
        return level == WARNING;
    }
    void write(const std::string& message) override {
        std::cout << "WarningLogger: " << message << "\n";
    }
};

// 具体的日志处理器:错误日志处理器
class ErrorLogger : public Logger {
public:
    bool canHandle(LogLevel level) override {
        return level == ERROR;
    }
    void write(const std::string& message) override {
        std::cout << "ErrorLogger: " << message << "\n";
    }
};

int main() {
    auto errorLogger = std::make_shared<ErrorLogger>();
    auto warningLogger = std::make_shared<WarningLogger>();
    auto infoLogger = std::make_shared<InfoLogger>();

    infoLogger->setNext(warningLogger);
    warningLogger->setNext(errorLogger);

    infoLogger->logMessage(INFO, "This is an information.");
    infoLogger->logMessage(WARNING, "This is a warning.");
    infoLogger->logMessage(ERROR, "This is an error.");

    return 0;
}

技术支持系统

用责任链模式来创建一系列处理器,每个处理器处理特定级别的客户请求,并将其传递给下一个处理器。

#include <iostream>
#include <memory>

// 请求级别
enum RequestLevel {
    GENERAL,
    TECHNICAL,
    ADVANCED_TECHNICAL
};

// 抽象的请求处理器
class SupportHandler {
protected:
    std::shared_ptr<SupportHandler> next;
public:
    SupportHandler() : next(nullptr) {}
    void setNext(std::shared_ptr<SupportHandler> nextHandler) {
        next = nextHandler;
    }
    void handleRequest(RequestLevel level, const std::string& request) {
        if (this->canHandle(level)) {
            this->process(request);
        } else if (next) {
            next->handleRequest(level, request);
        }
    }
    virtual bool canHandle(RequestLevel level) = 0;
    virtual void process(const std::string& request) = 0;
};

// 具体的请求处理器:一般请求处理器
class GeneralSupportHandler : public SupportHandler {
public:
    bool canHandle(RequestLevel level) override {
        return level == GENERAL;
    }
    void process(const std::string& request) override {
        std::cout << "GeneralSupportHandler: Processing " << request << "\n";
    }
};

// 具体的请求处理器:技术请求处理器
class TechnicalSupportHandler : public SupportHandler {
public:
    bool canHandle(RequestLevel level) override {
        return level == TECHNICAL;
    }
    void process(const std::string& request) override {
        std::cout << "TechnicalSupportHandler: Processing " << request << "\n";
    }
};

// 具体的请求处理器:高级技术请求处理器
class AdvancedTechnicalSupportHandler : public SupportHandler {
public:
    bool canHandle(RequestLevel level) override {
        return level == ADVANCED_TECHNICAL;
    }
    void process(const std::string& request) override {
        std::cout << "AdvancedTechnicalSupportHandler: Processing " << request << "\n";
    }
};

int main() {
    auto advancedHandler = std::make_shared<AdvancedTechnicalSupportHandler>();
    auto technicalHandler = std::make_shared<TechnicalSupportHandler>();
    auto generalHandler = std::make_shared<GeneralSupportHandler>();

    generalHandler->setNext(technicalHandler);
    technicalHandler->setNext(advancedHandler);

    generalHandler->handleRequest(GENERAL, "General Inquiry");
    generalHandler->handleRequest(TECHNICAL, "Technical Issue");
    generalHandler->handleRequest(ADVANCED_TECHNICAL, "Advanced Technical Problem");

    return 0;
}

审批流程系统

用责任链模式来创建一系列处理器,每个处理器处理特定级别的审批请求,并将其传递给下一个处理器。

#include <iostream>
#include <memory>

// 审批级别
enum ApprovalLevel {
    DEPARTMENT_MANAGER,
    GENERAL_MANAGER,
    BOARD
};

// 抽象的审批处理器
class Approver {
protected:
    std::shared_ptr<Approver> next;
public:
    Approver() : next(nullptr) {}
    void setNext(std::shared_ptr<Approver> nextApprover) {
        next = nextApprover;
    }
    void approveRequest(ApprovalLevel level, const std::string& request) {
        if (this->canApprove(level)) {
            this->approve(request);
        } else if (next) {
            next->approveRequest(level, request);
        }
    }
    virtual bool canApprove(ApprovalLevel level) = 0;
    virtual void approve(const std::string& request) = 0;
};

// 具体的审批处理器:部门经理
class DepartmentManager : public Approver {
public:
    bool canApprove(ApprovalLevel level) override {
        return level == DEPARTMENT_MANAGER;
    }
    void approve(const std::string& request) override {
        std::cout << "DepartmentManager: Approving " << request << "\n";
    }
};

// 具体的审批处理器:总经理
class GeneralManager : public Approver {
public:
    bool canApprove(ApprovalLevel level) override {
        return level == GENERAL_MANAGER;
    }
    void approve(const std::string& request) override {
        std::cout << "GeneralManager: Approving " << request << "\n";
    }
};

// 具体的审批处理器:董事会
class Board : public Approver {
public:
    bool canApprove(ApprovalLevel level) override {
        return level == BOARD;
    }
    void approve(const std::string& request) override {
        std::cout << "Board: Approving " << request << "\n";
    }
};

int main() {
    auto board = std::make_shared<Board>();
    auto generalManager = std::make_shared<GeneralManager>();
    auto departmentManager = std::make_shared<DepartmentManager>();

    departmentManager->setNext(generalManager);
    generalManager->setNext(board);

    departmentManager->approveRequest(DEPARTMENT_MANAGER, "Budget Approval");
    departmentManager->approveRequest(GENERAL_MANAGER, "Project Approval");
    departmentManager->approveRequest(BOARD, "Company Merger Approval");

    return 0;
}

总结

责任链模式在实际项目中可以帮助我们将请求的发送者与接收者解耦,并沿着处理器链传递请求,直到有一个处理器处理它。

  • 11
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
责任链设计模式是一种行为设计模式,它允许你将请求沿着处理者链进行传递,直到有一个处理者能够处理该请求。每个处理者都可以决定是否要处理该请求,或者将其传递给链的下一个处理者。 在责任链设计模式,有以下几个角色: 1. 抽象处理者(Handler):定义了处理请求的接口,并维护了对下一个处理者的引用。 2. 具体处理者(ConcreteHandler):实现了抽象处理者的接口,处理它所负责的请求,如果不能处理则将请求传递给下一个处理者。 责任链设计模式通常用于以下场景: - 当有多个对象可以处理同一个请求,但具体由哪个对象处理该请求在运行时才能确定。 - 当不希望请求的发送者和接收者之间耦合在一起,使得发送者不需要知道请求的处理者是谁。 代码示例: ```java // 抽象处理者 abstract class Handler { private Handler nextHandler; public void setNextHandler(Handler nextHandler) { this.nextHandler = nextHandler; } public void handleRequest(Request request) { if (canHandle(request)) { // 处理请求 System.out.println("处理请求:" + request); } else if (nextHandler != null) { // 传递给下一个处理者 nextHandler.handleRequest(request); } else { // 没有处理者能够处理该请求 System.out.println("无法处理请求:" + request); } } // 判断是否能够处理该请求的抽象方法 protected abstract boolean canHandle(Request request); } // 具体处理者A class ConcreteHandlerA extends Handler { @Override protected boolean canHandle(Request request) { // 判断是否能够处理该请求 return request.getType() == RequestType.TYPE_A; } } // 具体处理者B class ConcreteHandlerB extends Handler { @Override protected boolean canHandle(Request request) { // 判断是否能够处理该请求 return request.getType() == RequestType.TYPE_B; } } // 请求类 class Request { private RequestType type; public Request(RequestType type) { this.type = type; } public RequestType getType() { return type; } } // 请求类型枚举 enum RequestType { TYPE_A, TYPE_B } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

沉夢志昂丶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值