- 浏览: 301615 次
- 性别:
- 来自: 成都
文章分类
最新评论
-
tacyuuhon:
这个代码就有问题。当前的 int activeSessions ...
HttpSessionListener统计在线人数 -
yangleilt:
唉。。能通俗的说一下不?你说的这些百科上到处都是的!
LDAP是什么? -
hezhou_0521:
你显示正确了吗?
HttpSessionListener统计在线人数 -
sevk:
我喜欢用vim或gvim,比Ultra Edit 顺手
让Ultra Edit和Keil结合的更紧密
Chain of Responsibility定義
Chain of Responsibility(CoR) 是用一系列類別(classes)試圖處理一個請求request,這些類別之間是一個鬆散的耦合,唯一共同點是在他們之間傳遞request。 也就是說,來了一個請求,A類別先處理,如果沒有處理,就傳遞到B類別處理,如果沒有處理,就傳遞到C類別處理,就這樣象一個鏈條(chain)一樣傳遞下去。
如何使用?
雖然這一段是如何使用CoR,但是也是演示什麽是CoR。
有一個Handler介面:
public interface Handler{
public void handleRequest();
}
這是一個處理request的事例, 如果有多種request,比如 請求幫助 請求列印 或請求格式化:
最先想到的解決方案是:在介面中增加多個請求:
public interface Handler{
public void handleHelp();
public void handlePrint();
public void handleFormat();
}
具體是一段實現介面Handler代碼:
public class ConcreteHandler implements Handler{
private Handler successor;
public ConcreteHandler(Handler successor){
this.successor=successor;
}
public void handleHelp(){
//具體處理請求Help的代碼
...
}
public void handlePrint(){
//如果是print 轉去處理Print
successor.handlePrint();
}
public void handleFormat(){
//如果是Format 轉去處理format
successor.handleFormat();
}
}
一共有三個這樣的具體實現類別,上面是處理help,還有處理Print 處理Format這大概是我們最常用的編程思路。
雖然思路簡單明瞭,但是有一個擴展問題,如果我們需要再增加一個請求request種類,需要修改介面及其每一個實現。
第二方案:將每種request都變成一個介面,因此我們有以下代碼 :
public interface HelpHandler{
public void handleHelp();
}
public interface PrintHandler{
public void handlePrint();
}
public interface FormatHandler{
public void handleFormat();
}
public class ConcreteHandler
implements HelpHandler,PrintHandler,FormatHandlet{
private HelpHandler helpSuccessor;
private PrintHandler printSuccessor;
private FormatHandler formatSuccessor;
public ConcreteHandler(HelpHandler helpSuccessor,PrintHandler printSuccessor,FormatHandler formatSuccessor)
{
this.helpSuccessor=helpSuccessor;
this.printSuccessor=printSuccessor;
this.formatSuccessor=formatSuccessor;
}
public void handleHelp(){
.......
}
public void handlePrint(){this.printSuccessor=printSuccessor;}
public void handleFormat(){this.formatSuccessor=formatSuccessor;}
}
這個辦法在增加新的請求request情況下,只是節省了介面的修改量,介面實現ConcreteHandler還需要修改。而且代碼顯然不簡單美麗。
解決方案3: 在Handler介面中只使用一個參數化方法:
public interface Handler{
public void handleRequest(String request);
}
那麽Handler實現代碼如下:
public class ConcreteHandler implements Handler{
private Handler successor;
public ConcreteHandler(Handler successor){
this.successor=successor;
}
public void handleRequest(String request){
if (request.equals("Help")){
//這裏是處理Help的具體代碼
}else
//傳遞到下一個
successor.handle(request);
}
}
}
這裏先假設request是String類型,如果不是怎麽辦?當然我們可以創建一個專門類別Request
最後解決方案:介面Handler的代碼如下:
public interface Handler{
public void handleRequest(Request request);
}
Request類別的定義:
public class Request{
private String type;
public Request(String type){this.type=type;}
public String getType(){return type;}
public void execute(){
//request真正具體行爲代碼
}
}
那麽Handler實現代碼如下:
public class ConcreteHandler implements Handler{
private Handler successor;
public ConcreteHandler(Handler successor){
this.successor=successor;
}
public void handleRequest(Request request){
if (request instanceof HelpRequest){
//這裏是處理Help的具體代碼
}else if (request instanceof PrintRequst){
request.execute();
}else
//傳遞到下一個
successor.handle(request);
}
}
}
這個解決方案就是CoR, 在一個鏈上,都有相應職責的類別,因此叫Chain of Responsibility。
CoR的優點:
因爲無法預知來自外界的請求是屬於哪種類型,每個類別如果碰到它不能處理的請求只要放棄就可以。無疑這降低了類別之間的耦合性。
缺點是效率低,因爲一個請求的完成可能要遍曆到最後才可能完成,當然也可以用樹的概念優化。 在Java AWT1.0中,對於滑鼠按鍵事情的處理就是使用CoR,到Java.1.1以後,就使用Observer代替CoR
擴展性差,因爲在CoR中,一定要有一個統一的介面Handler.局限性就在這裏。
发表评论
-
第四篇:设计模式与Struts介绍篇
2004-06-24 07:02 713严重警告:只关心程序的人请跳过<o:p></ ... -
设计模式之Factory
2004-06-24 19:47 588定义:提供创建对象的接口. 为何使用?工厂模式是我们最常用的模 ... -
設計模式之Prototype(原型)
2004-06-24 19:48 638定義:用原型實例指定創建物件的種類,並且通過拷貝這些原型創建新 ... -
设计模式之Singleton(单态)
2004-06-24 19:49 293定义:Singleton模式主要作用是保证在Java应用程序中 ... -
設計模式之Builder
2004-06-24 19:49 578Builder模式定義:將一個 ... -
設計模式之Facade(外觀)
2004-06-24 19:50 494Facade的定義: 爲子系統中的一組介面提供一個一致的介面。 ... -
設計模式之Proxy(代理)
2004-06-24 19:51 733理解並使用設計模式,能夠培養我們良好的面向物件編程習慣,同時在 ... -
設計模式之Adapter(適配器)
2004-06-24 19:52 587定義:將兩個不相容的類別糾合在一起使用,屬於結構型模式,需要有 ... -
設計模式之Composite(組合)
2004-06-24 19:53 562Composite定義:將物件以樹 ... -
設計模式之Decorator(油漆工)
2004-06-24 19:54 652Decorator常被翻譯成"裝飾",我覺 ... -
設計模式之Bridge
2004-06-24 19:55 567Bridge定義 :將抽象和行為劃分開來,各自獨立,但能動態的 ... -
設計模式之Template
2004-06-24 19:57 547Template定義:定義一個操作中演算法的骨架,將一些步驟的 ... -
設計模式之Flyweight(享元)
2004-06-24 19:57 574Flyweight定義:避免大量擁有相同內容的小類別的開銷(如 ... -
設計模式之Memento(備忘機制)
2004-06-24 19:58 568Memento定義:memento是一個保存另外一個物件內部狀 ... -
設計模式之Observer
2004-06-24 20:06 644Java深入到一定程度,就 ... -
設計模式之Command
2004-06-24 20:07 592Command模式是最讓我疑惑的一個模式,我在閱讀了很多代碼後 ... -
設計模式之State
2004-06-24 20:09 654State的定義: 不同的狀態,不同的行爲;或者說,每個狀態有 ... -
設計模式之Strategy(策略)
2004-06-24 20:10 548Strategy是屬於設計模式 ... -
設計模式之Mediator(仲介者)
2004-06-24 20:12 571Mediator定義:用一個仲介物件來封裝一系列關於物件交互行 ... -
設計模式之Visitor
2004-06-24 20:13 602Visitor定義作用於某個物件群中各個物件的操作。 它可以使 ...
相关推荐
C#面向对象设计模式 (行为型模式) Chain Of Responsibility 职责链模式 视频讲座下载
C#面向对象设计模式 Chain of Responsibility 职责链模式 视频讲座下载
职责链模式(Chain of Responsibility)是一种行为型设计模式,它允许将请求沿着处理者对象的链进行传递,直到某个对象能够处理这个请求。在C#中,职责链模式的应用可以帮助我们构建灵活、可扩展的系统,减少对象...
职责链模式(Chain of Responsibility Pattern)是一种行为设计模式,它允许将请求的发送者和接收者解耦,使得多个对象都有可能处理一个请求,而无需显式指定接收者。在这个模式中,请求沿着一个处理者链进行传递,...
### C#面向对象设计模式纵横谈(14):Chain of Responsibility 职责链模式(行为型模式) #### 概述 在本篇文章中,我们将深入探讨C#中的Chain of Responsibility(职责链)模式,这是行为型设计模式的一种。虽然标题...
职责链模式(Chain of Responsibility)是一种行为型设计模式,它允许你将请求沿着处理者对象的链进行传递,直到某个对象处理该请求。在C#编程中,职责链模式能够帮助我们实现一种松耦合的架构,使得请求的发送者和...
Chain of Responsibility模式是GOF(GoF,Gang of Four)在他们的经典著作《设计模式:可复用面向对象软件的基础》中提出的23种设计模式之一,属于行为模式类别。这个模式的主要目的是允许在对象之间传递请求,同时...
创建模式: ...设计模式之Chain of Responsibility(职责链) 设计模式之Command 设计模式之State 设计模式之Strategy(策略) 设计模式之Mediator(中介者) 设计模式之Interpreter(解释器) 设计模式之Visitor
**PHP设计模式:Chain Of Responsibility(职责链模式)** 职责链模式是一种行为设计模式,它的主要目的是解耦请求的发送者和接收者,通过创建一个处理请求的对象链,使得多个对象都有机会处理这个请求。在PHP中,...
设计模式参考文档 ...设计模式之Chain of Responsibility(职责链) 设计模式之Command 设计模式之State 设计模式之Strategy(策略) 设计模式之Mediator(中介者) 设计模式之Interpreter(解释器) 设计模式之Visitor
职责链模式(Chain of Responsibility)是设计模式中的一种行为模式,它允许将请求沿着处理者对象的链式结构进行传递,直到某个对象决定处理这个请求。这种模式的主要优点在于可以解耦发送者和接收者,使得系统更加...
职责链模式(Chain of Responsibility)是一种行为设计模式,它的核心思想是将一系列处理请求的对象组织成一条链,每个对象都包含对请求的处理或传递的责任。在C++中实现职责链模式,我们可以创建一个抽象处理器类,...
**职责链模式**(Chain of Responsibility Pattern)是一种行为设计模式,它使多个对象都有机会处理请求,从而避免请求的发送者和接收者之间的耦合关系。将这些对象连成一条链,并沿着这条链传递该请求,直到有一个...
**职责链模式**(Chain of Responsibility Pattern)是行为型设计模式的一种,其核心在于避免请求发送者与接收者的直接耦合,通过构建一系列处理对象的链路,使请求能在链上逐级传递直至被某个对象处理。这种模式的...
本文实例讲述了Python设计模式之职责链模式原理与用法。分享给大家供大家参考,具体如下: 职责链模式(Chain Of Responsibility):使多个对象都有机会处理请求,从而避免发送者和接收者的耦合关系。将对象连成链并...
在软件设计领域,职责链(Chain of Responsibility)模式是一种行为设计模式,它允许将请求沿着处理者对象的链式结构进行传递,直到被某个对象处理。这种模式在C++中广泛应用,可以有效地解耦发送者和接收者,使得...
C#面向对象设计模式纵横谈(14):Chain of Responsibility 职责链模式(行为型模式) C#面向对象设计模式纵横谈(15):(行为型模式) Command 命令模式 C#面向对象设计模式纵横谈(16):(行为型模式) Interpreter 解释...