Heim >Backend-Entwicklung >Golang >Wie können gleichzeitige Go-Routinen mit Kanälen effektiv eingeschränkt werden?

Wie können gleichzeitige Go-Routinen mit Kanälen effektiv eingeschränkt werden?

Barbara Streisand
Barbara StreisandOriginal
2024-11-03 08:45:291121Durchsuche

How to Effectively Limit Concurrent Go Routines with Channels?

Begrenzung der Anzahl gleichzeitiger Go-Routinen

Wenn Sie mit einer Liste von URLs arbeiten, die asynchron verarbeitet werden müssen, ist es oft wünschenswert, die Anzahl gleichzeitiger Goroutinen auf zu begrenzen verhindern, dass überwältigende Ressourcen zur Verfügung stehen. Die Lösung besteht darin, einen begrenzten Kanal zu erstellen, der die maximale Anzahl von Goroutinen steuert, die gleichzeitig ausgeführt werden können.

Ursprünglicher Versuch

Im ursprünglichen Versuch wurde ein gepufferter Kanal der Größe parallel erstellt:

<code class="go">results := make(chan string, *parallel)</code>

Die Absicht war, dass das Programm blockiert, wenn der Ergebniskanal voll ist, bis ein Wert aus dem Kanal gelesen wird, sodass eine weitere Goroutine erzeugt werden kann. Allerdings schränkt dieser Ansatz die Anzahl der Goroutinen nicht effektiv ein, da das Hauptprogramm nicht blockiert, wenn alle URLs verarbeitet wurden.

Lösung

Eine effektivere Lösung besteht darin, eine feste URL zu erstellen Anzahl der Worker-Goroutinen:

<code class="go">for i := 0; i < *parallel; i++ {
    wg.Add(1)
    go func() {
        defer wg.Done()
        for url := range urls {
            worker(url, client, results)
        }
    }()
}</code>

In dieser Lösung sind Goroutinen dafür verantwortlich, URLs von einem Kanal abzurufen und zu verarbeiten. Der Kanal wird mit URLs von einer Feeder-Goroutine gespeist, und sobald alle URLs abgerufen wurden, schließt die Feeder-Goroutine den Kanal und signalisiert den Arbeitern, ihre Aufgaben zu beenden.

Eine separate Goroutine überwacht den Abschlussstatus des Arbeiters Goroutinen, die den Ergebniskanal schließen, wenn alle Worker fertig sind. Dieser Ansatz begrenzt effektiv die Anzahl der ausgeführten Goroutinen auf die angegebene Parallelanzahl.

Das obige ist der detaillierte Inhalt vonWie können gleichzeitige Go-Routinen mit Kanälen effektiv eingeschränkt werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn