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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 手机号码归属地最新数据库2015年12月(附带采集更新程序)[通俗易懂]

    手机号码归属地最新数据库2015年12月(附带采集更新程序)[通俗易懂]手机号码归属地最新数据库2015年12月(附带采集更新程序)转:http://www.duanmu.org/log/mobile/昨天发现数据库的手机号归属地判断不准确,数据库该更新了,百度了下好像没有什么共享好的。以前是去淘宝上买的数据库,每次更新还得加钱,干脆自己做个算了,共享给大家。使用说明:1.单独号段的更新,请在手机号段里输入开始号

    2022年7月22日
    25
  • Gradle教程「建议收藏」

    Gradle教程「建议收藏」1.简介在本课程中,我们将学习Gradle,它是一个构建工具和一个依赖管理系统,与Maven和Ant非常相似,并且专门用于构建基于Java的项目。与Maven和Ant构建系统不同,Gradle不使用XML。它实际上是基于Groovy构建在DSL中的。与基于XML的其他构建系统相比,基于Groovy的Gradle脚本的最大优势是可以使构建脚本更小,更简洁。就像Maven构建文件…

    2022年6月28日
    33
  • failed to load response data:Request content was evicted from inspector cache

    failed to load response data:Request content was evicted from inspector cache在项目中,我用谷歌浏览器查看后台返回的json数据,但是发现前端页面已经接收成功,并且渲染了对应json数据了,但是network里面的response却报错:调整对应json数据后发现,当后台返回前端的数据超过了一定大小时,就会出现响应截断的问题,不过目前没有找到在哪里设置,我本地是大概超过10m就会截断。谷歌浏览器编辑设置是about:flags,但是我找不到对应设置response的选项。后来发现火狐浏览器可以设置报文响应大小的限制,先在url栏输入about:config,然后选择接受风险并

    2022年5月13日
    89
  • hdfs常用操作命令

    hdfs常用操作命令hdfs常用操作命令

    2022年4月23日
    40
  • PyTorch 学习笔记(九):自动编码器(AutoEncoder)「建议收藏」

    PyTorch 学习笔记(九):自动编码器(AutoEncoder)「建议收藏」一.生成模型生成模型(GenerativeModel)这一概念属于概率统计与机器学习,是指一系列用于随机生成可观测预测数据得模型。简而言之,就是“生成”的样本和“真实”的样本尽可能地相似。生成模型的两个主要功能就是学习一个概率分布Pmodel(X)P_{model}(X)Pmodel​(X)和生成数据,这是非常重要的,不仅可以用在无监督学习中,还可以用在监督学习中。无监督学习的发展…

    2022年6月10日
    55
  • MTK65XX平台充电调试总结

    MTK65XX平台充电调试总结

    2022年2月6日
    41

发表回复

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

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