


Aufruf von defer in einer for-Schleife – gibt es eine bessere Möglichkeit, das Lesen der Antwort vom Kanal zu verzögern?
Aufrufverzögerung in einer for-Schleife – gibt es eine bessere Möglichkeit, das Lesen der Antwort vom Kanal zu verzögern? Dies ist ein häufiges Problem, auf das viele Entwickler bei der Verwendung der Go-Sprache stoßen. Das Schlüsselwort „defer“ wird verwendet, um die Ausführung von Funktionen in der Go-Sprache zu verzögern. Durch die Verwendung von „defer“ in einer for-Schleife kann sichergestellt werden, dass bestimmte Operationen nach dem Ende jeder Schleife ausgeführt werden. Wenn Sie jedoch die Antwort des Kanals in jeder Schleife lesen müssen, ist die Verwendung von defer möglicherweise nicht die beste Wahl. Gibt es also eine bessere Möglichkeit, das Lesen der Antwort vom Kanal zu verzögern? Lassen Sie es uns gemeinsam erkunden.
Frageninhalt
Ich versuche eine Funktion aufzurufen, die einen Kanal in einer Schleife zurückgibt. Hängen Sie dann diesen Kanal an das Slice an channelslice
. Abschließend iterieren Sie über die Kanalabschnitte und drucken die Antwort für jeden Kanal aus. Wenn ich das mache, zeigt meine IDE die Warnung:
possible resource leak, 'defer' is called in the 'for' loop
Wie Sie sehen können, rufe ich close(channelslice[i])
innerhalb der zweiten for-Schleife auf. Ist das nicht zu empfehlen? Wie könnte dies außerdem zu einem Ressourcenleck führen? Gibt es eine bessere Möglichkeit, mit dem Schließen oder Schneiden von Kanälen umzugehen?
package main import ( "fmt" "math/rand" ) func t() chan int { c := make(chan int) go func() { c <- rand.Intn(100) }() return c } func main() { channelSlice := make([]chan int, 0) for i := 0; i<100; i++ { // Keep making concurrent calls // Will read responses from the channel later channelSlice = append(channelSlice, t()) } for i := 0; i<100; i++ { defer close(channelSlice[i]) // Warning thrown by IDE fmt.Println(<-channelSlice[i]) } }
Workaround
Wie @mkopriva betont hat,
Verzögerte Aufrufe werden ausgeführt, wenn umgebende Funktionen beendet werden, sie werden nicht aufgerufen, wenn umgebende nichtfunktionale Blöcke beendet werden. Kapseln Sie den Schlaufenkörper in einem Verschluss ein.
Das habe ich getan:
for i := 0; i<100; i++ { func() { defer close(channelSlice[i]) fmt.Println(<-channelSlice[i]) }() }
Wie Sie sehen können, habe ich die defer
-Anweisung in ein iife (sofort aufgerufenen Funktionsausdruck) eingeschlossen. Es wäre auch schön, es zu einem Abschluss zu machen.
Dadurch wird sichergestellt, dass der Kanal jetzt geschlossen wird und kein Speicherverlust auftritt.
Das obige ist der detaillierte Inhalt vonAufruf von defer in einer for-Schleife – gibt es eine bessere Möglichkeit, das Lesen der Antwort vom Kanal zu verzögern?. 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.

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 der Bibliothek, die für den Betrieb der Schwimmpunktnummer in der GO-Sprache verwendet wird, wird die Genauigkeit sichergestellt, wie die Genauigkeit ...

In diesem Artikel werden eine Vielzahl von Methoden und Tools eingeführt, um PostgreSQL -Datenbanken im Debian -System zu überwachen, um die Datenbankleistung vollständig zu erfassen. 1. verwenden Sie PostgreSQL, um die Überwachungsansicht zu erstellen. PostgreSQL selbst bietet mehrere Ansichten für die Überwachung von Datenbankaktivitäten: PG_STAT_ACTIVITY: Zeigt Datenbankaktivitäten in Echtzeit an, einschließlich Verbindungen, Abfragen, Transaktionen und anderen Informationen. PG_STAT_REPLIKATION: Monitore Replikationsstatus, insbesondere für Stream -Replikationscluster. PG_STAT_DATABASE: Bietet Datenbankstatistiken wie Datenbankgröße, Transaktionsausschüsse/Rollback -Zeiten und andere Schlüsselindikatoren. 2. Verwenden Sie das Log -Analyse -Tool PGBADG

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

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

Um die Leistung von Debianhadoop Cluster zu verbessern, müssen wir von Hardware, Software, Ressourcenmanagement und Leistungsstimmen beginnen. Im Folgenden finden Sie einige wichtige Strategien und Vorschläge für wichtige Optimierungsstrategien: 1. Wählen Sie Hardware- und Systemkonfigurationen sorgfältig aus, um Hardwarekonfigurationen auszuwählen: Wählen Sie die entsprechenden CPU-, Speicher- und Speichergeräte gemäß den tatsächlichen Anwendungsszenarien aus. SSD beschleunigte E/O: Verwenden Sie so weit wie möglich Festkörper -Festplatten (SSDs), um die E/A -Betriebsgeschwindigkeit zu verbessern. Speicherausdehnung: Zuordnen ausreichend Speicher an Namenode- und Datanode -Knoten, um die größere Datenverarbeitung und -aufgaben zu bewältigen. 2. Software-Konfigurationsoptimierung Hadoop-Konfigurationsdateianpassung: Core-Site.xml: Konfigurieren Sie das HDFS-Standarddateisystem
