


Wie sollte mit der Verantwortung für das Schließen von Kanälen in Go-Generatoren umgegangen werden?
Idiomatische Implementierung von Generatoren mit Yield
In Go wird die Implementierung von Generatoren mit Yield typischerweise durch eine Kombination aus Goroutinen und Kanälen erreicht. Die Generatorfunktion erstellt eine Goroutine, die Werte über einen Kanal liefert, und die Verbraucherfunktion empfängt diese Werte vom Kanal in einer For-Range-Schleife.
Verantwortung für das Schließen des Kanals
Gemäß der Go Idiome, die Verantwortung für das Schließen des Kanals liegt bei der Generatorfunktion. Da der Generator weiß, wann die Iteration abgeschlossen ist, sollte er den Kanal schließen, um dem Verbraucher zu signalisieren, dass keine weiteren Werte empfangen werden.
Geänderter Code mit Caller Deferring Close()
In Ihrem geänderten Code haben Sie die Verantwortung für das Schließen des Kanals korrekt dem Anrufer zugewiesen, indem Sie ihn in der Generatorfunktion nicht geschlossen haben. Sie sollten jedoch auch den Aufruf close() in der Funktion main() entfernen, da es falsch ist, einen bereits geschlossenen Kanal zu schließen.
package main import ( "./lib" "fmt" ) var ( fruits = []string{"apple", "banana", "cherry", "durian"} banned = "durian" ) func main() { channel := lib.PermutateWithChannel(fruits) defer close(channel) // Defer closing the channel for myFruits := range channel { fmt.Println(myFruits) if myFruits[0] == banned { break // Break from the loop instead of closing the channel } } }
Negative Nebenwirkungen des Schließens eines geschlossenen Kanals
Wenn der Aufrufer den Kanal schließt, führen alle nachfolgenden Versuche, Werte an ihn zu senden, zu einer Laufzeitpanik. Dies liegt daran, dass der Kanal als geschlossen markiert ist und das Senden an einen geschlossenen Kanal illegal ist. Diese Panik hat jedoch keine negativen Nebenwirkungen außer dem Beenden der Goroutine, die versucht hat, Werte zu senden.
Receive-Only Channel Return Type
Um den von der Bibliotheksfunktion zurückgegebenen Kanal auf den Empfang zu beschränken -only, während der Aufrufer es weiterhin schließen kann, können Sie einen neuen Typ einführen, der den Kanal umschließt und nur den Nur-Empfang-Kanal verfügbar macht Kanal:
type ReceiveOnlyChannel <-chan []string func NewReceiveOnlyChannel(channel <-chan []string) *ReceiveOnlyChannel { return (*ReceiveOnlyChannel)(&channel) } func PermutateWithChannel(strings []string) *ReceiveOnlyChannel { // ... (same as before, except it returns ReceiveOnlyChannel) }
Indem Sie den Kanal in einen neuen Typ einschließen, können Sie seinen Zugriff darauf beschränken, nur Vorgänge zu empfangen, während der Aufrufer ihn dennoch über die Close()-Methode des Wrapper-Typs schließen kann.
Das obige ist der detaillierte Inhalt vonWie sollte mit der Verantwortung für das Schließen von Kanälen in Go-Generatoren umgegangen werden?. 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, ...

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 ...

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

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. � ...

Der Unterschied zwischen Stringdruck in GO -Sprache: Der Unterschied in der Wirkung der Verwendung von Println und String () ist in Go ...
