`
zxpjsj1984
  • 浏览: 1773 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
文章分类
社区版块
存档分类
最新评论

基于Java的责任链模式深入理解

阅读更多
一、引言

  初看责任链模式,心里不禁想起了一个以前听过的相声:看牙。说的是一个病人看牙的时候,医生不小心把拔下的一个牙掉进了病人嗓子里。病人因此楼上楼下的跑了好多科室,最后无果而终。

  责任链模式就是这种“推卸”责任的模式,你的问题在我这里能解决我就解决,不行就把你推给另一个对象。至于到底谁解决了这个问题了呢?我管呢!

  二、定义与结构

  从名字上大概也能猜出这个模式的大概模样——系统中将会存在多个有类似处理能力的对象。当一个请求触发后,请求将在这些对象组成的链条中传递,直到找到最合适的“责任”对象,并进行处理。

  《设计模式》中给它的定义如下:使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系。将这些对象连成一条链,并沿着这条链传递该请求,直到有一个对象处理它为止。

  从定义上可以看出,责任链模式的提出是为了“解耦”,以应变系统需求的变更和不明确性。

  下面是《设计模式》中给出的适用范围:

  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来管理的

 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来管理具体处理者角色的引入。当有了新的处理者需要添加的时候,仅仅需要修改下配置文件。

  五、其他

  责任链模式优点,上面已经体现出来了。无非就是降低了耦合、提高了灵活性。但是责任链模式可能会带来一些额外的性能损耗,因为它要从链子开头开始遍历。



分享到:
评论

相关推荐

    基于Java的设计模式实现.zip

    基于Java的设计模式实现 内容概要 本项目是一个基于Java的设计模式实现集合,涵盖了创建型、结构型和行为型设计模式。每个设计模式都通过具体的代码示例进行了详细讲解,确保代码在本地成功运行,并遵循Java编程...

    深入浅出设计模式C#Java版

    本资源"深入浅出设计模式C#Java版"是针对这两种主流编程语言介绍设计模式的经典著作,旨在帮助开发者理解和应用这些模式。 1. **单例模式**:确保一个类只有一个实例,并提供全局访问点。在C#中,可以使用`密封`和`...

    基于java的设计模式ppt

    行为型模式则关注对象间通信和职责分配,如观察者模式(Observer)、策略模式(Strategy)和责任链模式(Chain of Responsibility)。 在Java中,设计模式的实现通常依赖于其强大的面向对象特性,如封装、继承和...

    基于Java的设计模式示例项目.zip

    Java开发者希望通过实际代码示例深入理解设计模式的开发者。 软件架构师需要了解如何在实际项目中应用设计模式来提升代码的可维护性和可扩展性。 计算机科学学生正在学习设计模式,希望通过实际案例加深理解的...

    基于Java的设计模式理解与实现.zip

    设计模式是软件工程中的一种最佳实践,它是在特定...通过阅读“基于Java的设计模式理解与实现.pdf”这份资料,你可以深入了解每个模式的原理、应用场景以及如何在Java中实现它们,从而提高你的编程素养和项目设计能力。

    设计模式Java版

    在这个“设计模式Java版”资料中,我们将会探讨一系列基于Java的设计模式。 首先,我们要了解设计模式的三大类:创建型模式、结构型模式和行为型模式。创建型模式包括单例模式、工厂模式(简单工厂、工厂方法、抽象...

    基于java的电子通讯录系统(带文档)

    本文将深入探讨一个基于Java编程语言实现的电子通讯录系统,旨在帮助读者理解其工作原理、设计思路以及核心功能。 一、Java语言基础 Java是一种广泛应用于服务器端开发的面向对象的编程语言,具有跨平台、安全性高...

    基于Java的宠物管理系统

    【基于Java的宠物管理系统】是一个综合性的项目,它利用了Java技术栈,结合了SSM(Spring、SpringMVC、MyBatis)框架和Layui前端框架,以MySQL为后台数据库,MyEclipse作为开发环境。这个系统设计用于管理和维护宠物...

    基于C/S模式的Java聊天室

    【标题】"基于C/S模式的Java聊天室"是一个典型的网络通信项目,它采用客户机/服务器(Client/Server...开发者在实现这样一个系统时,不仅能深入理解Java核心技术,还能提升对网络通信、并发处理和软件架构设计的理解。

    基于Java C/S模式的简单学生管理系统

    【基于Java C/S模式的简单学生管理系统】是一个利用Java编程语言实现的客户端/服务器(Client/Server,C/S)架构的软件应用,主要用于演示学生信息的管理。由于它并未包含管理员功能,所以其功能可能相对基础,适用...

    易懂的基于java设计模式

    《易懂的基于Java设计模式》是一本专为Java初学者打造的设计...总之,《易懂的基于Java设计模式》是Java初学者掌握设计模式的绝佳资源,通过深入学习,开发者可以提高自己的编程技巧,为未来的软件开发奠定坚实基础。

    基于JAVA的全流程供应链系统源码(前后端分离).zip

    该资源是一个基于JAVA技术开发的全流程供应链管理系统源代码,实现了前后端分离的架构设计,适合进行毕业设计或者作为深入理解JAVA编程、Web开发以及供应链管理系统的实践案例。下面将详细介绍这个系统可能涉及的...

    基于JAVA办公自动化系统(OA)

    【基于JAVA办公自动化系统(OA)】是一种使用Java编程语言开发的企业级应用,主要用于提高办公效率,实现工作流程自动化。该系统集成了多种功能模块,旨在简化日常办公任务,提升组织内部的工作协同能力。 首先,...

    基于java的图书管理系统

    【基于Java的图书管理系统】是一种使用Java编程语言开发的软件应用程序,主要用于管理和组织图书馆的书籍信息,包括借阅、归还、查询等操作。这样的系统通常包含前后端交互、数据库设计以及用户界面等多个组成部分,...

    基于Java的考试管理系统源代码

    综上所述,基于Java的考试管理系统涵盖了多种技术和概念,从后端开发到前端展示,从数据库设计到权限控制,都需要深入理解和实践。开发者需具备扎实的Java基础,同时熟悉Web开发、数据库操作、安全性和测试等多方面...

    基于java语言开发的提醒簿程序源码

    理解这些类之间的关系和职责划分有助于深入理解OOP的核心思想。 3. **异常处理**:在处理用户输入或执行任务时,程序可能会遇到各种预期之外的情况。因此,异常处理机制(try-catch-finally)的应用是必不可少的,...

    基于Java语言的设计模式.zip

    "基于Java语言的设计模式.zip"这个压缩包很可能包含了一系列关于如何在Java环境中应用设计模式的教程或示例代码。 在Java中,设计模式大致可以分为三类:创建型、结构型和行为型。创建型模式如单例(Singleton)、...

    Java 设计模式最佳实践

    在Java中,有静态代理和动态代理两种方式,动态代理通常基于Java的反射机制实现。 八、适配器模式(Adapter) 适配器模式作为两个不兼容接口之间的桥梁,使得原本由于接口不兼容而不能一起工作的那些类可以一起工作...

    基于Java的MVC模式简单的新生报到系统.zip

    【标题】:“基于Java的MVC模式简单的新生报到系统” 这个项目是一个使用Java编程语言实现的简单新生报到系统,它遵循了Model-View-Controller(MVC)设计模式。MVC是一种软件架构模式,它将应用程序的业务逻辑、...

    基于Java +Swing的员工工资管理系统.rar

    通过这个项目,开发者不仅学习了Java和Swing的基本用法,还可能深入理解了数据库操作、业务逻辑处理、用户交互设计等多个方面的知识,这对于提升Java桌面应用开发技能大有裨益。对于初学者,这是一个很好的实践案例...

Global site tag (gtag.js) - Google Analytics