Java资源网

| JAVA基础 | 环境配置 | JDBC | 线程技术 | Socket编程 | JavaMail | JAVA与XML | 设计模式 | 技术新闻 | Java认证 | 程序人生 软件下载
| JSP&Servlet | Spring | Struts | Hibernate | JBuilder | Eclipse | WebService | EJB技术 | J2ME开发 | 应用服务器 | JXTA | Ajax
Articles search文章搜索
   关键字:
   类 别:
       
New download 最新下载
· [组件]HTML Parser 1.5
· [教程]WebSphere Studio应用教程
· [组件]JDom 1.0
· [工具]Junit3.8.1
· [教程]EJB编程及J2EE系统架构和设计
· [教程]EJB教程
· [教程]J2EE Tutorial中文版
· [教程]Java编程思想2(英文)
· [教程]java编程思想(完整版)
· [教程]Java网络编程
New articles 最新文章
· 设计移动 Web 服务
· 解析XML的时候完全忽略DTD
· 理解XML Schema XML Schema 初步
· 标签库的深入研究
· 提升JSP应用程序的七大绝招
· 如何使用JDOM对XML文件进行操作
· 处理XML字符串中特殊字符
· 利用Digester把XML转换成为Java对象
· 使用WebService 和RMI远程协作
· 使用Axis开发Web Service程序
Articles top 热门文章
· Eclipse基础--plugin插件安装(6644)
· eclipse+tomcat+lomboz的安装配置说明(4774)
· Java程序员就业前景(4584)
· Windows下JAVA环境变量的设置祥解(3788)
· Tomcat下JSP、Servlet和JavaBean环境的配置(3716)
· 使用links方式安装Eclipse插件(3698)
· 一个老程序员的心理话(3533)
· linux下jdk的安装与配置(3459)
· 初学者入门:Structs中基本配置入门(3334)
· Eclipse 运行命令行参数大全(3084)
您的位置:首页>>设计模式>>调停者模式(Mediatornbsp;Pattern)
调停者模式(Mediatornbsp;Pattern)
2007-04-13   来源:www.javaresearch.org  作者:未知

第31章:调停者模式(Mediator Pattern)


描述:


    通常,面向对象应用程序是由一组为了提供某种服务而彼此交互的对象组成。当彼此引用的对象数量比较少时,此时对象之间就为直接交互(点对点)。图31.1展示了当ObjectA和ObjectB之间彼此直接引用时的直接交互。
  
Figure 31.1: Point-to-Point Communication in the Case of Two Objects 
当对象的数量增加时,这种直接交互会导致对象之间复杂的、混乱的引用(如图31.2)。这就会影响应用程序的可维护性。同时,因为对象之间的高耦合,当一个对象直接引用其他的对象时,缩小了这些对象的复用范围。
 
 
Figure 31.2: Point-toPoint Communication?Increased Number of Objects 
在这种情况下,调停模式(Mediator Pattern)可以为这组对象设计一个控制、协调交互(交流)的模型,从而消除对象直接引用其他对象的需求。(如图31.3)
  
Figure 31.3: Object Interaction?Mediator as a Communication Hub
    调停者模式(Mediator Pattern)推荐抽象所有对象交互的细节到一个独立的类,这个类就是调停者,它负责这组对象之间的交互。这组对象中的每一个对象仍然负责提供它所具有的服务,但为了提供服务,对象之间不能直接彼此交互。两个不同对象之间的交互通过调停者(Mediator)进行路由。所有的对象把消息发送给调停者(Mediator)。调停者(Mediator)依据应用程序的需求把消息再发送给相应的对象。这样的设计有以下主要的优点:
(1)    随着所有对象的交互行为移到一个独立的对象中,通过调停者(Mediator)的子类替换调停者(Mediator)或者改变它的功能可以很容易的改变对象之间内部的关联行为。
(2)    将对象的内部依赖关系移到一个单独的对象,这样会提高对象的可用性。
(3)    因为对象不需要直接引用其他的对象,所以对象可以更容易的进行单元测试。
(4)    类之间的低耦合可以使类在不影响其他类的基础上进行修改。
调停者(Mediator)模式和外观(Façade)模式
在一些方面调停者(Mediator)模式和外观(Façade)模式有相似之处。表31.1列出了两种模式之间的相似点和不同点。
Table 31.1: 调停者(Mediator)模式和外观(Façade)模式
  
在讨论命令模式的时候,我们建立了两个实验应用程序,让我们从新回顾这些应用程序,看一看应用调停者(Mediator,)模式如何避免对象与对象之间的直接交互。

