设计模式 ( 十五 ) 中介者模式Mediator(对象行为型)

简介:

设计模式 ( 十五 ) 中介者模式Mediator(对象行为型)

1.概述

在面向对象的软件设计与开发过程中,根据“ 单一职责原则”,我们应该尽量将对象细化,使其只负责或呈现单一的职责,即将行为分布到各个对象中。

对于一个模块或者系统,可能由很多对象构成, 而且这些对象之间可能存在相互的引用,在最坏的情况下,每一个对象都知道其他所有的对象,这无疑复杂化了对象之间的联系。虽然将一个系统分割成许多对象通常可以增强可复用性,但是对象间相互连接的激增又会降低其可复用性,大量的相互连接使得一个对象似乎不太可能在没有其他对象的支持下工作,系统表现为一个不可分割的整体,而且对系统的行为进行任何较大的改动都会十分困难。结果是你不得不定义大量的子类以定制系统的行为。因此,为了减少对象两两之间复杂的引用关系,使之成为一个松耦合的系统,我们需要使用 中介者模式.
例子1:

2.问题

面对一系列的相交互对象。怎么样保证使各对象不需要显式地相互引用,使其耦合松散?

3.解决方案

中介者模式:用一个中介对象来封装一系列的对象交互。中介者使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互。中介者模式又称为调停者模式。(Define an object thatencapsulates how a set of objects interact. Mediator promotes loose coupling by keeping objects fromreferring to each other explicitly, and it lets you vary their interaction independently

4.适用性

在下列情况下使用中介者模式:

• 1)系统中 对象之间存在复杂的引用关系,产生的相互依赖关系结构混乱且难以理解。
• 2)一组对象以定义良好但是复杂的方式进行通信。产生的相互依赖关系结构混乱且难以理解。
• 3)一个对象引用其他很多对象并且直接与这些对象通信 ,导致难以复用该对象。
• 4) 想通过一个中间类来封装多个类中的行为,而又不想生成太多的子类。可以通过引入中介者类来实现,在中介者中定义对象交互的公共行为,如果需要改变行为则可以增加新的中介者类。

5.结构


6.模式的组成

抽象中介者(Mediator):中介者定义一个接口用于与各同事(Colleague)对象通信。
具体中介者(ConcreteMediator): 具体中介者通过协调各同事对象实现协作行为。了解并维护它的各个同事。
抽象同事类(Colleague class): 定义同事类接口,定义各同事的公有方法.
具体同事类(ConcreteColleague): 实现抽象同事类中的方法。每一个同时类需要知道中介者对象;每个具体同事类只需要了解自己的行为,而不需要了解其他同事类的情况。每一个同事对象在需与其他的同事通信的时候,与它的中介者通信。

7.效果

中介者模式的优点:
1) 减少了子类生成:  Mediator将原本分布于多个对象间的行为集中在一起。改变这些行为只需生成Mediator的子类即可。这样各个Colleague类可被重用。
2) 简化各同事类的设计和实现 : 它将各同事类Colleague解耦,Mediator有利于各Colleague间的松耦合. 你可以独立的改变和复用各Colleague类和Mediator类。
3) 它简化了对象协议: 用Mediator和各Colleague间的一对多的交互来代替多对多的交互。一对多的关系更易于理解、维护和扩展。
4) 它对对象如何协作进行了抽象 将中介作为一个独立的概念并将其封装在一个对象中,使你将注意力从对象各自本身的行为转移到它们之间的交互上来。这有助于弄清    楚一个系统中的对象是如何交互的。
5) 它使控制集中化 中介者模式将交互的复杂性变为中介者的复杂性。
中介者模式的缺点:
因为中介者封装了协议,即在具体中介者类中包含了同事之间的交互细节,可能会导致具体中介者类非常复杂,这可能使得中介者自身成为一个难于维护的
庞然大物。

8.实现

