Maison >développement back-end >Golang >Pourquoi mon code de concurrence Go s'imprime-t-il 6 six fois au lieu de 1 à 5 ?
Go Concurrency : Explorer le comportement surprenant d'une fonction anonyme dans une boucle for
Dans cette exploration, nous mettrons en lumière un phénomène inattendu comportement présenté par la concurrence Go lors de l'utilisation d'une boucle for et anonyme fonctions.
Problème :
Imaginez exécuter l'extrait de code suivant pour tester la concurrence à l'aide de sync.WaitGroup :
func main() { var wg sync.WaitGroup for i := 1; i <= 5; i++ { wg.Add(1) go func() { fmt.Println(i) time.Sleep(time.Second * 1) wg.Done() }() } wg.Wait() }
Étonnamment, le résultat observé était : 6, 6, 6, 6, 6, au lieu de la séquence anticipée : 1, 2, 3, 4, 5.
Explication :
Pour comprendre ce comportement, nous nous référons à la FAQ Go sur "Que se passe-t-il avec les fermetures exécutées en tant que goroutines ?". Dans ce scénario, les goroutines n'étaient planifiées qu'après la fin de la boucle for. Par conséquent, à ce stade, j'étais avancé à 6. Lorsque les goroutines se sont exécutées, elles ont toutes imprimé la valeur capturée de i, qui était 6.
Passer i comme argument à la fonction anonyme a effectivement créé une copie de la valeur actuelle, capturant la valeur au moment de l'appel. Ceci explique le comportement attendu observé dans la version modifiée du code.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!