例子1:


    在前一章建立的FTP模拟客户应用程序有下面的客户UI组件(表31.2)
  
Table 31.2: List of User Interface Objects and the Associated Functionality 
图31.4描述了不同UI对象之间的交互。
   
Figure 31.4: Object Interaction 
为了使现存应用程序对客户更加友好,让我们考虑如下的较小的改进。
(1)    当UI第一次显示,除了Exit按钮的所有按钮都是disabled的。
(2)    当从显示本地文件系统的JList控件中选择文件名时:
A、    Upload和Delete按钮应该是enabled的。
B、    在远程文件系统中任何可选择的文件项目应该为不可选的(deselected).
C、    Download按钮应该是disabled的。
(3)    当从显示远程文件系统的JList控件中选择文件名时:
A、Download和Delete按钮应该是enabled的。
B、在本地文件系统中任何可选择的文件项目应该为不可选的(deselected).
C、Upload按钮应该是disabled的。
D、当执行完必要的Upload/download操作之后,Upload、Download和Delete按钮应该为disabled的。同样,删除一个特定的文件后,Delete按钮应该为disabled的,同时Upload、Download按钮应该为enabled的。本地的和远程的文件系统在执行完Upload、Download和Delete操作后,应该进行刷新。
图31.5显示了对象之间交互的结果。
   
Figure 31.5: Object-to-Object Communication with Increased Direct Reference to Each Other 
当更多的控件因增加功能而被添加,如重命名一个文件、FTP服务器连接、断开等,对象直接直接的交互在对象内部产生复杂的、混乱的对象引用。这很大程度上降低了应用程序的可维护性。
调停者模式可以被应用到这种情况,是一种对对象交互的高效的设计。应用调停者模式,一个描述对象之间交互细节的抽象被建立。这个抽象被设计为一个独立的Mediator类,如图31.6和Listing 31.1
  

