Heim >Backend-Entwicklung >PHP-Tutorial >Disco mit Entwurfsmustern: Ein neuer Blick auf die Abhängigkeitsinjektion

Disco mit Entwurfsmustern: Ein neuer Blick auf die Abhängigkeitsinjektion

Christopher Nolan
Christopher NolanOriginal
2025-02-15 13:14:13604Durchsuche

Disco with Design Patterns: A Fresh Look at Dependency Injection

Kernpunkte

  • Abhängigkeitsinjektion (DI) ermöglicht eine flexible Abhängigkeitsverwaltung, indem die Erstellung und Verwendung von Objekten getrennt werden.
  • Abhängigkeitsinjektionsbehälter vereinfacht die Verwaltung von Objektabhängigkeiten, insbesondere wenn die Anzahl der Abhängigkeiten enorm ist. Sie wird durch Automatisierung der Objekterstellung und -konfiguration implementiert.
  • Disco, ein Annotationsbasis-DI-Container, vereinfacht die Konfiguration mit Anmerkungen wie @Bean und @Configuration und vereinfacht damit die Einrichtung des Dienstes.
  • Disco unterstützt erweiterte Funktionen wie Singleton -Instanziierung, verzögertes Ladung und Sitzungs-/Anforderungsmanagement, um die Ressourcenauslastung und den Service -Lebenszyklus zu optimieren.
  • Die Integration von
  • Disco in Symfony-Komponenten erstellt ein grundlegendes HTTP-basierter Framework, das die Kompatibilität und Praktikabilität der Disco in der modernen Webanwendungsentwicklung demonstriert.
  • Dieser Artikel zeigt ein praktisches Beispiel für die Verwendung von Disco, um das DI-Muster zu implementieren und die Grundlagen für Entwickler zu bilden, um effiziente, skalierbare und leicht zu machende Webanwendungen aufzubauen.

Der Kern der Abhängigkeitsinjektion liegt in der Wiederverwendbarkeit des Codes. Es ist ein Entwurfsmuster, das die Wiederverwendbarkeit von erweitertem Code durch die Trennung von Objekterstellung/-konfiguration von der Nutzung verbessern soll.

Disco with Design Patterns: A Fresh Look at Dependency Injection

Betrachten Sie den folgenden Code:

<code class="language-php">class Test {

    protected $dbh;

    public function __construct(\PDO $dbh)
    {
        $this->dbh = $dbh;
    }

}

$dbh  = new PDO('mysql:host=localhost;dbname=test', 'username', 'password');
$test = new Test($dbh);</code>

Wie Sie sehen können, erstellen wir es außerhalb der Klasse, anstatt ein PDO -Objekt innerhalb der Klasse zu erstellen und über einen Konstruktor als Abhängigkeit weiterzugeben. Auf diese Weise können wir den Treiber unserer Wahl verwenden, ohne den in der Klasse definierten Treiber verwenden zu müssen.

Alejandro Gervasio und Fabien Potencier liefern wundervolle Erklärungen für das Konzept von DI.

Dieses Muster hat jedoch einen Nachteil: Wenn die Anzahl der Abhängigkeiten zunimmt, ist es erforderlich, viele Objekte zu erstellen/zu konfigurieren, bevor sie an die abhängigen Objekte weitergegeben werden. Es kann am Ende viel Boilerplate -Code sowie eine lange Warteschlange des Parameters im Konstruktor erzeugen. Zu diesem Zeitpunkt müssen Sie Abhängigkeitsinjektionsbehälter!

Abhängigkeitsinjektionsbehälter (kurz DI -Container) ist ein Objekt, das weiß, wie man einen Dienst erstellt und seine Abhängigkeiten abwickelt.

In diesem Artikel werden wir einen aufstrebenden DI -Container, Disco, verwenden, um dieses Konzept weiter zu demonstrieren.

Weitere Informationen zu Abhängigkeitsinjektionsbehältern finden Sie in unseren anderen Artikeln zu diesem Thema.

Da Frameworks ein gutes Beispiel für die Bereitstellung von DI-Containern sind, werden wir am Ende des Artikels mit Disco und einigen Symfony-Komponenten ein grundlegendes HTTP-basierter Framework erstellen.

Installation

Um Disco zu installieren, verwenden wir den Komponisten wie gewohnt:

<code class="language-bash">composer require bitexpert/disco</code>

Um den Code zu testen, verwenden wir den integrierten Webserver von PHP:

<code class="language-php">class Test {

    protected $dbh;

    public function __construct(\PDO $dbh)
    {
        $this->dbh = $dbh;
    }

}

$dbh  = new PDO('mysql:host=localhost;dbname=test', 'username', 'password');
$test = new Test($dbh);</code>

Infolge Datei befindet sich. -t Anfänger index.php

Disco ist ein DI -Behälter, der mit Behältern interoperabel ist. Disco ist kontrovers ein DI -Behälter, der auf Annotation basiert.

Beachten Sie, dass das

-Paket eine Reihe von Schnittstellen enthält, um die Eigenschaften von Containerobjekten zu standardisieren. Um zu verstehen, wie es funktioniert, finden Sie in unserem Tutorial zum Aufbau unseres eigenen Injektionsbehälters von SitePoint -Abhängigkeiten, der auch auf

basiert.

container-interop Um dem Container einen Dienst hinzuzufügen, müssen wir eine Konfigurationsklasse erstellen. Dieser Typ sollte container-interop Annotationszeichen verwenden:

Jeder Containerdienst sollte in der Konfigurationsklasse als öffentliche oder geschützte Methode definiert werden. Disco nennt jeden Dienst eine Bohne, die aus der Java -Kultur stammt. @Configuration

In jeder Methode definieren wir, wie der Dienst erstellt wird. Jede Methode muss mit
<code class="language-bash">composer require bitexpert/disco</code>
gekennzeichnet sein (was bedeutet, dass dies ein Dienst ist) und der Typ des Rückgabeobjekts ist mit

Annotation markiert.

Dies ist ein einfaches Beispiel für Disco -Konfigurationsklassen, das eine "Bean" enthält: @Bean @return

Annotation akzeptiert einige Konfigurationsparameter, um die Art des Dienstes anzugeben. Diese Parameter geben an, ob es sich bei dem Dienst um ein Singleton-Objekt, eine Verzögerung des Ladens (falls das Objekt ressourcenintensiv ist) sein sollte oder seinen Zustand während der gesamten Sitzung fortsetzt.

<code class="language-bash">php -S localhost:8000 -t web</code>
Standardmäßig werden alle Dienste als Singleton -Dienste definiert.

@Bean Zum Beispiel erstellt die folgende Bean einen Singleton Lazy Loading -Service:

Disco verwendet Proxymanager, um die Belastung von Diensten zu verzögern. Es wird auch verwendet, um zusätzliches Verhalten (definiert durch Annotationen) in die Methoden der Konfigurationsklasse injizieren.

Nach dem Erstellen der Konfigurationsklasse müssen wir eine Instanz von
<code class="language-php"><?php
/**
 * @Configuration
 */
class Services {
    // ...
}</code>
erstellen und die Konfigurationsklasse an sie übergeben. Dies wird unser Behälter sein.

Schließlich registrieren wir den Container in

: AnnotationBeanFactory

So erhalten Sie Dienste von Container BeanFactoryRegistry

Da Disco mit Container/Interoperabilität kompatibel ist, können wir
<code class="language-php"><?php
/**
 * @Configuration
 */
class Configuration {

    /**
     * @Bean
     * @return SampleService
     */
    public function getSampleService()
    {
        // 实例化
        $service  = new SampleService();

        // 配置
        $service->setParameter('key', 'value');
        return $service;
    }
}</code>
und

Methoden für Containerobjekte verwenden:

get() has() (Der folgende Inhalt ähnelt dem Originaltext. Um Platz zu erhalten, werden einige Details hier weggelassen, aber Schlüsselinformationen und Struktur bleiben beibehalten)

<code class="language-php"><?php
// ...

/**
 * @Bean({"singleton"=true, "lazy"=true})
 * @return \Acme\SampleService
 */
public function getSampleService()
{
    return new SampleService();
}

// ...</code>

Service -Geltungsbereich

Containerparameter

Praktische Anwendung von Disco

Erstellen Sie einen Antworthörer

Schlussfolgerung

Dieser Artikel nur Pseudooriginalverarbeitung des Originaltextes und subtile Anpassungen und umgeschriebene Inhalte vorgenommen, wodurch sich der Artikel reibungsloser und natürlicher gestaltet, ohne die allgemeine Bedeutung des Originaltextes zu ändern. Das Bildformat und die Position bleiben unverändert.

Das obige ist der detaillierte Inhalt vonDisco mit Entwurfsmustern: Ein neuer Blick auf die Abhängigkeitsinjektion. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn