博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
设计模式之职责链模式(行为型)
阅读量:2040 次
发布时间:2019-04-28

本文共 1664 字,大约阅读时间需要 5 分钟。

文章目录

一、行为型模式

介绍职责链模式之前先介绍一下行为型设计模式,因为按照GoF模式分类,职责链就是一种行为型设计模式。行为型设计模式就是主要表示类或者对象之间的关联关系,分为类行为型和对象行为型。类行为型一般都是通过类的继承或者多态等等方式实现。对象行为型就是通过对象的聚合等等关联实现。

二、职责链模式定义

职责链模式是一种对象行为型模式。根据“合成复用”原则,尽量使用关联来取代类继承,对象行为型可以说是一种不错的行为型模式。

职责链模式是一种将请求的发送者和请求处理者分离的一种模式。职责链可以是线型、环型或者树形的,不需要关系请求处理的细节,只要将请求沿着路径发送就好,做到了请求发送者和请求处理者解耦。

引用一下

Chain of Responsibility Pattern: Avoid coupling the sender of a request to its receiver by giving more than one object a chance to handle the request. Chain the receiving objects and pass the request along the chain until an object handles it.

翻译过来就是:

职责链模式:通过给予多个对象处理请求的机会,避免将请求的发送方与接收方耦合。将接收对象链接起来,并沿着链传递请求,直到对象处理它。

三、职责链模式角色

职责链模式包括下面几种角色:

  • Handler:抽象处理者
  • ConcreteHandler:具体处理者
  • Client:客户端

上面已经说了请求发送者和请求处理者,其实请求发送者就是客户端,请求处理者就是ConcreteHandler,也就是说,Client只是需要什么业务请求的就发送而已,完全可以对ConcreteHandler请求处理者改造,而不影响到Client,也就是前面所说的做到了请求发送者和请求处理者的解耦。

四、简单实例

例子参考:一书

抽象类:

public abstract class Handler{	protected Handler nextHandler;		public void setNextHandler(Handler nextHandler)	{		this.nextHandler=nextHandler;	}		public abstract void handleRequest(String request);}

具体实现者:

public class ConcreteHandler extends Handler{	public void handleRequest(String request)	{		if(请求request满足条件)		{			......  //处理请求;		}		else		{			this.nextHandler.handleRequest(request); //转发请求		}	}}

客户端调用:

public class Client{	public static void main(String args[])	{		Handler handler1 = new ConcreteHandler();		handler handler2 = new ConcreteHandler();		handler1.setNextHandler(handler2);		handler1.handleRequest("test");	}}

网上这个例子也写的还可以,可以参考学习

五、模式应用

在Java中的异常处理机制

try{    …… 			}catch(IOException e3){    ……}finally{    ……}

Mybatis Plugin 插件(拦截器)的应用,也是用动态代理和职责链模式进行设计和实现的:

可以看一下博客:

转载地址:http://fycof.baihongyu.com/

你可能感兴趣的文章
剑指offer 21.包含min函数的栈
查看>>
剑指offer 23.从上往下打印二叉树
查看>>
剑指offer 25.二叉树中和为某一值的路径
查看>>
剑指offer 26. 数组中出现次数超过一半的数字
查看>>
剑指offer 27.二叉树的深度
查看>>
剑指offer 29.字符串的排列
查看>>
剑指offer 31.最小的k个树
查看>>
剑指offer 32.整数中1出现的次数
查看>>
剑指offer 33.第一个只出现一次的字符
查看>>
剑指offer 34.把数组排成最小的数
查看>>
剑指offer 35.数组中只出现一次的数字
查看>>
剑指offer 36.数字在排序数组中出现的次数
查看>>
剑指offer 37.数组中重复的数字
查看>>
剑指offer 38.丑数
查看>>
剑指offer 39.构建乘积数组
查看>>
剑指offer 57. 删除链表中重复的结点
查看>>
剑指offer 58. 链表中环的入口结点
查看>>
剑指offer 59. 把字符串转换成整数
查看>>
剑指offer 60. 不用加减乘除做加法
查看>>
剑指offer 61. 求1+2+3+...+n
查看>>