1、模式定义
中介者模式(Mediator)就是用一个中介对象来封装一系列的对象交互,中介者使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互。
对于中介对象而言,所有相互交互的对象,都视为同事类,中介对象就是用来维护各个同事对象之间的关系,所有的同事类都只和中介对象交互,也就是说,中介对象是需要知道所有的同事对象的。当一个同事对象自身发生变化时,它是不知道会对其他同事对象产生什么影响,它只需要通知中介对象,“我发生变化了”,中介对象会去和其他同事对象进行交互的。这样一来,同事对象之间的依赖就没有了。有了中介者之后,所有的交互都封装在了中介对象里面,各个对象只需要关心自己能做什么就行,不需要再关心做了之后会对其他对象产生什么影响,也就是无需再维护这些关系了。
2、UML类图
3、示例代码
MediatorInterface.php
<?phpnamespace DesignPatterns\Behavioral\Mediator;/** * MediatorInterface是一个中介者契约 * 该接口不是强制的,但是使用它更加符合里氏替换原则 */interface MediatorInterface{ /** * 发送响应 * * @param string $content */ public function sendResponse($content); /** * 发起请求 */ public function makeRequest(); /** * 查询数据库 */ public function queryDb();}
Mediator.php
<?phpnamespace DesignPatterns\Behavioral\Mediator;use DesignPatterns\Behavioral\Mediator\Subsystem;/** * Mediator是中介者模式的具体实现类 * In this example, I have made a "Hello World" with the Mediator Pattern. */class Mediator implements MediatorInterface{ /** * @var Subsystem\Server */ protected $server; /** * @var Subsystem\Database */ protected $database; /** * @var Subsystem\Client */ protected $client; /** * @param Subsystem\Database $db * @param Subsystem\Client $cl * @param Subsystem\Server $srv */ public function setColleague(Subsystem\Database $db, Subsystem\Client $cl, Subsystem\Server $srv) { $this->database = $db; $this->server = $srv; $this->client = $cl; } /** * 发起请求 */ public function makeRequest() { $this->server->process(); } /** * 查询数据库 * @return mixed */ public function queryDb() { return $this->database->getData(); } /** * 发送响应 * * @param string $content */ public function sendResponse($content) { $this->client->output($content); }}
Colleague.php
<?phpnamespace DesignPatterns\Behavioral\Mediator;/** * Colleague是一个抽象的同事类,但是它只知道中介者Mediator,而不知道其他同事 */abstract class Colleague{ /** * this ensures no change in subclasses * * @var MediatorInterface */ private $mediator; /** * @param MediatorInterface $medium */ public function __construct(MediatorInterface $medium) { $this->mediator = $medium; } // for subclasses protected function getMediator() { return $this->mediator; }}
Subsystem/Client.php
<?phpnamespace DesignPatterns\Behavioral\Mediator\Subsystem;use DesignPatterns\Behavioral\Mediator\Colleague;/** * Client是发起请求&获取响应的客户端 */class Client extends Colleague{ /** * request */ public function request() { $this->getMediator()->makeRequest(); } /** * output content * * @param string $content */ public function output($content) { echo $content; }}
Subsystem/Database.php
<?phpnamespace DesignPatterns\Behavioral\Mediator\Subsystem;use DesignPatterns\Behavioral\Mediator\Colleague;/** * Database提供数据库服务 */class Database extends Colleague{ /** * @return string */ public function getData() { return "World"; }}
Subsystem/Server.php
<?phpnamespace DesignPatterns\Behavioral\Mediator\Subsystem;use DesignPatterns\Behavioral\Mediator\Colleague;/** * Server用于发送响应 */class Server extends Colleague{ /** * process on server */ public function process() { $data = $this->getMediator()->queryDb(); $this->getMediator()->sendResponse("Hello $data"); }}
4、测试代码
Tests/MediatorTest.php
<?phpnamespace DesignPatterns\Tests\Mediator\Tests;use DesignPatterns\Behavioral\Mediator\Mediator;use DesignPatterns\Behavioral\Mediator\Subsystem\Database;use DesignPatterns\Behavioral\Mediator\Subsystem\Client;use DesignPatterns\Behavioral\Mediator\Subsystem\Server;/** * MediatorTest tests hello world */class MediatorTest extends \PHPUnit_Framework_TestCase{ protected $client; protected function setUp() { $media = new Mediator(); $this->client = new Client($media); $media->setColleague(new Database($media), $this->client, new Server($media)); } public function testOutputHelloWorld() { // 测试是否输出 Hello World : $this->expectOutputString('Hello World'); // 正如你所看到的, Client, Server 和 Database 是完全解耦的 $this->client->request(); }}
5、总结
中介者主要是通过中介对象来封装对象之间的关系,使之各个对象在不需要知道其他对象的具体信息情况下通过中介者对象来与之通信。同时通过引用中介者对象来减少系统对象之间关系,提高了对象的可复用和系统的可扩展性。但是就是因为中介者对象封装了对象之间的关联关系,导致中介者对象变得比较庞大,所承担的责任也比较多。它需要知道每个对象和他们之间的交互细节,如果它出问题,将会导致整个系统都会出问题。

PHP仍然流行的原因是其易用性、灵活性和强大的生态系统。1)易用性和简单语法使其成为初学者的首选。2)与web开发紧密结合,处理HTTP请求和数据库交互出色。3)庞大的生态系统提供了丰富的工具和库。4)活跃的社区和开源性质使其适应新需求和技术趋势。

