- 浏览: 34908 次
- 性别:
- 来自: 上海
最新评论
转自:《深入浅出设计模式》
一、 引言
初看责任链模式,心里不禁想起了一个以前听过的相声:看牙。说一个病人看牙的时候,
医生不小心把拔下的一个牙掉进了病人嗓子里。各个科室的医生推卸责任,搞得病人因此楼
上楼下的跑了不少冤枉路,最后无果而终。
责任链模式就是这种“推卸”责任的模式,你的问题在我这里能解决我就解决,不行就把
你推给另一个对象。至于到底谁解决了这个问题了呢?我管呢!
二、 定义与结构
从名字上大概也能猜出这个模式的大概模样——系统中将会存在多个有类似处理能力
的对象。当一个请求触发后,请求将在这些对象组成的链条中传递,直到找到最合适的“责
任”对象,并进行处理。
《设计模式》中给它的定义如下:使多个对象都有机会处理请求,从而避免请求的发送
者和接收者之间的耦合关系。将这些对象连成一条链,并沿着这条链传递该请求,直到有一
个对象处理它为止。
呵呵,从定义上可以看出,责任链模式的提出是为了“解耦”,以应变系统需求的变更和
不明确性。
下面是《设计模式》中给出的适用范围:
1) 有多个的对象可以处理一个请求,哪个对象处理该请求运行时刻自动确定。
2) 你想在不明确指定接收者的情况下,向多个对象中的一个提交一个请求。
3) 可处理一个请求的对象集合应被动态指定。
责任链模式真的能给发送者和接收者之间解耦(这好像很神奇)吗?先来看下它的组成
角色。这个问题我会在下面提及。
责任链模式由两个角色组成:
1) 抽象处理者角色(Handler):它定义了一个处理请求的接口。当然对于链子的不同实现,
也可以在这个角色中实现后继链。
2) 具体处理者角色(Concrete Handler):实现抽象角色中定义的接口,并处理它所负责
的请求。如果不能处理则访问它的后继者。
至于类图不放也罢。毕竟就是一个继承或者实现。
三、 纯与不纯
责任链模式的纯与不纯的区别,就像黑猫、白猫的区别一样。不要刻意的去使自己的代
码来符合一个模式的公式。只要能够使代码降低耦合、提高重用,满足系统需求并能很好的
适应变化就好了。正所谓:管它黑猫白猫,抓住老鼠就是好猫!
纯的责任链模式,规定一个具体处理者角色只能对请求作出两种动作:自己处理;传给
下家。不能出现处理了一部分,把剩下的传给了下家的情况。而且请求在责任链中必须被处
理,而不能出现无果而终的结局。
反之,则就是不纯的责任链模式。
不纯的责任链模式还算是责任链模式吗?比如一个请求被捕获后,每个具体处理者都尝
试去处理它,不管结果如何都将请求再次转发。我认为这种方式的实现,算不算是责任链模
式的一种倒不重要,重要的是我们也能从中体味到责任链模式的思想:通过将多个处理者之
间建立联系,来达到请求与具体的某个处理者的解耦。
下面的例子就是采用了上面提到的“不纯的责任链模式”。
四、 举例
这个例子来源于项目中我刚刚完成的一个小功能点——“代号自动生成器”。在项目中存
在很多地方,比如:员工工号、档案代号,要求客户在使用时输入。而这些代号对于一个特
定的企业或者类别,往往有一定的规则。因此可以让用户在系统参数中维护一定的规则,然
后通过“代号自动生成器”来给用户生成代号。
根据初期需求,用户代号中往往存在以下几种变动元素:年份、月份、日期、流水号。
由于需求比较简单,因此考虑到用户可能存在其他变动元素,所以我打算在“被第一颗子弹
击中”后重构一下现有的结构。下面就是我在头脑中演绎过的使用责任链模式的重构。
这里只用来说明下责任链模式的结构和使用,因此不体现功能细节。
//这是抽象处理者角色
public interface CodeAutoParse {
//这里就是统一的处理请求使用的接口
String[] generateCode(String moduleCode, int number, String rule,String[] target)
throws BaseException;
}
//这个为处理日期使用的具体处理者
public class DateAutoParse implements CodeAutoParse{
//获取当前时间
private final Calendar currentDate = Calendar.getInstance();
//这里用来注入下一个处理者,系统中采用Spring Bean 管理
private CodeAutoParse theNextParseOfDate;
public void setTheNextParseOfDate(CodeAutoParse theNextParseOfDate){
this.theNextParseOfDate = theNextParseOfDate ;
}
/*
*实现的处理请求的接口
*这个接口首先判断用户定义的格式是否有流水号,有则解析,没有则跳过
*下传到下一个处理者
*/
public String[] generateCode(String moduleCode, int number, String rule, String[]
target)
throws BaseException {
//这里省略了处理的业务
……
if(theNextParseOfDate != null)
return theNextParseOfDate.generateCode(moduleCode , number , rule,
target)
else
return target;
}
其它具体处理者也是如此的结构,每一个里面都设置有一个用来存放下一个处理者的引
用,不管你有没有下一个处理者。
其实责任链模式本身的结构和使用都没有什么,就是一个继承或者实现。在处理请求的
时候,按照规定去调用下一个处理者。但是怎么来维护这样一条链子呢?
《设计模式》一书中仅仅说必须自己引入它,可以参考使用list 或者map 来进行注册。
而在上面我使用spring 来管理具体处理者角色的引入。当有了新的处理者需要添加的时候,
仅仅需要修改下配置文件。
五、 其他
责任链模式优点,上面已经体现出来了。无非就是降低了耦合、提高了灵活性。但是责
任链模式可能会带来一些额外的性能损耗,因为它每次执行请求都要从链子开头开始遍历。
一、 引言
初看责任链模式,心里不禁想起了一个以前听过的相声:看牙。说一个病人看牙的时候,
医生不小心把拔下的一个牙掉进了病人嗓子里。各个科室的医生推卸责任,搞得病人因此楼
上楼下的跑了不少冤枉路,最后无果而终。
责任链模式就是这种“推卸”责任的模式,你的问题在我这里能解决我就解决,不行就把
你推给另一个对象。至于到底谁解决了这个问题了呢?我管呢!
二、 定义与结构
从名字上大概也能猜出这个模式的大概模样——系统中将会存在多个有类似处理能力
的对象。当一个请求触发后,请求将在这些对象组成的链条中传递,直到找到最合适的“责
任”对象,并进行处理。
《设计模式》中给它的定义如下:使多个对象都有机会处理请求,从而避免请求的发送
者和接收者之间的耦合关系。将这些对象连成一条链,并沿着这条链传递该请求,直到有一
个对象处理它为止。
呵呵,从定义上可以看出,责任链模式的提出是为了“解耦”,以应变系统需求的变更和
不明确性。
下面是《设计模式》中给出的适用范围:
1) 有多个的对象可以处理一个请求,哪个对象处理该请求运行时刻自动确定。
2) 你想在不明确指定接收者的情况下,向多个对象中的一个提交一个请求。
3) 可处理一个请求的对象集合应被动态指定。
责任链模式真的能给发送者和接收者之间解耦(这好像很神奇)吗?先来看下它的组成
角色。这个问题我会在下面提及。
责任链模式由两个角色组成:
1) 抽象处理者角色(Handler):它定义了一个处理请求的接口。当然对于链子的不同实现,
也可以在这个角色中实现后继链。
2) 具体处理者角色(Concrete Handler):实现抽象角色中定义的接口,并处理它所负责
的请求。如果不能处理则访问它的后继者。
至于类图不放也罢。毕竟就是一个继承或者实现。
三、 纯与不纯
责任链模式的纯与不纯的区别,就像黑猫、白猫的区别一样。不要刻意的去使自己的代
码来符合一个模式的公式。只要能够使代码降低耦合、提高重用,满足系统需求并能很好的
适应变化就好了。正所谓:管它黑猫白猫,抓住老鼠就是好猫!
纯的责任链模式,规定一个具体处理者角色只能对请求作出两种动作:自己处理;传给
下家。不能出现处理了一部分,把剩下的传给了下家的情况。而且请求在责任链中必须被处
理,而不能出现无果而终的结局。
反之,则就是不纯的责任链模式。
不纯的责任链模式还算是责任链模式吗?比如一个请求被捕获后,每个具体处理者都尝
试去处理它,不管结果如何都将请求再次转发。我认为这种方式的实现,算不算是责任链模
式的一种倒不重要,重要的是我们也能从中体味到责任链模式的思想:通过将多个处理者之
间建立联系,来达到请求与具体的某个处理者的解耦。
下面的例子就是采用了上面提到的“不纯的责任链模式”。
四、 举例
这个例子来源于项目中我刚刚完成的一个小功能点——“代号自动生成器”。在项目中存
在很多地方,比如:员工工号、档案代号,要求客户在使用时输入。而这些代号对于一个特
定的企业或者类别,往往有一定的规则。因此可以让用户在系统参数中维护一定的规则,然
后通过“代号自动生成器”来给用户生成代号。
根据初期需求,用户代号中往往存在以下几种变动元素:年份、月份、日期、流水号。
由于需求比较简单,因此考虑到用户可能存在其他变动元素,所以我打算在“被第一颗子弹
击中”后重构一下现有的结构。下面就是我在头脑中演绎过的使用责任链模式的重构。
这里只用来说明下责任链模式的结构和使用,因此不体现功能细节。
//这是抽象处理者角色
public interface CodeAutoParse {
//这里就是统一的处理请求使用的接口
String[] generateCode(String moduleCode, int number, String rule,String[] target)
throws BaseException;
}
//这个为处理日期使用的具体处理者
public class DateAutoParse implements CodeAutoParse{
//获取当前时间
private final Calendar currentDate = Calendar.getInstance();
//这里用来注入下一个处理者,系统中采用Spring Bean 管理
private CodeAutoParse theNextParseOfDate;
public void setTheNextParseOfDate(CodeAutoParse theNextParseOfDate){
this.theNextParseOfDate = theNextParseOfDate ;
}
/*
*实现的处理请求的接口
*这个接口首先判断用户定义的格式是否有流水号,有则解析,没有则跳过
*下传到下一个处理者
*/
public String[] generateCode(String moduleCode, int number, String rule, String[]
target)
throws BaseException {
//这里省略了处理的业务
……
if(theNextParseOfDate != null)
return theNextParseOfDate.generateCode(moduleCode , number , rule,
target)
else
return target;
}
其它具体处理者也是如此的结构,每一个里面都设置有一个用来存放下一个处理者的引
用,不管你有没有下一个处理者。
其实责任链模式本身的结构和使用都没有什么,就是一个继承或者实现。在处理请求的
时候,按照规定去调用下一个处理者。但是怎么来维护这样一条链子呢?
《设计模式》一书中仅仅说必须自己引入它,可以参考使用list 或者map 来进行注册。
而在上面我使用spring 来管理具体处理者角色的引入。当有了新的处理者需要添加的时候,
仅仅需要修改下配置文件。
五、 其他
责任链模式优点,上面已经体现出来了。无非就是降低了耦合、提高了灵活性。但是责
任链模式可能会带来一些额外的性能损耗,因为它每次执行请求都要从链子开头开始遍历。
发表评论
-
模板方法模式
2013-06-27 10:28 426引用http://eneasy.iteye.com/blog/ ... -
状态模式
2013-06-26 16:38 549引用http://blog.csdn.net/hguisu/a ... -
策略模式
2013-06-24 18:28 576定义 策略模式(Strategy)属于对象行为型设计模式,主要 ... -
代理模式-动态代理
2013-06-20 16:37 495转自:http://www.cnblogs.com/jqyp/ ... -
观察者模式-JDK支持
2013-06-18 14:39 420JDK对观察者模式的支持主要是通过Observable类和Ob ... -
观察者模式
2013-06-18 13:31 375GoF说道:Observer模式的意图是“定义对象间的一种一对 ... -
备忘录模式
2013-06-14 15:45 391转载:http://blog.csdn.net/m136663 ... -
java 中介者模式
2013-06-07 16:19 594定义:用一个中介者对象封装一系列的对象交互,中介者使各对象不需 ... -
迭代器模式
2013-06-07 11:18 656定义:提供一种方法访 ... -
命令模式
2013-06-05 16:56 760定义 将一个请求封装为 ... -
代理模式
2013-05-27 11:07 433一、简介 代理模式有两 ... -
享元模式
2013-05-23 16:43 531一、引子 让我们先来复习下 java 中String 类型的特 ... -
门面模式
2013-05-21 15:28 426转自http://www.cnblogs.com/java-m ... -
装饰模式
2013-05-21 11:03 354动态地给一个对象添加一些额外的职责。就增加功能来说,Decor ... -
组合模式
2013-05-20 16:21 708一、引子 在大学的数据 ... -
桥接模式
2013-05-10 11:05 608认识桥接模式 (1)什么是桥接 在桥接模式里面 ... -
适配器模式
2013-05-08 14:04 6281. 概述 将一个类的接口转换成客户希望的另外一个接口 ... -
原型模式
2013-04-22 14:53 648转自:http://blog.csdn.net/zhengzh ... -
单态模式
2013-04-22 14:24 603保证一个类仅有一个实例,*提供一个访问它的全局访*点。 适 ... -
建造者模式
2013-04-18 10:27 636转自:http://www.2cto.com/kf/20120 ...
相关推荐
责任链模式是软件设计模式中的一种行为模式,它允许将请求沿着处理者对象的链进行传递,直到某个对象处理该请求。在Spring框架中,责任链模式被广泛应用于AOP(面向切面编程)和事件处理等场景。下面将详细阐述责任...
责任链模式是设计模式中的一种行为模式,它允许在对象之间建立一条处理请求的链条,每个对象都包含对请求的处理逻辑,以及将请求传递给下一个对象的能力。这种模式使得请求可以在链上的对象之间传递,直到被某个对象...
职责链模式(ChainOfResponsibilityPattern)是一种行为设计模式,主要目的是通过建立一个处理请求的对象链,使得请求可以在链上的各个对象间传递,直到被某个对象处理。这种模式可以有效地解耦请求发起者和处理者,...
责任链模式是一种设计模式,它允许我们把请求沿着处理者对象的链进行传递,直到某个对象处理这个请求。这种模式让请求的发送者和接收者解耦,因为发送者无需知道哪个对象会处理请求,而接收者也无需知道请求来自哪里...
职责链模式(Chain of Responsibility)是一种行为设计模式,它的核心思想是将一系列处理请求的对象组织成一条链,每个对象都包含对请求的处理或传递的责任。在C++中实现职责链模式,我们可以创建一个抽象处理器类,...
责任链模式是一种设计模式,它允许我们通过定义一系列处理请求的对象来形成一条链,每个对象都包含对请求的处理逻辑,以及将请求传递给链中下一个对象的能力。这种模式使得我们可以将请求的发送者和接收者解耦,使得...
责任链模式是一种行为设计模式,它允许我们把请求沿着处理者对象的链式结构进行传递,直到某个对象处理这个请求。这种模式使得我们能够将请求的发送者与接收者解耦,同时也允许在运行时动态地改变处理顺序或添加新的...
本篇将探讨两种重要的行为设计模式:责任链模式(Chain of Responsibility Pattern)和状态模式(State Pattern)。 **责任链模式**是一种使多个对象都有机会处理请求的模式,避免请求发送者与接收者之间的耦合。在...
职责链模式(Chain of Responsibility)是一种行为设计模式,它允许我们沿着对象链传递请求,让每个对象决定是否处理这个请求,或者将请求传递给链中的下一个对象。在C#中,我们可以利用类和接口来实现这种模式。让...
责任链模式是一种行为设计模式,它的核心思想是将请求的发送者和接收者解耦,通过将多个处理对象串联成一个处理链,使得请求沿着这个链进行传递,直到被某个对象处理。这种模式使得系统更加灵活,可以在运行时动态...
责任链模式是一种设计模式,它允许我们通过定义一系列处理请求的对象来解耦发送者和接收者。在责任链模式中,每个对象都是链上的一个节点,可以处理请求的一部分或者将请求传递给链上的下一个对象。这种模式使得系统...
【职责链模式】是行为型模式的一种,其主要动机是解耦请求的发送者和处理者。在职责链中,多个对象可以接收并处理同一个请求,这些对象形成一条链,请求沿着链传递,直到某个对象负责处理。这种方式减少了对象间的...
责任链模式是一种设计模式,它允许我们通过定义一系列处理对象(过滤器)形成一个链,这些对象依次处理请求,而发送者无需知道哪个对象具体处理请求。这种模式将请求的发送者与接收者解耦,增加了系统的灵活性和可...
责任链模式是一种行为设计模式,它允许将请求沿着处理者对象的链进行发送,而接收者可以在链中的任何位置处理该请求。这种模式的核心思想是将处理请求的对象组织成一个链条,每个对象(节点)都包含对下个处理者的...
责任链模式是一种行为设计模式,它允许我们定义一系列处理请求的对象,这些对象形成一个链,请求沿着这个链传递,直到某个对象能够处理它。这种方式使得我们可以将请求的发送者和接收者解耦,同时增加了系统扩展的...
一、责任链模式 现有 “战士”、“班长”、“排长”、“连长”,“营长”五种角色,当有人要请假时要进行以下处理 1.只能是下级象上级请假(如“排长”只能向“连长请假”) 2.班长可以批准1天内的假期,排长批5天,...
责任链模式(Chain of Responsibility)是一种行为设计模式,它允许将请求沿着处理者对象的链进行传递,直到某个对象能够处理这个请求为止。在Java中,我们可以通过接口和类的组合来实现这种模式。让我们深入探讨...
责任链模式(Chain of Responsibility Pattern)是设计模式中的一种行为模式,它的主要目的是将请求的发送者和接收者解耦,使得多个对象有机会处理这个请求,形成一条责任链。在这个链上,请求会沿着链传递,直到有...
责任链模式是一种设计模式,它允许我们通过定义一系列处理对象(每个对象称为一个节点),将请求在这些对象之间传递,直到被某个节点处理或者传递完整个链条。这种模式的主要优点在于解耦了发送者和接收者,使得系统...