[php]  view plain  copy
 
 
  1. <?php  
  2.   
  3. /** 
  4.  * 中介者模式 
  5.  * 
  6.  *  
  7. */  
  8. /** 
  9.  * 抽象中介者类 
  10.  */  
  11. abstract class Mediator  
  12. {  
  13.     static protected  $_colleaguesend = array(  
  14.                                         'ConcreteColleague1'=> 'ConcreteColleague2',  
  15.                                         'ConcreteColleague2'=> 'ConcreteColleague3',  
  16.                                         'ConcreteColleague3'=> 'ConcreteColleague1',  
  17.                                         );  
  18.     protected  $_colleagues = null; //array  
  19.     public  function register(Colleague $colleague) {  
  20.         $this->_colleagues[get_class($colleague)] = $colleague;  
  21.     }  
  22.   
  23.     public abstract function operation($name$message);  
  24. }  
  25. /** 
  26.  * 具体中介者类 
  27.  */  
  28. class ConcreteMediator extends Mediator  
  29. {  
  30.       
  31.     public function operation($obj$message) {  
  32.         $className = self::$_colleaguesend[get_class($obj)];  
  33.         if ($className == get_class($obj) ) {  
  34.             return ;  
  35.         }  
  36.         if ($this->_colleagues[$className]) {  
  37.               
  38.             $this->_colleagues[$className]->notify($message);  
  39.         }     
  40.         return ;  
  41.     }  
  42. }  
  43. /** 
  44.  * 抽象同事类 
  45.  */  
  46. abstract class Colleague  
  47. {  
  48.     protected  $_mediator = null;  
  49.   
  50.     public function __construct($mediator) {  
  51.   
  52.         $this->_mediator = $mediator;  
  53.         $mediator->register($this);  
  54.     }  
  55.     /** 
  56.      * 通过中介实现相互调用 
  57.      */  
  58.     public abstract function send($message);  
  59.     /** 
  60.      * 具体需要实现的业务逻辑代码 
  61.      */  
  62.     public abstract function notify($message);  
  63. }  
  64.   
  65. /** 
  66.  * 具体同事类 
  67.  */  
  68. class ConcreteColleague1 extends Colleague  
  69. {  
  70.     public function __construct(Mediator $mediator) {  
  71.         parent::__construct($mediator);  
  72.     }  
  73.   
  74.     public function send($message) {  
  75.         $this->_mediator->operation($this$message);  
  76.     }  
  77.       
  78.     public function notify($message) {  
  79.         echo 'ConcreteColleague1 m:'$message'<br/>';  
  80.     }  
  81.   
  82. }  
  83.   
  84. /** 
  85.  * 具体同事类 
  86.  */  
  87. class ConcreteColleague2 extends Colleague  
  88. {  
  89.     public function __construct(Mediator $mediator) {  
  90.         parent::__construct($mediator);  
  91.     }  
  92.   
  93.     public function send($message) {  
  94.         $this->_mediator->operation($this$message);  
  95.     }  
  96.     public function notify($message) {  
  97.         echo 'ConcreteColleague2 m:'$message'<br/>';  
  98.     }  
  99.       
  100. }  
  101.   
  102.   
  103. /** 
  104.  * 具体同事类 
  105.  */  
  106. class ConcreteColleague3 extends Colleague  
  107. {  
  108.     public function __construct(Mediator $mediator) {  
  109.         parent::__construct($mediator);  
  110.     }  
  111.   
  112.     public function send($message) {  
  113.         $this->_mediator->operation($this$message);  
  114.     }  
  115.     public function notify($message) {  
  116.         echo 'ConcreteColleague3 m:'$message'<br/>';  
  117.     }  
  118.       
  119. }  
  120. $objMediator = new  ConcreteMediator();  
  121. $objC1 = new ConcreteColleague1($objMediator);  
  122. $objC2 = new ConcreteColleague2($objMediator);  
  123. $objC3 = new ConcreteColleague3($objMediator);  
  124.   
  125. $objC1->send("from ConcreteColleague1");  
  126. $objC2->send("from ConcreteColleague2");  
  127. $objC3->send("from ConcreteColleague3");  
  128. /****************************************************/  


9.与其他相关模式

1)外观模式,Facade与中介者的不同之处在于它是对一个对象子系统进行抽象,从而提供了一个为方便的接口。它的协议是单向的,即 Facade对象对这个子系统类提出请求,但反之则不。相反,Mediator提供了各Colleague对象不支持或不能支持的协作行为,而且协议是多向。
2) Colleague可使用Observers模式与Mediator通信。

10.总结与分析

1)迪米特法则的一个典型应用:在中介者模式中,通过创造出一个中介者对象,将系统中有关的对象所引用的其他对象数目减少到最少,使得一个对象与其同事之间的相互作用被这个对象与中介者对象之间的相互作用所取代。因此,中介者模式就是迪米特法则的一个典型应用
2) 通过引入中介者对象,可以将系统的网状结构变成以中介者为中心的星形结构,中介者承担了中转作用和协调作用。中介者类是中介者模式的核心,它对整个系统进行控制和协调,简化了对象之间的交互,还可以对对象间的交互进行进一步的控制。
3) 中介者模式的主要优点在于简化了对象之间的交互,将各同事解耦,还可以减少子类生成,对于复杂的对象之间的交互,通过引入中介者,可以简化各同事类的设计和实现;中介者模式主要缺点在于具体中介者类中包含了同事之间的交互细节,可能会导致具体中介者类非常复杂,使得系统难以维护。
4) 中介者模式适用情况包括:系统中对象之间存在复杂的引用关系,产生的相互依赖关系结构混乱且难以理解;一个对象由于引用了其他很多对象并且直接和这些对象通信,导致难以复用该对象;想通过一个中间类来封装多个类中的行为,而又不想生成太多的子类

