栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

c++职责链模式

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

c++职责链模式

1.对职责链的理解

  客户端发出一个请求时,有不同的对象都可以处理这个类型的请求,但是我们不知道最终哪个对象会处理它,于是用一个链路的方式传递这个请求,直到有能处理处理这个具体的请求。

2.职责链的好处

 避免了不同对象都要显示调用处理这个请求的方法,避免耦合性。只需要一个对象显示调用,它处理不了时会传递给它指向的下个对象。

c++实现简单的职责链
#include 
class Handler {

protected:
   Handler* successor;
public:
  Handler () {}
  ~Handler () {}
  void SetSuccessor(Handler* next_handler) {
    this->successor = next_handler;
  }

  virtual void HandleRequest(int request) = 0;

};

class Handler_A: public Handler {
public:
  void HandleRequest(int request) {
    if (request < 10) {
      std::cout<< "A handle 0-9"<HandleRequest(request);
    }
  }

};
class Handler_B: public Handler {
public:
  void HandleRequest(int request) {
    if (request < 20) {
      std::cout<< "B handle 10-19"<HandleRequest(request);
      }
    }
  }

};
int main (int argc, char* argv[]) {

Handler_A A;
Handler_B B;
A.SetSuccessor(&B);
B.SetSuccessor(0);
A.HandleRequest(16);
return 0;
}

输出结果:

B handle 10-19

在main.cc 里面指定职责链处理的顺序,还可以封装一个处理规则的类里面实现处理顺序

class HandlerWay {
public:
  HandlerWay(){
    A.SetSuccessor(&B);
    B.SetSuccessor(0);
  }
  ~HandlerWay(){}
  void handle (int request) {
    A.HandleRequest(request);
  }
private:
  Handler_A A;
  Handler_B B;

};
int main (int argc, char* argv[]) {
  HandlerWay way;
  way.handle(15);

return 0;
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/665865.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号