PHP 设计模式系列 -- 中介者模式(Mediator)
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、总结
中介者主要是通过中介对象来封装对象之间的关系,使之各个对象在不需要知道其他对象的具体信息情况下通过中介者对象来与之通信。同时通过引用中介者对象来减少系统对象之间关系,提高了对象的可复用和系统的可扩展性。但是就是因为中介者对象封装了对象之间的关联关系,导致中介者对象变得比较庞大,所承担的责任也比较多。它需要知道每个对象和他们之间的交互细节,如果它出问题,将会导致整个系统都会出问题。

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Alipay Php ...

Le détournement de la session peut être réalisé via les étapes suivantes: 1. Obtenez l'ID de session, 2. Utilisez l'ID de session, 3. Gardez la session active. Les méthodes pour empêcher le détournement de la session en PHP incluent: 1. Utilisez la fonction Session_RegeReate_id () pour régénérer l'ID de session, 2. Stocker les données de session via la base de données, 3. Assurez-vous que toutes les données de session sont transmises via HTTPS.

JWT est une norme ouverte basée sur JSON, utilisée pour transmettre en toute sécurité des informations entre les parties, principalement pour l'authentification de l'identité et l'échange d'informations. 1. JWT se compose de trois parties: en-tête, charge utile et signature. 2. Le principe de travail de JWT comprend trois étapes: la génération de JWT, la vérification de la charge utile JWT et l'analyse. 3. Lorsque vous utilisez JWT pour l'authentification en PHP, JWT peut être généré et vérifié, et les informations sur le rôle et l'autorisation des utilisateurs peuvent être incluses dans l'utilisation avancée. 4. Les erreurs courantes incluent une défaillance de vérification de signature, l'expiration des jetons et la charge utile surdimensionnée. Les compétences de débogage incluent l'utilisation des outils de débogage et de l'exploitation forestière. 5. L'optimisation des performances et les meilleures pratiques incluent l'utilisation des algorithmes de signature appropriés, la définition des périodes de validité raisonnablement,

L'application du principe solide dans le développement de PHP comprend: 1. Principe de responsabilité unique (SRP): Chaque classe n'est responsable d'une seule fonction. 2. Principe ouvert et ferme (OCP): les changements sont réalisés par extension plutôt que par modification. 3. Principe de substitution de Lisch (LSP): les sous-classes peuvent remplacer les classes de base sans affecter la précision du programme. 4. Principe d'isolement d'interface (ISP): utilisez des interfaces à grain fin pour éviter les dépendances et les méthodes inutilisées. 5. Principe d'inversion de dépendance (DIP): les modules élevés et de bas niveau reposent sur l'abstraction et sont mis en œuvre par injection de dépendance.

Comment déboguer le mode CLI dans phpstorm? Lors du développement avec PHPStorm, nous devons parfois déboguer PHP en mode interface de ligne de commande (CLI) ...

Comment définir automatiquement les autorisations d'UnixSocket après le redémarrage du système. Chaque fois que le système redémarre, nous devons exécuter la commande suivante pour modifier les autorisations d'UnixSocket: sudo ...

Liaison statique (statique: :) implémente la liaison statique tardive (LSB) dans PHP, permettant à des classes d'appel d'être référencées dans des contextes statiques plutôt que de définir des classes. 1) Le processus d'analyse est effectué au moment de l'exécution, 2) Recherchez la classe d'appel dans la relation de succession, 3) il peut apporter des frais généraux de performance.

Envoyant des données JSON à l'aide de la bibliothèque Curl de PHP dans le développement de PHP, il est souvent nécessaire d'interagir avec les API externes. L'une des façons courantes consiste à utiliser la bibliothèque Curl pour envoyer le post� ...