Figure 31.6: Mediator 
Listing 31.1: Mediator Class 
  1. class Mediator { 
  2.   private UploadButton btnUpload; 
  3.   private DownloadButton btnDownload; 
  4.   private DeleteButton btnDelete; 
  5.   private LocalList localList; 
  6.   private RemoteList remoteList; 
  7.   public void registerUploadButton(UploadButton inp_ib) { 
  8.     btnUpload = inp_ib; 
  9.   } 
  10.   public void registerDownloadButton( 
  11.     DownloadButton inp_dnb) { 
  12.     btnDownload = inp_dnb; 
  13.   } 
  14.   public void registerDeleteButton(DeleteButton inp_db) { 
  15.     btnDelete = inp_db; 
  16.   } 
  17.   public void registerLocalList(LocalList inp_arl) { 
  18.     localList = inp_arl; 
  19.   } 
  20.   public void registerRemoteList(RemoteList inp_drl) { 
  21.     remoteList = inp_drl; 
  22.   } 
  23.   public void UploadItem() { 
  24.     int index = localList.getSelectedIndex(); 
  25.     String selectedItem = 
  26.      localList.getSelectedValue().toString(); 
  27.     ((DefaultListModel) localList.getModel()).remove( 
  28.      index); 
  29.     ((DefaultListModel) remoteList.getModel()).addElement( 
  30.      selectedItem); 
  31.     btnUpload.setEnabled(false); 
  32.     btnDelete.setEnabled(false); 
  33.     btnDownload.setEnabled(false); 
  34.   } 
  35.   public void DownloadItem() { 
  36.         … 
  37.         … 
  38.   } 
  39.   public void DeleteItem() { 
  40.         … 
  41.         … 
  42.   } 
  43.   public void LocalListSelect() { 
  44.         … 
  45.         … 
  46.   } 
  47.   public void RemoteListSelect() { 
  48.     localList.setSelectedIndex(-1); 
  49.     btnUpload.setEnabled(false); 
  50.     btnDelete.setEnabled(true); 
  51.     btnDownload.setEnabled(true); 
  52.   } 

从Mediator类的实现可以看到:Mediator为不同的UI对象提供了把它们自己注册到Mediator的方法。当每一个UI控件被激活(或者点击)时对象之间需要执行的一组交互被设计为Mediator内部的一个单独的方法。
客户使用调停者(Mediator)
客户(Listing31.2)创建一个Meditor的实例,当创建UI对象时,客户传递Mediator实例给它,UI对象通过这个Mediator实例注册它自身。
Listing 31.2: Client FTPGUI Class 
  1. public class FTPGUI extends JFrame { 
  2.           … 
  3.           … 
  4.   private Mediator mdtr = new Mediator(); 
  5.   public FTPGUI() throws Exception { 
  6.           … 
  7.           … 
  8.     //Create controls 
  9.     defLocalList = new DefaultListModel(); 
  10.     defRemoteList = new DefaultListModel(); 
  11.     localList = new LocalList(defLocalList, mdtr); 
  12.     remoteList = new RemoteList(defRemoteList, mdtr); 
  13.     pnlFTPUI = new JPanel(); 
  14.           … 
  15.           … 
  16.     //Create buttons 
  17.     UploadButton btnUpload = 
  18.      new UploadButton(FTPGUI.UPLOAD, mdtr); 
  19.     btnUpload.setMnemonic(KeyEvent.VK_U); 
  20.     DownloadButton btnDownload = 
  21.      new DownloadButton(FTPGUI.DOWNLOAD, mdtr); 
  22.     btnDownload.setMnemonic(KeyEvent.VK_N); 
  23.     DeleteButton btnDelete = 
  24.      new DeleteButton(FTPGUI.DELETE, mdtr); 
  25.     btnDelete.setMnemonic(KeyEvent.VK_D); 
  26.           … 
  27.           … 
  28.   } 
  29.           … 
  30.           … 
  31. }//end of class 

用户接口对象--Mediator交互

因为所有的对象之间交互的细节从单独的UI对象移到了Mediator对象,每一个UI对象的processEvent方法简单到调用Mediator上的是当方法(listing 31.3)。图31.7显示了应用调停者模式以后,UI对象之间的交互。
Listing 31.3: Simplified UI Object Classes 
 
  1.          … 
  2.           … 
  3. class UploadButton extends JButton 
  4.   implements CommandInterface { 
  5.   Mediator mdtr; 
  6.   public void processEvent() { 
  7.     mdtr.UploadItem(); 
  8.   } 
  9.   public UploadButton(String name, Mediator inp_mdtr) { 
  10.     super(name); 
  11.     mdtr = inp_mdtr; 
  12.     mdtr.registerUploadButton(this); 
  13.   } 
  14. class DownloadButton extends JButton 
  15.   implements CommandInterface { 
  16.   Mediator mdtr; 
  17.   public void processEvent() { 
  18.     mdtr.DownloadItem(); 
  19.   } 
  20.   public DownloadButton(String name, Mediator inp_mdtr) { 
  21.     super(name); 
  22.     mdtr = inp_mdtr; 
  23.     mdtr.registerDownloadButton(this); 
  24.   } 
  25.           … 
  26.           … 
 
  
Figure 31.7: Object Interaction?Mediator as a Communication Hub 

例子2:


在讨论命令模式的时候,我们建立了一个增加和删除图书馆中项目数据库中项目的应用程序。一个给定的项目可以使一个或者多个分类的一部分。每一个Item对象维护了它所属的分类的一个列表。同理,每一个Category对象也维护了一个它的所有项目的列表。图31.8是了这种类关联图。
   
Figure 31.8: Item-Category Association 
当应用程序需要处理很多属于一个或者多个分类的项目时,对象之间的交互就会相当复杂。图31.9描述了当不同Item和Category对象彼此直接引用时的场景。
   
Figure 31.9: Item-Category Object Interaction 
不同的Item和Category对象间的直接交互可以通过把对象的交互细节从Item和Category类移到一个单独的Mediator类中得到消除(图31.10)。Mediator可以设计为有以下两组方法:
(1)    一组可以允许不同的Item和Category对象注册到Mediator的方法。
(2)    一组可以增加和删除项目的方法。作为这些方法一部分的不同对象之间交互,由Mediator负责的实现。


  
Figure 31.10: Mediator
Mediator可以维护Item?Category的关联,Item对象不需要直接引用Catory对象。
因此,一个Item对象不需要维护一个它所属的Categories的列表。同样,增加和删除操作不需要在Item和Category类的内部实现。
AddCommand 和DeleteCommand Command对象的Execute方法只是分别调用Mediator类的addItem和deleteItem方法。

本文原码:
附件:36.rar(10K)
 

  --相关文章--
· 面向对象编程,我的思想 (2007-04-13)
· 面向对象的思维方式 (2007-04-13)
· 通过Javanbsp;Swing看透MVC设计模式 (2007-04-13)
· 适配器模式(Adapternbsp;Pattern) (2007-04-13)
· 追MM与Java的23种设计模式 (2007-04-13)
· 责任链模式(Chainnbsp;ofnbsp;Responsibility) (2007-04-13)

版权所有©2005-2006 JAVA资源网 渝ICP备05007591号 虚拟主机 | 关于我们 | 联系方式 | 广告业务 | 网站地图 | 友情链接