网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.J2ee学习流程.
.在J2EE Web 应用中使用.
.Java与.NET 谁才能主宰未来?.
.应用Rational 工具简化基于J2EE的.
.六个for循环的Java小程序源码展播.
.Hibernate的一对一关系(转).
.别让Hibernate偷走了你的标识符.
.我看多态——多态的学习笔记.
.web应用分页技术.
.控制对类内部数据或函数成员访问.
.从零开始学 Java (一) Hello W.
.在JAVA中连接Sybase数据库的例子.
.310-025 scjp exam dumps 06/10/.
.J2EE应用开发中与Oracle数据库的.
.java swing的拖放例子.
.利用Eclipse进行重构(上).
.Java异常处理之陋习展播.
.JAVA程序员面试32问,你能回答多少.
.JAVA基础知识(1).
.gsoap中文文档(5.gSoap2.x版与g.

java设计模式之Chain of Responsibility

发表日期:2008-1-5



  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.局限性就在这里。
上一篇:Java设计模式之Observer 人气:692
下一篇:java设计模式之Command(菜单命令) 人气:796
浏览全部Java的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