Python设计模式-职责链模式
代码基于3.5.2,代码如下;
#coding:utf-8
#职责链模式
class Handler():
def __init__(self):
self.successor = None
def setSuccseeor(self,successor):
self.successor = successor
def handleRequest(self,request):
raise NotImplementedError
class ConcreteHandle1(Handler):
def handleRequest(self,request):
if request >=0 and request <10:
print("ConcreteHandle1 处理了 {0}".format(request))
else:
if self.successor != None:
self.successor.handleRequest(request)
else:
print("没有对应对象处理该请求")
class ConcreteHandle2(Handler):
def handleRequest(self,request):
if request >=10 and request <20:
print("ConcreteHandle2 处理了 {0}".format(request))
else:
if self.successor != None:
self.successor.handleRequest(request)
else:
print("没有对应对象处理该请求")
class ConcreteHandle3(Handler):
def handleRequest(self,request):
if request >=20 and request <30:
print("ConcreteHandle3 处理了 {0}".format(request))
else:
if self.successor != None:
self.successor.handleRequest(request)
else:
print("没有对应对象处理该请求")
if __name__ == "__main__":
c1 = ConcreteHandle1()
c2 = ConcreteHandle2()
c3 = ConcreteHandle3()
c2.setSuccseeor(c1)
c3.setSuccseeor(c2)
c3.handleRequest(8)
c3.handleRequest(12)
c3.handleRequest(24)
c3.handleRequest(50)
职责链模式分析与解读
职责链模式
职责链模式,使多个对象都有机会处理请求,从而避免请求的发送者和接受者之间的耦合关系。将这个对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它为止。
代码解读
1、先定义了Handler类,所以继承该类的类需要实现handleRequest方法,并且setSuccseeor方法为设置当当前对象无法处理该请求时,处理该请求的下一级对象;
2、定义了三个继承自Handler类的ConcreteHandle1,ConcreteHandle2和ConcreteHandle3,分别实现了handleRequest方法,通过判读输入request来判断是否可以处理该请求;
3、在客户端调用时,通过将实例c1,c2,c3,通过setSuccseeor方法来设置处理请求的上一级从而使得三个实例构成一条处理链,此时的入口实例便是c3,通过将请求出入c3的handleRequest方法,从而完成请求的传递。
代码运行结果如下:
”’
ConcreteHandle1 处理了 8
ConcreteHandle2 处理了 12
ConcreteHandle3 处理了 24
没有对应对象处理该请求
”’
职责链模式应用场景:
1、若一个请求可能由一个怼请求有链式优先级的处理群所处理时,可以考虑责任链模式。
优缺点分析
优点
1、将请求者与处理者分离,请求者并不知道请求是被哪个处理者所处理,易于扩展,降低了耦合度;
2、随时地增加或修改处理一个请求的结构,增强了给对象指派职责的灵活性。
缺点
1、如果责任链比较长,会有比较大的性能问题;在业务出问题时,难定位是哪个处理者的问题。