C++设计模式 -- 责任链模式 CRP

本文通过一个具体的案例,详细解析了职责链模式在处理权限审批流程中的应用。通过定义一个对象链来传递请求,使得多个处理者能够处理同一请求,每个处理者负责检查其职权范围内的请求,并将未处理的请求传递给链上的下一个处理者。这种方式减少了对象之间的耦合,提高了系统的灵活性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

// 抽象管理者
class Manager {
protected:
    Manager *m_manager;
    string m_name;

public:
    Manager(Manager *manager, string name) : m_manager(manager), m_name(name) {}
    virtual void DealWithRequest(string name, int num) {}
};
// 经理
class CommonManager : public Manager {
public:
    CommonManager(Manager *manager, string name) : Manager(manager, name) {}
    void DealWithRequest(string name, int num)
    {
        if (num < 500) { // 经理职权之内
            cout << "经理" << m_name << "批准" << name << "加薪" << num << "元" << endl << endl;
        } else {
            cout << "经理" << m_name << "无法处理,交由总监处理" << endl;
            m_manager->DealWithRequest(name, num);
        }
    }
};
// 总监
class Majordomo : public Manager {
public:
    Majordomo(Manager *manager, string name) : Manager(manager, name) {}
    void DealWithRequest(string name, int num)
    {
        if (num < 1000) { // 总监职权之内
            cout << "总监" << m_name << "批准" << name << "加薪" << num << "元" << endl << endl;
        } else {
            cout << "总监" << m_name << "无法处理,交由总经理处理" << endl;
            m_manager->DealWithRequest(name, num);
        }
    }
};
// 总经理
class GeneralManager : public Manager {
public:
    GeneralManager(Manager *manager, string name) : Manager(manager, name) {}
    void DealWithRequest(string name, int num) // 总经理可以处理所有请求
    {
        cout << "总经理" << m_name << "批准" << name << "加薪" << num << "元" << endl << endl;
    }
};

// 测试案例
int main()
{
    Manager *general = new GeneralManager(NULL, "A");    // 设置上级,总经理没有上级
    Manager *majordomo = new Majordomo(general, "B");    // 设置上级
    Manager *common = new CommonManager(majordomo, "C"); // 设置上级
    common->DealWithRequest("D", 300);                   // 员工D要求加薪
    common->DealWithRequest("E", 600);
    common->DealWithRequest("F", 1000);
    delete common;
    delete majordomo;
    delete general;
    return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值