Maison > développement back-end > tutoriel php > Explication détaillée des cinq principes du PHP orienté objet : principe ouvert-fermé

Explication détaillée des cinq principes du PHP orienté objet : principe ouvert-fermé

零到壹度
Libérer: 2023-03-23 13:40:01
original
1464 Les gens l'ont consulté

Le contenu partagé avec vous dans cet article est une explication détaillée du principe ouvert-fermé des cinq principes orientés objet de PHP. Il a une certaine valeur de référence. Les amis dans le besoin peuvent se référer à

    <.>
  1. Qu'est-ce que « ouvert-fermé »

À mesure que l'échelle des systèmes logiciels continue d'augmenter, la complexité de la maintenance et de la modification des systèmes logiciels continue d'augmenter. Ce dilemme a incité French. L'académicien en ingénierie Bertrand Meyer à Le principe "Open-Close Principe (OCP)" a été proposé en 1998. L'idée de base de ce principe est :

Ouvert (Ouvert pour extension) Le comportement du module doit être ouvert et supporte l'expansion, plutôt que rigide.

Fermer (Fermé pour modification) Lors de l'extension des fonctionnalités d'un module, cela ne doit pas affecter ou affecter les modules existants à grande échelle.

En d'autres termes, les développeurs sont tenus d'étendre les fonctions logicielles du système d'application sans modifier le code existant (code source ou code binaire) dans le système. Pour le résumer en une phrase : un module doit être développé en termes d'extensibilité et fermé en termes de variabilité.

Dans la vie, l'exemple le plus simple auquel penser est l'ordinateur. Nous pouvons facilement étendre les fonctions de l'ordinateur en connectant simplement différents appareils via l'interface.

Ouvert-fermé peut améliorer l'évolutivité et la maintenabilité du système, mais cela est aussi relatif. Il est impossible qu'un ordinateur soit complètement ouvert. Certains appareils et fonctions doivent rester stables pour réduire les difficultés de maintenance. Pour implémenter une nouvelle fonctionnalité, vous devez mettre à niveau votre matériel ou passer à un ordinateur plus performant. Prenons comme exemple un logiciel de lecture multimédia sur ordinateur. En tant que lecteur, il doit avoir certaines fonctions de base et universelles, telles que l'ouverture de fichiers multimédia, l'arrêt de la lecture, l'avance rapide, le réglage du volume, etc. Mais quel que soit le lecteur, quelle que soit la plateforme de lecture sur laquelle il se trouve, les lecteurs conçus selon ce principe doivent avoir un style et des habitudes de fonctionnement unifiés. Quel que soit celui utilisé, l'auteur doit pouvoir démarrer rapidement.

Prenons le lecteur comme exemple. Définissez d'abord une interface abstraite. Le code est le suivant.

  1. interface process
    {
      public function process();
    }
    Copier après la connexion

Ensuite, étendez cette interface pour implémenter les fonctions de décodage et de sortie, comme indiqué ci-dessous

  1. class playerencode implements process
    {
      public function process()
      {
        echo "encode",PHP_EOL;
      }
    }
    class playeroutput implements process
    {
      public function process()
      {
        echo "ouput",PHP_EOL;
      }
    }
    Copier après la connexion

Les différentes fonctions du lecteur sont ouvertes ici. Tant que vous suivez l'accord et implémentez l'interface du processus, vous pouvez ajouter de nouveaux modules fonctionnels au lecteur. Seuls les modules de décodage et de sortie sont implémentés ici, et d'autres nouveaux modules peuvent être ajoutés en fonction des besoins.

Définissez ensuite le gestionnaire de planification élevée du fil du joueur. Une fois que le joueur reçoit une notification (il peut s'agir d'un comportement de clic externe ou d'un comportement de notification interne), il rappellera le traitement réel du fil.

  1. class playProcess
    {
      private $message = null;
      public function __construct() {}
      public function callback(event $event)
      {
        $this->message = $event->click();
        if($this->message instanceof process)
        {
          $this->message->process();
        }
      }
    }
    Copier après la connexion

Le produit spécifique est sorti Ici, nous définissons une classe MP4. Cette classe est relativement fermée et définit la logique de traitement des événements. suit

  1. class mp4
    {
      public function work()
      {
        $playProcess = new playProcess();
        $playProcess->callback(new event(&#39;encode&#39;));
        $playProcess->callback(new event(&#39;output&#39;));
      }
    }
    Copier après la connexion

La dernière est la classe de traitement pour le tri des événements. Cette classe est chargée de trier les événements et de juger le comportement de l'utilisateur ou du interne pour générer un " Thread " correct. " pour la planification par le gestionnaire de race pure intégré au lecteur. Le code est le suivant

  1. class event
    {
      private $m;
      public function __construct($me)
      {
        $this->m = $me;
      }
      public function click()
      {
        switch($this->m)
        {
          case &#39;encode&#39;;
            return new playerencode();
            break;
          case &#39;output&#39;:
            return new playeroutput();
            break;
        }
      }
    }
    Copier après la connexion

Le code qui est finalement exécuté

  1. $mp4 = new mp4;
    $mp4->work();
    Copier après la connexion

Les résultats d'exécution sont les suivants :

encoder la sortie

  1. Comment respecter le principe ouvert-fermé

Le cœur de la réalisation de l'ouvert-fermé est de programmer de manière abstraite, pas concrètement, car l'abstraction est relativement stable . En laissant une classe dépendre d'une abstraction fixe, ces modifications sont fermées ; grâce à des mécanismes d'héritage et de polymorphisme orientés objet, vous pouvez hériter du corps abstrait, modifier le comportement inhérent en remplaçant ses méthodes et implémenter de nouvelles méthodes d'extension, c'est donc le cas. ouvert à l'agrandissement.

1) Appliquer les idées d'« abstraction » et d'« encapsulation » dans le design.

D'une part, il s'agit de trouver différents "facteurs variables" possibles dans le système logiciel et de les encapsuler.

D'un autre côté, un facteur variable ne doit pas être dispersé dans plusieurs modules de code différents, mais doit être encapsulé dans un objet.

2) Appliquer la programmation orientée interface dans la mise en œuvre de la programmation des fonctions système.

Lorsque les exigences changent, une nouvelle classe d'implémentation de cette interface peut être fournie pour s'adapter au changement.

La programmation orientée interface nécessite que des classes fonctionnelles implémentent des interfaces et que des objets soient déclarés comme types d'interface. En mode design, le mode décoration utilise évidemment OCP.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
php
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal