- 浏览: 1336407 次
- 性别:
- 来自: 成都
文章分类
- 全部博客 (471)
- 原创文章 (4)
- Database (84)
- J2SE (63)
- Web (26)
- Javascript (30)
- Lucene (11)
- os (13)
- 算法 (8)
- Webservice (1)
- Open projects (18)
- Hibernate (18)
- Spring (15)
- Css (2)
- J2ee (2)
- 综合技术 (18)
- 安全管理 (13)
- PatternsInJava (27)
- NIO (5)
- Ibatis (2)
- 书籍收藏 (1)
- quartz (7)
- 并发编程 (15)
- oracle问题 (2)
- ios (60)
- coco2d-iphone (3)
- C++ (6)
- Zookeeper (2)
- golang (4)
- animation (2)
- android (1)
最新评论
-
dandingge123:
【引用】限制UITextField输入长度的方法 -
qja:
...
对List顺序,逆序,随机排列实例代码 -
安静听歌:
现在在搞这个,,,,,哎~头都大了,,,又freemarker ...
通用大型网站页面静态化解决方案(一) -
springdata-jpa:
java quartz定时任务demo教程源代码下载,地址:h ...
Quartz 配置参考 -
马清天:
[b][/b][list][*]引用[u][/u][/list ...
通用大型网站页面静态化解决方案(一)
其实Chain of Responsibility的概念,即使是一个刚学程式设计的新手也会用到,一个简单的 if...else if ... else 流程控制就有Chain of Responsibility的概念:
// 执行请求一
else if(/* 符合请求条件二 */)
// 执行请求二
else
// 执行预设请求或显示讯息
这是从结构化程式设计的观点来看Chain of Responsibility的概念,若使用物件的观点来看Chain of Responsibility的话,有一个较佳的例子就是Java的例外处理机制,当程式中发生例外时,也比会catch所捕捉的例外是否符合,如果符合就执行所设定的处理,如果都没有比对到适当的例外物件,就会将例外丢出try...catch区块之外。
在 Gof 的书 中给定Chain of Responsibility目的为:使多个物件都有机会处理请求,以避免请求的发送者与接收者之间的耦合关系,将这些物件组合为一个链,并沿着这个链传递该请求,直到有物件处理它为止。
先用一个例子来说明使用if...else的方式来处理请求:
- IHandler.java
public interface IHandler { public void handle(); }
- SymbolHandler.java
public class SymbolHandler implements IHandler { public void handle() { System.out.println("Symbol has been handled"); } }
- CharacterHandler.java
public class CharacterHandler implements IHandler { public void handle() { System.out.println("Character has been handled"); } }
- NumberHandler.java
public class NumberHandler implements IHandler { public void handle() { System.out.println("Number has been handled"); } }
- Application.java
import java.io.*; public class Application { public void run() throws Exception { System.out.print("Press any key then return: "); char c = (char) System.in.read(); IHandler handler = null; if (Character.isLetter(c)) { handler = new CharacterHandler(); } else if (Character.isDigit(c)) { handler = new NumberHandler(); } else { handler = new SymbolHandler(); } handler.handle(); } public static void main(String[] args) throws IOException { Application app = new Application(); app.run(); } }
这是一个很简单的程式,可以判定您所输入的是数字、字元或是符号,如果将之以物件的方式来组织物件之间的职责,可以将程式改写如下:
- Handler.java
public class Handler { private Handler successor; public void setSuccessor(Handler successor) { this.successor = successor; } public Handler getSuccessor() { return successor; } public void handleRequest(char c) { if(successor != null) successor.handleRequest(c); } }
- NumberHandler.java
public class NumberHandler extends Handler { public void handleRequest(char c) { if(Character.isDigit(c)) { System.out.println("Number has been handled"); } else { getSuccessor().handleRequest(c); } } }
- CharacterHandler.java
public class CharacterHandler extends Handler { public void handleRequest(char c) { if(Character.isLetter(c)) { System.out.println("Character has been handled"); } else { getSuccessor().handleRequest(c); } } }
- SymbolHandler.java
public class SymbolHandler extends Handler { public void handleRequest(char c) { System.out.println("Symbol has been handled"); } }
- Application.java
import java.io.*; public class Application { public static void main(String[] args) throws IOException { Handler numberHandler = new NumberHandler(); Handler characterHandler = new CharacterHandler(); Handler symbolHandler = new SymbolHandler(); numberHandler.setSuccessor(characterHandler); characterHandler.setSuccessor(symbolHandler); System.out.print("Press any key then return: "); char c = (char)System.in.read(); numberHandler.handleRequest(c); } }
在组织物件之间的职责时,通常是从细粒度至粗粒度的方式来组织,从特殊到抽象化,就像程式中将数字视为字元的特殊化,字元又为符号的特殊化。
以上所举的例子在请求上是很简单的,只是比对输入的型态,在更一般的情况下,可以将请求包装为一个物件,并提供getType()之间的方法,以让 Chain of Responsibility中的物件进行比对,例如:
- Request.java
public class Request{ private String type; public Request(String type) { this.type=type; } public String getType() { return type; } public void execute(){ // 执行请求 } }
在Gof的书中所举的例子为辅助说明系统,在一个介面中希望使用者一定可以得到相关的说明主题,如果子元件有说明的话,就显示相关说明,否则的话就转发给包括它的容器元件或父元件,以保证使用者的辅助说明请求一定可以得到回应。
例子--2
1.要处理的对象
package com.ijo.chain.of.responsibility;
public class Trouble {
private char ch;
public char getCh() {
return ch;
}
public void setCh(char ch) {
this.ch = ch;
}
public Trouble(char ch) {
this.ch = ch;
}
}
进行处理请求的抽象父类
package com.ijo.chain.of.responsibility;
public abstract class Support {
private Support support;
public Support addNext(Support support) {
this.support = support;
return support;
}
public void support(Trouble trouble) {
if (resolve(trouble)) {
done(trouble);
} else if (support != null) {
support.support(trouble);
} else {
fail(trouble);
}
}
private void fail(Trouble trouble) {
System.out.println(" fail " + trouble.getCh());
}
private void done(Trouble trouble) {
System.out.println(" doing " + trouble.getCh());
}
protected abstract boolean resolve(Trouble trouble);
}
实现处理请求的子类,字符
package com.ijo.chain.of.responsibility;
public class CharacterSupport extends Support {
@Override
protected boolean resolve(Trouble trouble) {
if (Character.isLetter(trouble.getCh())) {
return true;
}
return false;
}
}
实现处理请求的子类,数字
package com.ijo.chain.of.responsibility;
public class NumberSupport extends Support {
@Override
protected boolean resolve(Trouble trouble) {
if (Character.isDigit(trouble.getCh())) {
return true;
}
return false;
}
}
实现处理请求的子类,符号
package com.ijo.chain.of.responsibility;
public class SymbolSupport extends Support {
@SuppressWarnings("deprecation")
@Override
protected boolean resolve(Trouble trouble) {
if (Character.isSpace(trouble.getCh())) {
return true;
}
return false;
}
}
测试类
package com.ijo.chain.of.responsibility;
public class Main {
/**
* @param args
*/
public static void main(String[] args) {
Support symbol = new SymbolSupport();
Support number = new NumberSupport();
Support charactor = new CharacterSupport();
symbol.addNext(number).addNext(charactor);
// 第二个和最后一个都是空格字符
char[] chs = { 'a', ' ', 'b', '*', '2', '^', 'b', ' ' };
for (char c : chs) {
symbol.support(new Trouble(c));
}
}
}
结果
doing a
doing
doing b
fail *
doing 2
fail ^
doing b
doing
发表评论
-
Java 事件传送技术
2010-12-20 14:16 1485developerWorks 中国 ... -
Design Pattern: Mediator 模式
2010-11-13 23:31 1239Mediator的意思是中介者、调节者、传递物,顾名思义,这个 ... -
Design Pattern: Command 模式
2010-11-13 23:30 1098如果您写过Java的Swing视窗程式,您可能使用过Comma ... -
Design Pattern: Strategy 模式
2010-11-13 23:25 1285考虑您要设计一个更换各种符号的工具类TextCharChang ... -
Design Pattern: State 模式
2010-11-13 23:22 1043如果您不了解TCP的连线方式,在看 Gof 的书介绍State ... -
Design Pattern: Read-Write-Lock 模式
2010-11-10 23:58 1174如果有一个资料档有可能同时间会有许多客户端对它进行读取与写入的 ... -
Design Pattern: Producer Consumer 模式
2010-11-10 23:52 1310Producer Consumer模式与 Guar ... -
Design Pattern: Guarded Suspension 模式
2010-11-10 23:48 1131考虑这么一个伺服器,它可以处理来自多个客户端的服务请求(Req ... -
Design Pattern: Observer 模式
2010-11-10 23:33 1035Java深入到一定程度,就不可避免的碰到设计模式(design ... -
Design Pattern: Iterator 模式
2010-11-10 23:22 1085这个模式已经被整合入Java的Collection.在大多数场 ... -
Design Pattern: Interpreter 模式
2010-11-10 23:17 1268对于一个具有层次节点关系的问题来说,如果您要剖析每一个节点,您 ... -
Design Pattern: Command 模式
2010-11-10 23:08 1344Command定义n 将来自客户端的请求传入一个对象,无需了解 ... -
Design Pattern: Proxy 模式
2010-11-10 22:51 1593来看看实现代理的两种方式:Static Proxy与Dynam ... -
Design Pattern: Flyweight 模式
2010-11-10 22:48 1401Flyweight(享元)模式定义:避免大量拥有相同内容的小类 ... -
Design Pattern: Facade 模式
2010-11-10 22:42 1305Facade模式的定义: 为子系统中的一组接口提供一个一致的界 ... -
Design Pattern: Decorator 模式
2010-11-10 22:35 1342装饰模式:Decorator常被翻译成"装饰&quo ... -
Design Pattern: Bridge 模式
2010-11-10 22:24 1149Bridge模式定义 :将抽象 ... -
Design Pattern: Default Adapter 模式(二)
2010-11-10 22:16 1522适配器模式定义:将两个 ... -
Design Pattern: Default Adapter 模式
2010-11-10 22:07 1117在Java中如果要定义事件 ... -
Design Pattern: Singleton 模式
2010-11-10 22:06 1042Singleton的英文意义是独身,也就是只有一个人,应用在物 ...
相关推荐
★附录A介绍了剩下的设计模式:Bridge(桥接)、Builder(生成器)、Chainof Responsibility(责任链)、Flyweight(蝇量)、Interpreter(解释器)、Mediator(中介者)、Memento(备忘录)、Prototype(原型)、...
- 责任链模式(Chain of Responsibility):避免将处理请求的对象耦合到发送者。 - 命令模式(Command):将请求封装为一个对象,以便使用不同的请求、队列请求或者参数化不同请求。 - 解释器模式(Interpreter)...
责任链模式(Chain of Responsibility) 命令模式(Command) 解释器模式(Interpreter) 迭代器模式(Iterator) 中介者模式(Mediator) 备忘录模式(Memento) 观察者模式(Observer) 状态模式(State) 策略模式(Strategy) 模板...
- 责任链模式(Chain of Responsibility):将请求沿着处理者链传递,直到某个处理者处理它。 - 命令模式(Command):将请求封装为一个对象,以便使用不同的请求、队列请求、支持撤销操作。 - 解释器模式...
行为型模式涉及到对象间如何交互,如策略(Strategy)、观察者(Observer)和责任链(Chain of Responsibility)。 .NET Framework 4.5 是微软的一个强大的开发平台,支持多种编程语言,并提供了大量的类库和服务,...
- **责任链模式(Chain of Responsibility)**:避免将处理逻辑硬编码,而是将请求沿着处理者链传递,直到某个处理者处理它。 - **命令模式(Command)**:将请求封装为一个对象,以便使用不同的请求、队列请求或...
行为型模式则涉及对象间交互和职责分配,如观察者(Observer)、责任链(Chain of Responsibility)和策略(Strategy)模式。 在Java中,每个设计模式都有其独特的应用场景和优点。例如,单例模式确保一个类只有一...
- 责任链模式(Chain of Responsibility):避免将请求的发送者和接收者耦合在一起,将多个处理者对象链接在一起形成链。 - 命令模式(Command):将请求封装为一个对象,以便使用不同的请求、队列请求、支持撤销...
行为型模式则涉及对象之间的通信和职责分配,如策略(Strategy)、观察者(Observer)和责任链(Chain of Responsibility)。 让我们深入探讨几个常见的设计模式: 1. **单例模式**:保证一个类只有一个实例,并...
- 责任链模式(Chain of Responsibility):避免对象之间的耦合,将请求沿着处理者链传递,直到某个对象处理它。 - 命令模式(Command):将请求封装为一个对象,以便使用不同的请求、队列请求或记录请求日志。 -...
行为型模式则关注对象之间的交互和责任分配,比如策略模式(Strategy)、观察者模式(Observer)和责任链模式(Chain of Responsibility)。 2015年7月7日的这个项目,可能涵盖了从2015年至今的设计模式学习和研究...
- **职责链模式(Chain of Responsibility)**:将请求沿着处理者链进行传递,直到有处理者处理该请求为止。 - **命令模式(Command)**:将请求封装为一个对象,以便使用不同的请求、队列或者日志请求,以及支持...
例如策略模式(Strategy)、模板方法模式(Template Method)、观察者模式(Observer)、命令模式(Command)、迭代器模式(Iterator)、访问者...职责链模式(Chain of Responsibility)和解释器模式(Interpreter)...
Chapter 20: Chain of Responsibility Patterns Chapter 21: Composite Patterns Chapter 22: Bridge Patterns (Or Handle/Body Patterns) Chapter 23: Visitor Patterns Chapter 24: Interpreter Patterns
**行为型模式**着重于对象间的责任分配和交互,如命令模式(Command)、责任链模式(Chain of Responsibility)、解释器模式(Interpreter)、迭代器模式(Iterator)、备忘录模式(Memento)、观察者模式(Observer...
- **责任链模式(Chain of Responsibility)**:将请求沿着处理者链进行传递,直到有处理者处理为止。 - **命令模式(Command)**:将请求封装为一个对象,以便使用不同的请求、队列请求或参数化不同请求。 - **...
13. **责任链模式(Chain of Responsibility)**:避免将请求的发送者和接收者耦合在一起,让多个对象都有可能处理这个请求。 14. **解释器模式(Interpreter)**:给定一种语言,定义其文法表示,并提供一个解释器...
3. 行为型模式:这类模式定义了对象之间的通信和责任分配,包括策略模式(Strategy)、模板方法模式(Template Method)、观察者模式(Observer)、迭代器模式(Iterator)、责任链模式(Chain of Responsibility)...