PHP和Python都是高层次的编程语言,广泛应用于Web开发、数据处理和自动化任务。1.PHP常用于构建动态网站和内容管理系统,而Python常用于构建Web框架和数据科学。2.PHP使用echo输出内容,Python使用print。3.两者都支持面向对象编程,但语法和关键字不同。4.PHP支持弱类型转换,Python则更严格。5.PHP性能优化包括使用OPcache和异步编程,Python则使用cProfile和异步编程。

PHP主要是过程式编程,但也支持面向对象编程(OOP);Python支持多种范式,包括OOP、函数式和过程式编程。PHP适合web开发,Python适用于多种应用,如数据分析和机器学习。

PHP起源于1994年,由RasmusLerdorf开发,最初用于跟踪网站访问者,逐渐演变为服务器端脚本语言,广泛应用于网页开发。Python由GuidovanRossum于1980年代末开发,1991年首次发布,强调代码可读性和简洁性,适用于科学计算、数据分析等领域。

PHP适合网页开发和快速原型开发,Python适用于数据科学和机器学习。1.PHP用于动态网页开发,语法简单,适合快速开发。2.Python语法简洁,适用于多领域,库生态系统强大。

PHP在现代化进程中仍然重要,因为它支持大量网站和应用,并通过框架适应开发需求。1.PHP7提升了性能并引入了新功能。2.现代框架如Laravel、Symfony和CodeIgniter简化开发,提高代码质量。3.性能优化和最佳实践进一步提升应用效率。

PHPhassignificantlyimpactedwebdevelopmentandextendsbeyondit.1)ItpowersmajorplatformslikeWordPressandexcelsindatabaseinteractions.2)PHP'sadaptabilityallowsittoscaleforlargeapplicationsusingframeworkslikeLaravel.3)Beyondweb,PHPisusedincommand-linescrip

PHP类型提示提升代码质量和可读性。1)标量类型提示:自PHP7.0起,允许在函数参数中指定基本数据类型,如int、float等。2)返回类型提示:确保函数返回值类型的一致性。3)联合类型提示:自PHP8.0起,允许在函数参数或返回值中指定多个类型。4)可空类型提示:允许包含null值,处理可能返回空值的函数。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3汉化版
中文版,非常好用

Dreamweaver Mac版
视觉化网页开发工具

Atom编辑器mac版下载
最流行的的开源编辑器

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。