目录
相关文章
|
5月前
|
设计模式
**工厂模式与抽象工厂模式**都是创建型设计模式,用于封装对象创建,减少耦合
【6月更文挑战第23天】**工厂模式与抽象工厂模式**都是创建型设计模式,用于封装对象创建,减少耦合。工厂模式专注于单个对象,通过具体工厂创建具体产品,适用于简单对象创建;抽象工厂则关注一系列相关产品,提供创建一族对象的接口,适用于处理多个不兼容产品族。选择模式基于问题域的复杂性,单个产品需求时用工厂模式,多产品族时用抽象工厂模式。
33 5
|
2月前
|
设计模式 Java
Java设计模式-中介者模式(20)
Java设计模式-中介者模式(20)
|
3月前
|
设计模式 前端开发 Java
【十三】设计模式~~~行为型模式~~~中介者模式(Java)
文章详细介绍了中介者模式(Mediator Pattern),这是一种对象行为型模式,用于封装一系列对象的交互,降低系统耦合度,并简化对象之间的交互关系。通过案例分析、结构图、时序图和代码示例,文章展示了中介者模式的组成部分、实现方式和应用场景,并讨论了其优点、缺点和适用情况。
【十三】设计模式~~~行为型模式~~~中介者模式(Java)
|
3月前
|
设计模式 存储 安全
18 Java反射reflect(类加载+获取类对象+通用操作+设计模式+枚举+注解)
18 Java反射reflect(类加载+获取类对象+通用操作+设计模式+枚举+注解)
96 0
|
4月前
|
设计模式 JavaScript
js设计模式【详解】—— 中介者模式
js设计模式【详解】—— 中介者模式
66 5
|
5月前
|
设计模式 缓存 Java
Java设计模式:享元模式实现高效对象共享与内存优化(十一)
Java设计模式:享元模式实现高效对象共享与内存优化(十一)
|
5月前
|
设计模式
中介者模式-大话设计模式
中介者模式-大话设计模式
|
5月前
|
设计模式 Java 程序员
Java设计模式之中介者模式详解
Java设计模式之中介者模式详解
|
19天前
|
设计模式 安全 Java
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
Kotlin教程笔记(51) - 改良设计模式 - 构建者模式
|
2月前
|
设计模式 数据库连接 PHP
PHP中的设计模式:提升代码的可维护性与扩展性在软件开发过程中,设计模式是开发者们经常用到的工具之一。它们提供了经过验证的解决方案,可以帮助我们解决常见的软件设计问题。本文将介绍PHP中常用的设计模式,以及如何利用这些模式来提高代码的可维护性和扩展性。我们将从基础的设计模式入手,逐步深入到更复杂的应用场景。通过实际案例分析,读者可以更好地理解如何在PHP开发中应用这些设计模式,从而写出更加高效、灵活和易于维护的代码。
本文探讨了PHP中常用的设计模式及其在实际项目中的应用。内容涵盖设计模式的基本概念、分类和具体使用场景,重点介绍了单例模式、工厂模式和观察者模式等常见模式。通过具体的代码示例,展示了如何在PHP项目中有效利用设计模式来提升代码的可维护性和扩展性。文章还讨论了设计模式的选择原则和注意事项,帮助开发者在不同情境下做出最佳决策。

热门文章

最新文章

  • 1
    C++一分钟之-设计模式:工厂模式与抽象工厂
    43
  • 2
    《手把手教你》系列基础篇(九十四)-java+ selenium自动化测试-框架设计基础-POM设计模式实现-下篇(详解教程)
    48
  • 3
    C++一分钟之-C++中的设计模式:单例模式
    58
  • 4
    《手把手教你》系列基础篇(九十三)-java+ selenium自动化测试-框架设计基础-POM设计模式实现-上篇(详解教程)
    38
  • 5
    《手把手教你》系列基础篇(九十二)-java+ selenium自动化测试-框架设计基础-POM设计模式简介(详解教程)
    63
  • 6
    Java面试题:结合设计模式与并发工具包实现高效缓存;多线程与内存管理优化实践;并发框架与设计模式在复杂系统中的应用
    58
  • 7
    Java面试题:设计模式在并发编程中的创新应用,Java内存管理与多线程工具类的综合应用,Java并发工具包与并发框架的创新应用
    42
  • 8
    Java面试题:如何使用设计模式优化多线程环境下的资源管理?Java内存模型与并发工具类的协同工作,描述ForkJoinPool的工作机制,并解释其在并行计算中的优势。如何根据任务特性调整线程池参数
    50
  • 9
    Java面试题:请列举三种常用的设计模式,并分别给出在Java中的应用场景?请分析Java内存管理中的主要问题,并提出相应的优化策略?请简述Java多线程编程中的常见问题,并给出解决方案
    110
  • 10
    Java面试题:设计模式如单例模式、工厂模式、观察者模式等在多线程环境下线程安全问题,Java内存模型定义了线程如何与内存交互,包括原子性、可见性、有序性,并发框架提供了更高层次的并发任务处理能力
    78
  • 下一篇
    无影云桌面