使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系。将这些对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它为止。
UML结构图:

抽象基类:
1)Handler:定义一个处理请求的接口,在图中这个接口就是HandleRequset函数,这个类同时有一个指向Handler对象的指针,指向后续的处理请求的对象(如果有的话)。
解析:
这个模式把可以处理一个请求的对象以链的形式连在了一起,让这些对象都有处理请求的机会。好比原来看古装电视中经常看到皇宫中召见某人的时候,太监们(可以处理一个请求的对象)就会依次的喊:传XX……这样一直下去直到找到这个人为止。ChainOfResponsibility模式也是这样的处理请求的,如果有后续的对象可以处理,那么传给后续的对象处理,否则就自己处理请求。这样的设计把请求的发送者和请求这种的处理者解耦了,好比发号的皇帝不知道到底是哪个太监最后会找到他要找到的人一般,只管发出命令就OK了。
实现:
1)ChainOfResponsibility.h
|
#ifndef CHAINOFRESPONSIBILITY_H #include <stdio.h> // 抽象基类,定义一个处理请求的接口 // 纯虚函数,由派生类实现 protected: class ConcreateHandler1 virtual void HandleRequset(); class ConcreateHandler2 virtual void HandleRequset(); #endif |
2)ChainOfResponsibility.cpp
|
#include "ChainOfResponsibility.h" Handler::Handler(Handler *pSuccessor /**//* = NULL*/) Handler::~Handler() void ConcreateHandler1::HandleRequset() void ConcreateHandler2::HandleRequset() |
3)Main.cpp
|
#include "ChainOfResponsibility.h" int main() p2->HandleRequset(); delete p2; system("pause"); return 0; |
本文详细介绍了链式责任模式的作用、UML结构图、关键实现步骤,并通过实例展示了如何使用该模式来处理请求,使得请求的发送者与接收者解耦,提高了系统的灵活性与可维护性。
335

被折叠的 条评论
为什么被折叠?



