Heim >Backend-Entwicklung >PHP-Tutorial >Was ist das Schnittstellenisolationsprinzip?
Der Client sollte sich nicht auf Schnittstellen verlassen, die er nicht benötigt; die Abhängigkeit einer Klasse von einer anderen Klasse sollte auf der kleinsten Schnittstelle basieren.
Die Verwendung mehrerer spezialisierter Schnittstellen ist besser als die Verwendung einer einzigen allgemeinen Schnittstelle.
Die Abhängigkeit einer Klasse von einer anderen Klasse sollte auf der kleinsten Schnittstelle basieren.
Eine Schnittstelle stellt eine Rolle dar, und einer Schnittstelle sollten nicht unterschiedliche Rollen zugewiesen werden. Nicht verwandte Schnittstellen werden zu einer großen und aufgeblähten Schnittstelle zusammengeführt, was eine Verschmutzung der Rollen und Schnittstellen darstellt.
„Clients sollten nicht gezwungen werden, sich auf Methoden zu verlassen, die sie nicht verwenden. Die Schnittstelle gehört dem Client, nicht der Klassenhierarchie, in der sie sich befindet.“ Zwingen Sie Kunden nicht dazu, Methoden zu verwenden, die sie nicht verwenden. Wenn Benutzer gezwungen werden, Methoden zu verwenden, die sie nicht verwenden, werden diese Kunden mit Änderungen konfrontiert, die durch Änderungen an diesen Methoden verursacht werden, die sie nicht verwenden.
Dieses Bild bedeutet: Klasse A hängt von Methode 1, Methode 2 und Methode 3 in Schnittstelle I ab, und Klasse B ist die Implementierung der Abhängigkeit von Klasse A. Klasse C hängt von Methode 1, Methode 4 und Methode 5 in Schnittstelle I ab, und Klasse D ist die Implementierung der Abhängigkeit von Klasse C. Obwohl beide Klassen B und D nicht verwendete Methoden haben (d. h. die in der Abbildung rot markierten Methoden), müssen diese nicht verwendeten Methoden ebenfalls implementiert werden, da Schnittstelle I implementiert ist. Es ist ersichtlich, dass, wenn die Schnittstelle zu aufgebläht ist, die Methoden in der Implementierungsklasse implementiert werden müssen, unabhängig davon, ob sie für die davon abhängigen Klassen nützlich sind ein gutes Design. Wenn dieses Design geändert wird, um dem Schnittstellenisolationsprinzip zu entsprechen, muss Schnittstelle I aufgeteilt werden. Hier teilen wir die ursprüngliche Schnittstelle I in drei Schnittstellen auf. Das geteilte Design ist wie in der Abbildung gezeigt.
Die Bedeutung des Schnittstellenisolationsprinzips lautet: Erstellen Sie eine einzelne Schnittstelle Erstellen Sie keine riesige und aufgeblähte Schnittstelle, sondern versuchen Sie, die Schnittstelle zu verfeinern und so wenige Methoden wie möglich in der Schnittstelle zu haben. Mit anderen Worten: Wir müssen für jede Klasse dedizierte Schnittstellen einrichten, anstatt zu versuchen, eine riesige Schnittstelle für alle Klassen zu erstellen, deren Aufruf darauf angewiesen ist. Im Beispiel in diesem Artikel wird das Schnittstellenisolationsprinzip verwendet, um eine große Schnittstelle in drei dedizierte Schnittstellen umzuwandeln. Bei der Programmierung ist es flexibler, auf mehrere spezialisierte Schnittstellen zu setzen, als auf eine umfassende Schnittstelle. Schnittstellen sind „Verträge“, die während des Entwurfs extern festgelegt werden. Durch die dezentralisierte Definition mehrerer Schnittstellen können wir die Verbreitung externer Änderungen verhindern und die Flexibilität und Wartbarkeit des Systems verbessern.
Apropos, viele Leute werden denken, dass das Prinzip der Schnittstellenisolation dem vorherigen Prinzip der Einzelverantwortung sehr ähnlich ist, aber das ist nicht der Fall. Erstens konzentrierte sich das Prinzip der Einzelverantwortung ursprünglich auf Verantwortlichkeiten, während sich das Prinzip der Schnittstellenisolation auf die Isolierung von Schnittstellenabhängigkeiten konzentrierte. Zweitens schränkt das Prinzip der Einzelverantwortung hauptsächlich Klassen ein, gefolgt von Schnittstellen und Methoden, die auf die Implementierung und Details des Programms abzielen, während das Prinzip der Schnittstellenisolation hauptsächlich Schnittstellen einschränkt, hauptsächlich zur Abstraktion und für den Aufbau des Gesamtrahmens des Programms .
Wenn Sie das Schnittstellenisolationsprinzip zur Einschränkung von Schnittstellen verwenden, achten Sie auf die folgenden Punkte:
Die Schnittstelle sollte so klein wie möglich sein, aber innerhalb von Grenzen. Es ist eine Tatsache, dass eine Verfeinerung der Schnittstelle die Programmierflexibilität verbessern kann. Wenn sie jedoch zu klein ist, führt dies zu zu vielen Schnittstellen und verkompliziert das Design. Es muss also in Maßen geschehen.
Passen Sie Dienste für Klassen an, die auf Schnittstellen basieren, indem Sie der aufrufenden Klasse nur die Methoden zur Verfügung stellen, die sie benötigt, während Sie die Methoden ausblenden, die sie nicht benötigt. Nur durch die Fokussierung auf die Bereitstellung maßgeschneiderter Dienste für ein Modul können minimale Abhängigkeiten hergestellt werden.
Verbessern Sie den Zusammenhalt und reduzieren Sie externe Interaktionen. Stellen Sie sicher, dass die Schnittstelle die wenigsten Methoden verwendet, um die meisten Aufgaben zu erledigen.
Verwenden Sie das Schnittstellenisolationsprinzip und es muss moderat sein. Es ist nicht gut, die Schnittstelle zu groß oder zu klein zu gestalten. Beim Entwerfen von Schnittstellen können Sie dieses Prinzip nur dann genau umsetzen, wenn Sie mehr Zeit zum Nachdenken und Planen aufwenden.
Das obige ist der detaillierte Inhalt vonWas ist das Schnittstellenisolationsprinzip?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!