Golang: Struktur-, Schnittstellen- und Abhängigkeitsinjektion (DI)
Strukturen und Schnittstellen in der Go-Sprache: wann man sie verwendet und wie man die Abhängigkeitsinjektion kombiniert
In diesem Artikel wird untersucht, wann Strukturen und wann Schnittstellen in der Go-Sprache verwendet werden sollten und wie beide zum Implementieren der Abhängigkeitsinjektion (DI) verwendet werden können. Wir erklären diese Konzepte anhand einer einfachen Spielzeugkiste-Analogie.
Beispiel aus der Praxis: Spielzeugkiste
Struktur
- Stellen Sie sich eine Struktur als ein bestimmtes Spielzeug in einer Spielzeugkiste vor, beispielsweise ein Auto.
- Das Auto hat bestimmte Attribute wie Farbe, Größe und Typ (z. B. Sportwagen).
- In der Programmierung speichern Strukturen Daten über Objekte.
Schnittstelle
- Die Benutzeroberfläche ist wie eine Spielzeugkiste, die jede Art von Spielzeug aufnehmen kann.
- Es definiert, was das Spielzeug tun kann, z. B. rollen, Geräusche machen oder aufleuchten. Jedes Spielzeug, das diese Aktionen ausführen kann, kommt in die Spielzeugkiste.
- Bei der Programmierung definiert eine Schnittstelle eine Reihe von Methoden, die verschiedene Typen (Strukturen) implementieren können.
Abhängigkeitsinjektion
- Stellen Sie sich ein Kind vor, das mit Spielzeug spielt. Anstatt Ihr Kind auf ein bestimmtes Spielzeug zu beschränken, lassen Sie es jederzeit ein beliebiges Spielzeug aus der Spielzeugkiste auswählen.
- Dies ist wie eine Abhängigkeitsinjektion, bei der Sie einer Funktion oder Klasse die Tools (oder Abhängigkeiten) zur Verfügung stellen, die sie zum Funktionieren benötigt, und so die Flexibilität erhöhen.
Grundkenntnisse
Struktur
- Definition: Eine Struktur ist eine Möglichkeit, einen neuen Typ mit bestimmten Feldern zu definieren.
- Zweck: Wird zur Modellierung von Datenstrukturen und zur Kapselung von Daten und Verhalten in einer Einheit verwendet.
Beispiel:
type Car struct { Model string Year int }
Schnittstelle
- Definition: Eine Schnittstelle definiert eine Reihe von Methoden, die ein Typ implementieren muss.
- Zweck: Unverzichtbar für Polymorphismus und entkoppelte Komponenten, unterstützt generische Programmierung.
Beispiel:
type CarInterface interface { Start() Stop() }
Verwenden Sie die Car-Struktur, um CarInterface zu implementieren:
func (c *Car) Start() { fmt.Println("Car started") } func (c *Car) Stop() { fmt.Println("Car stopped") }
Wann was verwenden?
Wann Strukturen verwendet werden sollten
- Muss eine bestimmte Datenstruktur mit definierten Feldern modellieren.
- Daten und Verhalten müssen in einer Einheit zusammengefasst werden.
Wann werden Schnittstellen verwendet?
- Sie müssen Verträge definieren, die von mehreren Typen implementiert werden können.
- Komponenten müssen entkoppelt werden, um den Code flexibler und einfacher zu testen.
- Um generischen Code zu schreiben, muss der Polymorphismus genutzt werden.
Flexibilität und Leistung in Einklang bringen
Während Schnittstellen Flexibilität bieten, können dynamische Methodenaufrufe zu Mehraufwand führen.
Andererseits haben Strukturen aufgrund statischer Typprüfung und direkter Methodenaufrufe Leistungsvorteile. So bringen Sie beides in Einklang:
Schnittstellenkombination
Kombinieren Sie mehrere Schnittstellen, um spezifischere Schnittstellen zu erstellen. Betrachten Sie beispielsweise eine Dateisystemschnittstelle:
type Car struct { Model string Year int }
Jetzt können wir eine spezifischere ReadWrite-Schnittstelle erstellen, indem wir Reader und Writer kombinieren:
type CarInterface interface { Start() Stop() }
Vorteile: Dieser Ansatz verbessert die Modularität, Wiederverwendbarkeit und Flexibilität des Codes.
Schnittstelleneinbettung
Betten Sie die Schnittstelle in die Struktur ein, um ihre Methoden zu erben. Betrachten Sie beispielsweise eine Protokollierungsschnittstelle:
func (c *Car) Start() { fmt.Println("Car started") } func (c *Car) Stop() { fmt.Println("Car stopped") }
Jetzt können wir eine spezifischere Schnittstelle ErrorLogger erstellen, die die Logger-Schnittstelle einbettet:
type Reader interface { Read(p []byte) (n int, err error) } type Writer interface { Write(p []byte) (n int, err error) }
Jeder Typ, der die ErrorLogger-Schnittstelle implementiert, muss auch die von der eingebetteten Logger-Schnittstelle geerbte Log-Methode implementieren.
type ReadWrite interface { Reader Writer }
Vorteile: Dies kann verwendet werden, um hierarchische Beziehungen zwischen Schnittstellen zu erstellen, wodurch der Code sauberer und ausdrucksvoller wird.
Abhängigkeitsinjektion
Dies ist ein Entwurfsmuster, das dabei hilft, Komponenten zu entkoppeln und die Testbarkeit zu verbessern. In der Go-Sprache wird dies normalerweise über Schnittstellen implementiert.
Beispiel: Benachrichtigungssystem
In diesem Beispiel definieren wir einen Benachrichtigungsdienst, der Nachrichten über verschiedene Kanäle senden kann. Wir werden DI verwenden, damit der Dienst mit jeder Benachrichtigungsmethode funktioniert.
Schritt 1: Notifier-Schnittstelle definieren
Zuerst definieren wir eine Schnittstelle für den Notifier. Diese Schnittstelle gibt die Methode zum Senden von Benachrichtigungen an.
type Logger interface { Log(message string) }
Schritt 2: Verschiedene Melder implementieren
Als nächstes erstellen wir zwei Implementierungen der Notifier-Schnittstelle: eine zum Senden von E-Mail-Benachrichtigungen und eine andere zum Senden von SMS-Benachrichtigungen.
E-Mail-Benachrichtigungsimplementierung:
type ErrorLogger interface { Logger LogError(err error) }
SMS Notifier-Implementierung:
type ConsoleLogger struct{} func (cl *ConsoleLogger) Log(message string) { fmt.Println(message) } func (cl *ConsoleLogger) LogError(err error) { fmt.Println("Error:", err) }
Schritt 3: Benachrichtigungsdienst erstellen
Jetzt erstellen wir einen NotificationService, der die Notifier-Schnittstelle verwendet. Dieser Dienst ist für den Versand von Benachrichtigungen verantwortlich.
type Notifier interface { Send(message string) error }
Schritt 4: Verwenden Sie die Abhängigkeitsinjektion in der Hauptfunktion
In der Hauptfunktion erstellen wir Instanzen von Notifiern und fügen sie in den NotificationService ein.
type EmailNotifier struct { EmailAddress string } func (e *EmailNotifier) Send(message string) error { // 模拟发送电子邮件 fmt.Printf("Sending email to %s: %s\n", e.EmailAddress, message) return nil }
Vorteile dieser Methode
- Entkopplung: NotificationService ist nicht von einer bestimmten Implementierung des Notifiers abhängig. Es basiert nur auf der Notifier-Schnittstelle, sodass in Zukunft problemlos neue Benachrichtigungsmethoden hinzugefügt werden können.
- Testbarkeit: Sie können ganz einfach eine Scheinimplementierung der Notifier-Schnittstelle für Unit-Tests von NotificationService erstellen.
- Flexibilität: Wenn Sie eine neue Benachrichtigungsmethode hinzufügen möchten (z. B. eine Push-Benachrichtigung), können Sie eine neue Struktur erstellen, die die Notifier-Schnittstelle implementiert, ohne den NotificationService-Code zu ändern.
Um sauberen, wartbaren und testbaren Go-Code zu schreiben, ist es entscheidend zu verstehen, wann Strukturen und wann Schnittstellen verwendet werden sollten.
Durch die Verwendung dieser beiden Konzepte zusammen mit der Abhängigkeitsinjektion können wir flexible und leistungsstarke Anwendungen erstellen.
Um den vollständigen Blog zu lesen, besuchen Sie bitte unseren Canopas-Blog.
Wenn Ihnen der Inhalt dieses Artikels gefällt, klicken Sie bitte auf die Schaltfläche ? - Als Autor bedeutet mir das sehr viel!
Teilen Sie Ihre Gedanken gerne im Kommentarbereich unten mit. Ihre Kommentare bereichern nicht nur unsere Inhalte, sondern inspirieren uns auch dazu, weitere wertvolle und informative Artikel für Sie zu erstellen.
Viel Spaß beim Programmieren! ?
Das obige ist der detaillierte Inhalt vonGolang: Struktur-, Schnittstellen- und Abhängigkeitsinjektion (DI). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

OpenSSL bietet als Open -Source -Bibliothek, die in der sicheren Kommunikation weit verbreitet sind, Verschlüsselungsalgorithmen, Tasten und Zertifikatverwaltungsfunktionen. In seiner historischen Version sind jedoch einige Sicherheitslücken bekannt, von denen einige äußerst schädlich sind. Dieser Artikel konzentriert sich auf gemeinsame Schwachstellen und Antwortmaßnahmen für OpenSSL in Debian -Systemen. DebianopensL Bekannte Schwachstellen: OpenSSL hat mehrere schwerwiegende Schwachstellen erlebt, wie z. Ein Angreifer kann diese Sicherheitsanfälligkeit für nicht autorisierte Lesen sensibler Informationen auf dem Server verwenden, einschließlich Verschlüsselungsschlüssel usw.

Wie kann man im Beegoorm -Framework die mit dem Modell zugeordnete Datenbank angeben? In vielen BeEGO -Projekten müssen mehrere Datenbanken gleichzeitig betrieben werden. Bei Verwendung von BeEGO ...

Backend Learning Path: Die Erkundungsreise von Front-End zu Back-End als Back-End-Anfänger, der sich von der Front-End-Entwicklung verwandelt, Sie haben bereits die Grundlage von Nodejs, ...

Das Problem der Verwendung von RETISTREAM zur Implementierung von Nachrichtenwarteschlangen in der GO -Sprache besteht darin, die Go -Sprache und Redis zu verwenden ...

Was soll ich tun, wenn die benutzerdefinierten Strukturbezeichnungen in Goland nicht angezeigt werden? Bei der Verwendung von Goland für GO -Sprachentwicklung begegnen viele Entwickler benutzerdefinierte Struktur -Tags ...

In der Bibliothek, die für den Betrieb der Schwimmpunktnummer in der GO-Sprache verwendet wird, wird die Genauigkeit sichergestellt, wie die Genauigkeit ...

Das Problem der Warteschlange Threading In Go Crawler Colly untersucht das Problem der Verwendung der Colly Crawler Library in Go -Sprache. Entwickler stoßen häufig auf Probleme mit Threads und Anfordern von Warteschlangen. � ...

In diesem Artikel wird vorgestellt, wie MongoDB im Debian -System konfiguriert wird, um eine automatische Expansion zu erzielen. Die Hauptschritte umfassen das Einrichten der MongoDB -Replikat -Set und die Überwachung des Speicherplatzes. 1. MongoDB Installation Erstens stellen Sie sicher, dass MongoDB im Debian -System installiert ist. Installieren Sie den folgenden Befehl: sudoaptupdatesudoaptinstall-emongoDB-org 2. Konfigurieren von MongoDB Replika-Set MongoDB Replikate sorgt für eine hohe Verfügbarkeit und Datenreduktion, was die Grundlage für die Erreichung der automatischen Kapazitätserweiterung darstellt. Start MongoDB Service: SudosystemctlstartMongodsudosysys
