使用者發起乙個請求,之後請求上鏈,如果當前處理者可以處理該請求,那麼就直接處理;否則當前處理者把請求**給下乙個處理者。一般來說,責任鏈有直線、環狀和樹型的,不過最常見的是直線型別的。使用者不用管具體的責任鏈的處理步驟,只需要把請求加入責任鏈即可,這樣請求的傳送者和請求的處理者就可以解耦了。
**描述為:
class
abstracthandler
protected
: abstractlearder* m_plearder;}
;class
concretehanlder
:public abstracthandler
else
if(有後繼者)
else}}
;
#include
#include
class
request
void
setdays
(int day)
std::string getname()
const
intgetday()
const
private
: std::string m_strname;
int m_idays ;}
;class
abstractlearder
protected
: abstractlearder* m_plearder
;// 下一級領導處理};
class
leader1
:public abstractlearder
else
if(m_plearder !=
nullptr
)else}}
;class
leader2
:public abstractlearder
else
if(m_plearder !=
nullptr
)else}}
;class
leader3
:public abstractlearder
else
if(m_plearder !=
nullptr
)else}}
;int
main()
輸出結果:
leader1: tom ok!
leader2: amy ok!
leader3: kim ok!
system can not handle this request
責任鏈模式
責任鏈模式 chain of responsibility 的目標是使多個物件都有機會處理請求,從而避免請求的傳送者和接收者之間的耦合關係。將這些物件連成一條鏈,並沿著這條鏈傳遞請求,直到有乙個物件處理它為止。舉個例子。你到銀行去辦理業務,只是簡單的存個錢,也許atm就解決你的問題。如果你是為了交費...
責任鏈模式
有3個request與3個handler,每個request由相應的handler來處理,當乙個handler與request不匹配時則傳遞給下乙個handler來處理 inte ce request class request1 implements request class request2 ...
責任鏈模式
了解了一下責任鏈模式,簡單的說下自己的理解吧 責任鏈就是說待處理的資料在request的時候,先經過filter1的處理,再經過filter2的處理,然後response時,先經過filter2的處理,在經過filter1的處理。實現思路是filterchain包括filter1和filter2,同...