Wenn die Haupt- oder übergeordnete Goroutine in einem Go-Programm beendet wird, stehen unvollendete Goroutinen vor einem abrupten Ende. Das gesamte Laufzeitsystem wird heruntergefahren, so dass kein Platz zum Weiterlaufen, Warten oder Abbrechen bleibt. Dieses Phänomen kann damit verglichen werden, dass sich Flash-Papier entzündet und sofort verschwindet.
Im angegebenen Codeausschnitt aus dem Go-Programmierbuch werden die beiden langsamen Goroutinen nach der Rückkehr von MirroredQuery nicht mehr existieren, wenn die Haupt-Goroutine beendet wird sofort, unabhängig von ihrem aktuellen Zustand. Dies kann als Goroutine-Leck angesehen werden, aber da der gesamte Prozess beendet wird, werden die zugewiesenen Ressourcen automatisch bereinigt.
Wenn die Haupt-Goroutine jedoch nach der Rückkehr von MirroredQuery noch läuft, werden die unvollendeten Goroutinen bis dahin weiter ausgeführt Sie:
In diesem Fall senden sie ihre Antworten an den Kanal und kehren dann zurück. Sobald alle Goroutinen zurückgekehrt sind, speichert der Kanal die Antworten als geringfügiges Ressourcenleck. Da jedoch keine Verweise mehr auf den Kanal vorhanden sind, wird er schließlich zusammen mit den darin enthaltenen Zeichenfolgen in den Garbage Collection-Speicher verschoben.
Die Verwendung eines gepufferten Kanals in dieser Situation stellt sicher, dass die Goroutinen nicht blockieren und weiterlaufen, bis sie ausgeführt werden können ihre Aufgaben erledigen. Im Falle eines ungepufferten Kanals würden die verlorenen Goroutinen blockieren, was dazu führen würde, dass der Kanal und seine Ressourcen auf unbestimmte Zeit zugewiesen bleiben.
Das obige ist der detaillierte Inhalt vonWas passiert mit unvollendeten Goroutinen, wenn ihre übergeordnete Goroutine beendet wird?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!