Golang lädt mit Goroutinen mehrere Dateien parallel herunter
Ist es möglich, Dateien mit Goroutinen parallel herunterzuladen und zu speichern? Schauen wir uns zur Veranschaulichung einen bereitgestellten Codeausschnitt an, der in Golang geschrieben wurde.
<code class="go">import ( "encoding/json" "fmt" "io" "io/ioutil" "net/http" "net/url" "os" "path/filepath" "sync" ) ... func main() { ... var wg sync.WaitGroup for i, file := range flr.FileList { wg.Add(1) go download_file(file, tr, &wg) if i >= 2 { break } } wg.Wait() } ... func download_file(file File, token TokenResponse, wg *sync.WaitGroup) { ... wg.Done() }</code>
Die Lösung verstehen:
Das Problem entsteht, weil die Haupt-Goroutine vor allen beendet wird Goroutinen wurden erstellt, um die Dateien vollständig herunterzuladen. Um dies zu beheben, wird eine sync.WaitGroup eingeführt, um die Anzahl der ausgeführten Goroutinen zu verfolgen. Bevor die Haupt-Goroutine beendet wird, wartet sie, bis alle Goroutinen (die gleichzeitig ausgeführt werden) abgeschlossen sind.
Innerhalb jeder Goroutine erhöht die Methode wg.Add die Anzahl und zeigt so die Erstellung einer neuen Goroutine an. Nach dem erfolgreichen Herunterladen einer Datei wird die Methode wg.Done aufgerufen, die den Zähler verringert und den Abschluss einer Goroutine signalisiert.
Sobald alle Goroutinen abgeschlossen sind, wird die Methode wg.Wait() in der Haupt-Goroutine entsperrt und ermöglicht den Fortgang des Hauptprogramms.
Das obige ist der detaillierte Inhalt vonHier sind einige Titeloptionen basierend auf Ihrem bereitgestellten Artikel, wobei der Schwerpunkt auf dem Frage-und-Antwort-Format liegt und gleichzeitig Goroutinen und parallele Dateidownloads hervorgehoben werden: **Option 1 (Fokus auf Goroutinen):**. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!