„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 > Wie vermeide ich einen Deadlock beim Rangieren über einen gepufferten Kanal in GoLang?

Wie vermeide ich einen Deadlock beim Rangieren über einen gepufferten Kanal in GoLang?

Veröffentlicht am 02.11.2024
Durchsuche:367

How to Avoid Deadlock When Ranging Over a Buffered Channel in GoLang?

Deadlock in GoLang: Warum Bereich über einen gepufferten Kanal?

Bei der Verwendung gepufferter Kanäle in GoLang ist es wichtig, die Entstehung einer Deadlock-Situation zu vermeiden . Ein aktuelles Problem gab Anlass zu Bedenken hinsichtlich eines Deadlocks, der beim Versuch auftrat, über einen gepufferten Kanal zu wechseln, nachdem alle Goroutinen abgeschlossen waren.

Der bereitgestellte Code versucht, einen gepufferten Kanal mit einer Kapazität von 4 zu verwenden und 4 Goroutinen zu erzeugen, die Daten senden zum Kanal. Der Deadlock tritt jedoch auf, weil:

  • Die Kanalgröße ist zu klein, was dazu führt, dass blockierte Goroutinen darauf warten, in den gesamten Kanal zu schreiben.
  • Der Bereich über den Betrieb auf dem Kanal bleibt auf unbestimmte Zeit bestehen Warten auf das Eintreffen von Elementen, während keine Goroutinen mehr zum Schreiben übrig sind.

Lösung 1: Kanalgröße erweitern und nach Abschluss schließen

Um den Deadlock zu beheben, Der Kanal kann vergrößert und geschlossen werden, nachdem alle Goroutinen abgeschlossen sind:

ch := make(chan []int, 5)
...
wg.Wait()
close(ch)

Dies eliminiert jedoch die Vorteile des Pipelinings, da es das Drucken verhindert, bis alle Aufgaben abgeschlossen sind.

Lösung 2: Signalisierung des Abschlusses innerhalb der Druckroutine

Um tatsächliches Pipelining zu ermöglichen, kann die Funktion Done() innerhalb der Druckroutine aufgerufen werden:

func main() {
    ch := make(chan []int, 4)
    ...
    go func() {
        for c := range ch {
            fmt.Printf("c is %v\n", c)
            wg.Done()
        }
    }()
    ...
}

Dieser Ansatz stellt sicher, dass die Funktion „Done()“ erst aufgerufen wird, nachdem jedes Element gedruckt wurde, wodurch effektiv der Abschluss jeder Goroutine signalisiert wird.

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