`
fehly
  • 浏览: 247525 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

调停者模式(mediators)

阅读更多

     有一段时间没写过blog,今天没什么事情,看了看,jy里很多关于调停者设计模式的,打算自己也整理下,也算为自己加深下印象:


     前言:

     要了解调停者模式,先看看一个比较著名的法则:——迪米特法则


      迪米特法则(Law of Demeter)又叫作最少知识原则(Least Knowledge Principle 简写LKP),就是说一个对象应当对其他对象有尽可能少的了解,不和陌生人说话。英文简写为: LoD.

 

  迪米特法则可以简单说成:talk only to your immediate friends。 对于面向OOD来说,又被解释为下面几种方式:一个软件实体应当尽可能少的与其他实体发生相互作用。每一个软件单位对其他的单位都只有最少的知识,而且局限于那些与本单位密切相关的软件单位。

  迪米特法则的初衷在于降低类之间的耦合。由于每个类尽量减少对其他类的依赖,因此,很容易使得系统的功能模块功能独立,相互之间不存在(或很少有)依赖关系。

  迪米特法则不希望类直接建立直接的接触。如果真的有需要建立联系,也希望能通过它的友元类来转达。因此,应用迪米特法则有可能造成的一个后果就是:系统中存在大量的中介类,这些类之所以存在完全是为了传递类之间的相互调用关系——这在一定程度上增加了系统的复杂度。

    狭义的迪米特法则是指:如果两个类不必彼此直接通信,那么这两个类就不应当发生直接的相互作用。如果其中一个类需要调用另一类的某一个方法的话,可以通过第三者转发这个调用。

 

 

      广义的迪米特法则是指:一个模块设计的好坏的一个重要标志就是该模块在多大程度上讲自己的内部数据与实现的有关细节隐藏起来。

      一个软件实体应当尽可能少的与其他实体发生相互作用。

      每一个软件单位对其他的单位都只有最少的知识,而且局限于那些与本单位密切相关的软件单位。

      迪米特法则的目的在于降低类与类之间的耦合。由于每个类尽量减少对其他类的依赖,因此,很容易使得系统的功能模块功能独立,是的相互间存在尽可能少的依赖关系。

 

在运用迪米特法则到系统的设计中时,要注意以下几点:

第一:在类的划分上,应当创建弱耦合的类,类与类之间的耦合越弱,就越有利于实现可复用的目标。

第二:在类的结构设计上,每个类都应该降低成员的访问权限。

第三:在类的设计上,只要有可能,一个类应当设计成不变的类。

第四:在对其他类的应用上,一个对象对其他类的对象的应用应该降到最低。

第五:尽量限制局部变量的有效范围。

 

但是过度使用迪米特法则,也会造成系统的不同模块之间的通信效率降低,使系统的不同模块之间不容易协调等缺点。同时,因为迪米特法则要求类与类之间尽量不直接通信,如果类之间需要通信就通过第三方转发的方式,这就直接导致了系统中存在大量的中介类,这些类存在的唯一原因是为了传递类与类之间的相互调用关系,这就毫无疑问的增加了系统的复杂度。解决这个问题的方式是:使用依赖倒转原则(通俗的讲就是要针对接口编程,不要针对具体编程),这要就可以是调用方和被调用方之间有了一个抽象层,被调用方在遵循抽象层的前提下就可以自由的变化,此时抽象层成了调用方的朋友。

Demo (出自国士工作室)

 

 

故事分析: 

       慈禧太后要召见庞青龙。庞青龙在见到慈禧太后前经历了那些过程呢?首先,当然是有人通知庞青龙要被召见,通知庞青龙的人当然不会是慈禧本人!慈禧只是下达旨意,然后又相关的只能部门传达旨意,相关部门的领导人也不会亲自去通知庞青龙,这些领导人会派遣信得过的人去,而这个被派遣的人也不是说想见庞青龙就能见得了的,他也必须通过和庞青龙熟悉的人,最后才能见到庞青龙,从而才能成功的传达旨意;第二:在进宫前,庞青龙必须卸掉自己随身携带的任何武器;第三:会有专门的只能部门对庞青龙进行全身彻底的检查,以防有任何可以伤害人的东西携带在身上,当然这个过程可能非常的复杂和繁琐。最后,由一个太监带路到慈禧面前。当然,见到慈禧的时候,庞青龙不是和慈禧坐在一起的,要报仇距离!慈禧也深深的懂得保持距离的重要性!

       见到慈禧太后以后慈禧也没有和庞青龙直接说话,因为慈禧不和陌生人说话!而是同时身边的人传达自己的话,慈禧只需颐指气使即可。

       从上面的过程中我们可以看出处处体现了迪米特法则的应用,慈禧知道庞青龙这个人肯定是通过一层又一层的关系得知的,就是迪米特法则中的第三者转发而且这里面说不定还有若干个第三者的转发!而从慈溪下旨召见庞青龙到庞青龙收到旨意,这中间又是完美的提现了迪米特法则,这中间经历无数的第三者!就连庞青龙面见到慈禧后,慈禧也不和他直接说话,而是通过身边的人传话,这慈禧是不是太傻了,直接和他说不就行了吗?慈禧当然不傻,因为她深知迪米特法则的重要。两个类的对象之间如果不发生直接的联系就不直接发生关系!

       不过这也产生了一个问题,这中间经历这么多的转发,需要机构和人啊?或许这就是为什么当时的清政府机构那么庞大、财政开支惊人的原因之一吧^_^

如下图所示:

 新建一个陌生人的抽象父类,其他的陌生人继承这个接口:

package com.diermeng.designPattern.LoD;
/*
 * 抽象的陌生人类
 */
public abstract class Stranger {
    /*
     * 抽象的行为方法
     */
    public abstract void operation();
}
 

庞青龙实现继承实现陌生人抽象类:

package com.diermeng.designPattern.LoD.impl;
 
import com.diermeng.designPattern.LoD.Stranger;
/*
 * 庞青龙对抽象类Stranger的实现
 */
public class PangQingyong extends Stranger{
    /*
     * 操作方法
     * @see com.diermeng.designPattern.LoD.Stranger#operation()
     */
    public void operation(){
        System.out.println("禀报太后:我是庞青龙,我擅长用兵打仗!");
    }
}
 
 
 

   朋友类,这里指太监类

package com.diermeng.designPattern.LoD.impl;
 
import com.diermeng.designPattern.LoD.Stranger;
/*
 * 太监类
 */
public class Taijian {
    /*
     * 太监类的操作方法
     */
    public void operation(){
        System.out.println("friends paly");
    }
 
    /*
     * 由太监类提供Cixi需要的方法
     */
    public void findStranger() {
        //创建一个Stranger
        Stranger stranger = new PangQingyong();
        //执行相应的方法
        stranger.operation();
    }
}
 
 

 调用者类的代码,在这里是慈禧太后类:

package com.diermeng.designPattern.LoD.impl;
 
/*
 * 慈禧类
 */
public class Cixi {
    //拥有对太监的引用,即对“朋友”的引用
    private Taijian taijian;
 
    //得到一个太监对象
    public Taijian getTaijian() {
        return taijian;
    }
 
    //设置一个太监对象
    public void setTaijian(Taijian taijian) {
        this.taijian = taijian;
    }
 
    //操作方法
    public void operation(){
        System.out.println("someone play");
    }
 
 
}
 

 建立一个测试类,代码如下:

package com.diermeng.designPattern.LoD.client;
 
import com.diermeng.designPattern.LoD.impl.Taijian;
import com.diermeng.designPattern.LoD.impl.Cixi;
 
/*
 * 测试客户端
 */
public class LoDTest {
 
    public static void main(String[] args) {
        //声明并实例化慈禧类
        Cixi zhangsan = new Cixi();
 
        //设置一个太监实例化对象,即找到一个“朋友”帮忙做事
        zhangsan.setTaijian(new Taijian());
 
        //慈禧通过宫中太监传话给陌生人
        zhangsan.getTaijian().findStranger();
    }
}
 

 程序运行结果如下:

禀报太后:我是庞青龙,我擅长用兵打仗!
 已有应用简介: 

       迪米特法则或者最少知识原则作为面向对象设计风格的一种法则,也是很多著名软件设计系统的指导原则,比如火星登陆软件系统、木星的欧罗巴卫星轨道飞船软件系统。

温馨提示: 

迪米特法则是一种面向对象系统设计风格的一种法则,尤其适合做大型复杂系统设计指导原则。但是也会造成系统的不同模块之间的通信效率降低,使系统的不同模块之间不容易协调等缺点。同时,因为迪米特法则要求类与类之间尽量不直接通信,如果类之间需要通信就通过第三方转发的方式,这就直接导致了系统中存在大量的中介类,这些类存在的唯一原因是为了传递类与类之间的相互调用关系,这就毫无疑问的增加了系统的复杂度。解决这个问题的方式是:使用依赖倒转原则(通俗的讲就是要针对接口编程,不要针对具体编程),这要就可以是调用方和被调用方之间有了一个抽象层,被调用方在遵循抽象层的前提下就可以自由的变化,此时抽象层成了调用方的朋友。

分享到:
评论

相关推荐

    (Robotlegs五子棋)HelloRobotlegs

    此外,还能看到如何应用设计模式,如命令模式(Command)和中介者模式(Mediator),以实现更清晰的代码结构和更好的可维护性。对于希望深入理解ActionScript 3编程和使用Robotlegs框架的人来说,这是一个宝贵的资源...

    PureMVC Standard Framework for C#.zip

    6. **Mediator模式**:Mediators是介于View组件和Controller之间的一层,它们负责与特定的视图组件进行交互,处理组件的事件,并将这些事件转化为对Controller的操作。 在实际应用中,开发者可以利用PureMVC提供的...

    PureMVC_Best_Practices_cn.zip_C++ MVC_PureMVC C++_mvc_mvc c++_pu

    2. **PureMVC框架原理:** PureMVC提供了命令、观察者、代理、中介者等模式,帮助实现MVC模式。例如,Commands用于处理业务逻辑,Proxy管理数据,Mediators协调View和Model,Notifications则是通信机制。 3. **C++...

    robotlegs guide for actionscript developers source code

    这些例子对于初学者来说是宝贵的实践材料,能帮助他们快速掌握Robotlegs的用法。 在ActionScript开发中,使用Robotlegs框架有以下好处: - **模块化**:通过依赖注入,开发者可以轻松地将组件解耦,提高代码复用。...

    pureMVC源码实例(flex的mvc框架)

    3. **Mediators**: 视图组件和控制器之间的中介者,帮助解耦视图和控制器。 4. **Notifications**: 事件通知,通过全局常量定义,作为模型、视图和控制器之间通信的手段。 5. **_facade**: 应用程序外观,提供了一个...

    RobotLegs模块化构建的附加助手基类_ActionScript_下载.zip

    7. **Mediators**:Mediators在视图和模型之间提供了一个通信的桥梁。它们负责监听视图中的事件,并将这些事件转化为对模型的操作,反之亦然。这确保了视图和模型之间的解耦。 8. **Context**:RobotLegs的核心是...

    Robotlegs框架的Flex简单实例

    2. **Mediator模式**:Mediators作为视图组件和模型之间的桥梁,负责监听和处理视图事件,以及将数据传递给模型或视图。 3. **Injector(依赖注入)**:Robotlegs的依赖注入系统允许类声明它们的依赖项,而不是直接...

    PureMVC C#框架

    Mediators监听并响应用户的交互,同时可以订阅和发布通知来与模型和控制器进行通信。 3. **控制器(Controller)**:控制器层负责处理用户输入和协调模型与视图之间的交互。在PureMVC中,控制器由`ICommand`接口...

    基于StrangeIoC的点击方块加分的Demo

    6. **Mediators**: Mediators是MVC(Model-View-Controller)设计模式的一部分,它们在视图和模型之间建立联系。在这个Demo中,Mediator可能会监听用户的触摸输入,并将这些事件转化为 StrangeIoC 可以处理的形式。 ...

    PureMVC_study

    2. 可扩展性:通过添加新的Commands、Proxies和Mediators,可以轻松扩展功能。 3. 解耦合:组件间通过Notifications通信,降低了组件间的耦合度。 4. 重用性:由于组件独立,可以在不同项目中复用已有的组件。 五、...

    pure-MVC最佳实践.pdf

    - **Observer**:观察者模式的实现,用于监听特定的通知。 - **Notification**:用于在组件之间传递消息,触发Command的执行。当某个组件(通常是Mediator或Proxy)需要通知其他组件时,它会发布一个Notification。 ...

    PureMVC_CSharp

    - **Mediator(中介者)**: 作为视图组件和模型之间的通信桥梁,处理组件间的协作。 - **Notification(通知)**: 作为框架内的消息系统,负责组件间的通信。 2. **PureMVC C# 实现特点** - **模块化设计**: ...

    puremvc开发指南

    通过阅读提供的 CHM 和 PDF 文件,开发者可以学习如何设置项目结构,创建和注册 Mediators、Commands、Proxies,以及如何有效地使用 Notifications 进行通信。理解这些概念和实践将有助于提高使用 PureMvc 构建应用...

    puremvc基础教程

    总结起来,PureMVC提供了一种结构化的方法来组织Flex应用的业务逻辑,通过Proxy、Mediator、Command和Facade的协作,实现了MVC模式的高效实施,降低了代码的耦合度,提升了代码的可读性和可维护性。对于初学者,理解...

    Unity 专用 pureMVC

    PureMVC是面向对象的多层应用程序框架,它提供了一种模式来组织代码,使开发更加规范和高效。本篇文章将深入探讨Unity中如何使用PureMVC框架,以及它如何帮助实现UI和逻辑的分离。 PureMVC是一个轻量级的框架,其...

    Dataload_WCS

    - **基于业务对象模型**:该解决方案基于 WebSphere Commerce 的业务对象模型,因此用户只需要了解 WebSphere Commerce 的业务对象模式,而无需深入了解物理数据库模式。 - **CSV 输入文件**:用户只需准备 CSV 输入...

    PureMVC的框架

    PureMVC是一个强大的、轻量级...开发者可以根据需求创建自定义的Mediators、Commands和Proxies,实现灵活的扩展和复用。在实际项目中,PureMVC可以用于构建大型复杂应用,或者作为小型项目的结构基础,提高代码组织性。

    puremvc api

    PureMVC是一个开源的、轻量级的框架,主要用于构建多层应用架构,它强调了模型-视图-控制器(MVC)设计模式的分离。这个API文档是开发者深入理解和使用PureMVC的关键资源,尤其是在Flex环境中。由于网上不易获取,这...

    PureMvc实例 PureMvc第一个实例

    4. **中介者(Mediators)**:比如`LoginPageMediator`负责与登录页面的交互,监听登录按钮的点击事件,然后创建并发送`Login`通知。 5. **通知(Notifications)**:PureMvc使用`Notification`对象作为不同层间...

Global site tag (gtag.js) - Google Analytics