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
Freigeben: 2024-11-03 08:45:29
Original
1098 Leute haben es durchsucht

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>
Nach dem Login kopieren

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>
Nach dem Login kopieren

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!

Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage