„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Fanin-Muster in Go

Fanin-Muster in Go

Veröffentlicht am 24.08.2024
Durchsuche:815

Fanin Pattern in Go

Werfen wir einen Blick auf das Fan-In-Muster. Dies ist in Go wirklich nützlich, wenn wir verwandte Daten aus mehreren Threads haben, die wir zusammenführen müssen.

Angenommen, Sie haben mehrere API-Aufrufe an verschiedene Dienste durchgeführt und müssen die Ergebnisse kombinieren.

Dies ist ein wirklich einfach zu implementierendes Muster, aber Sie müssen darauf achten, wie Sie mit den Kanälen umgehen. Es ist leicht, einen Deadlock-Zustand zu bekommen.

// produce is used to simulate the different data sources
func produce(id int) chan int {
    ch := make(chan int)
    go func() {
        for i := 0; i 



Hier verwenden wir die Produce-Funktion, um die verschiedenen Quellen zu simulieren. Diese Quellkanäle werden an die Fanin-Funktion gesendet, die den Kombinationsvorgang ausführt.

Die Fanin-Funktion erstellt den Ausgabekanal und startet dann eine Goroutine, die jede Eingabe bearbeitet. Wir verwenden eine WaitGroup, um anzugeben, wann alle Eingabequellen im Ausgabekanal kombiniert wurden.

In diesem einfachen Beispiel iteriert der Hauptthread einfach über die Ausgabe. Beachten Sie, dass es keine Garantie für die Reihenfolge gibt, da die Werte der beiden Eingaben gemischt sind.

Ein wichtiger Punkt, den es zu erwähnen gilt, ist, dass wir den Ausgabekanal schließen müssen, wenn wir mit der Kombination der Eingaben fertig sind. Der Bereichsoperator wartet unbegrenzt, sobald der Kanal leer ist. Kommentieren Sie die Zeile „close(output)“ aus und Sie werden sehen, dass eine Deadlock-Bedingung vorliegt.

Wie können wir das verbessern? Hinterlassen Sie mir unten einen Kommentar.

Danke!

Der Code für diesen Beitrag und alle Beiträge dieser Serie finden Sie hier

Freigabeerklärung Dieser Artikel ist abgedruckt unter: https://dev.to/johnscode/fanin-pattern-in-go-5e5d?1 Bei Verstößen wenden Sie sich bitte an [email protected], um ihn zu löschen
Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3