Chain of Responsibility职责链[通俗易懂]

Chain of Responsibility职责链[通俗易懂]职责链 Chain of Responsibility动机模式定义实例结构要点总结笔记动机在软件构建过程中,一个请求可能被多个对象处理.但是每个请求在运行时只能有一个请求者.如果显示指定.将必不可少地带来请求发送者与接收者地紧耦合如何使请求地发送者不需要指定具体地接收者?让请求地接收者自己在运行时决定来处理请求,从而使两者解耦模式定义使多个对象都有机会处理请求 从而避免请求地发送者和接收者之间地耦合关系.将这些对象形成一条链.并沿着这条链传递请求.直到有一个对象处理它为止实例#include&

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

职责链 Chain of Responsibility

动机

在软件构建过程中,一个请求可能被多个对象处理.但是每个请求在运行时只能有一个请求者.如果显示指定.将必不可少地带来请求发送者与接收者地紧耦合

如何使请求地发送者不需要指定具体地接收者?让请求地接收者自己在运行时决定来处理请求,从而使两者解耦

模式定义

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

实例

#include<bits/stdc++.h>
#include<string>

using namespace std;

enum class RequestType{ 
   
    REQ_HANDLER1,
    REQ_HANDLER2,
    REQ_HANDLER3
}
class Request{ 
   
    string description;
    RequestType reqType;
public:
    Request(const string&desc,Request type) : description(desc),reqType()
    RequestType getReqType()const { 
   return reqType;}

    const string& getDescription()const { 
   return description;}
}

class ChainHandler{ 
   
    ChainHandler *nextChain;
    void sendRequestToNextHandler(const Request &req){ 
   
        if(nextChain != nullptr){ 
   
            nextChain->handle(req);
        }
    }
protected:
    virtual bool canHandleRequest(const Request& req) = 0;
    virtual bool processRequest(const Request& req) = 0;
public:
    ChainHandler(){ 
   nextChain = nullptr;}
    void setNextChain(ChainHandler * next){ 
   nextChain = next;}
    
    void handle(const Request& req){ 
   
        if(canHandleRequest(req))
            processRequest(req);
        else
            sendRequestToNextHandler(req);
    }
}

class Handler1 : public ChainHandler{ 
   
protected:
    bool canHandlerRequest(const Request&req)override{ 
   
        return req.getReqType() == RequestType::REQ_HANDLER1;
    }
    void processRequest(const Request&req)override{ 
   
        cout << "Handler1 is handle request" << req.getDescription() << endl;
    }
};
class Handler2 : public ChainHandler{ 
   
protected:
    bool canHandlerRequest(const Request&req)override{ 
   
        return req.getReqType() == RequestType::REQ_HANDLER2;
    }
    void processRequest(const Request&req)override{ 
   
        cout << "Handler2 is handle request" << req.getDescription() << endl;
    }
};
class Handler3 : public ChainHandler{ 
   
protected:
    bool canHandlerRequest(const Request&req)override{ 
   
        return req.getReqType() == RequestType::REQ_HANDLER3;
    }
    void processRequest(const Request&req)override{ 
   
        cout << "Handler3 is handle request" << req.getDescription() << endl;
    }
};

int main(){ 
   
    Handler1 h1;
    Handler1 h2;
    Handler1 h3;
    h1.setNextChain(&h2);
    h2.setNextChain(&h3);
    Request req("process task ... ",RequestType::REQ_HANDLER3);
    h1.handle(req);
    return 0;
}

结构

在这里插入图片描述

要点总结

  • Chain of Responsibility模式地应用场合在于”一个请求可能会有多个接收者,但是最后真正地接收者只有一个”,这时候请求发送者与接收者地耦合有可能出现”变化脆弱”地症状,职责链地目的就是将二者解耦,从而更好地应对变化
  • 应用了Chain of Responsibility模式后.对象地指责分配将更具灵活性.我们可以在运行时动态添加/修改请求地处理职责
  • 如果请求传递到职责链地末尾仍得不到处理 应该有一个合理地缺省机制.这也是每一个接收对象的责任.而不是发出请求的对象的责任

笔记

  • Iterator和职责链模式用的不多了现在
  • 现在有的人觉得职责链模式不是一个设计模式
  • 请求者只需要关系把球踢给第一个接收者即可
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168498.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • ESCMScript6(3)Promise对象「建议收藏」

    ESCMScript6(3)Promise对象「建议收藏」1.Promise的含义Promise是异步编程的一种解决方案,比传统的解决方案——回调函数和事件——更合理和更强大。它由社区最早提出和实现,ES6将其写进了语言标准,统一了用法,原生提供了P

    2022年7月31日
    3
  • Modelsim-win32-6.6d 破解安装教程

    Modelsim-win32-6.6d 破解安装教程1、准备文件  modelsim-win32-6.6d-se.exe 2、安装步骤·(安装前把杀毒软件关闭)双击文件 modelsim-win32-6.6d-se.exe(注:安装路径不要有中文)点击Next 点击Browser ,建议安装目录改成自己新建在D盘下  点击Next—-&gt;Agree —–&gt;等待安装 安…

    2022年5月10日
    64
  • java遍历数组取出最大值_求数组20个数的平均值

    java遍历数组取出最大值_求数组20个数的平均值求平均值与最大值实现前需要懂得如何获取数组长度实现数组遍历例如:int[]array={2,3,6,8,18};for(inti=0;i<array.length;i++){System.out.print(array[i]+”,”);}输出结果:2,3,6,8,18求最大值时则采用擂台制现默认一个数为最大值(max)使用循环遍历数组中的每个数进行两两比较从而得出最大值。实现代码importjav

    2026年1月23日
    3
  • TechEd亲历图集

    TechEd亲历图集 矗立在主会场北门的巨大徽标。老杨的身高大约和中间的小写字母差不多。 整个会场到处彩旗飘飘。 现场的巨大的大会日程表(总共4张如图这么大的)贴满了一面墙。长长的主讲人名单里,大都是大家耳熟能详的技术高手。 现场的微软展台,虽然距离开会还有两个多小时,已经聚集了不少人 会前,会场旁边的交流社区成了参会新朋老友的聚集地,热闹非凡 te…

    2022年7月12日
    18
  • 1.2线性代数-行列式的性质

    行列式的性质:性质1:;行列式转置值不变对行成立的性质,对列也成立性质二:两行互换(两列互换),行列式的值要变号证明思路:若D中的每一项都和D1中的每一项差一个负号,那么D=-D13214是1234经过一次顺序变换得来的(1和3变换位置),1234为偶,3214肯定是奇原因:2,7,12,13列标的排法没变,只是行标变了。原来是1-2-3-4行,现在变成了3-2-1-4推论:两行或者两列对应相等,行列式值等于0若第一行和第三行互换,那么根据…

    2022年4月9日
    44
  • 常用坐标系简介(正在完善~)

    常用坐标系简介(正在完善~)

    2020年11月8日
    203

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号