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