Concurrence Go et confusion des canaux
Problème
Un utilisateur essaie de comprendre la concurrence Go et les canaux en utilisant l'extrait de code suivant :
<code class="go">package main import "fmt" func display(msg string, c chan bool) { fmt.Println("display first message:", msg) c <- true } func sum(c chan bool) { sum := 0 for i := 0; i < 10000000000; i++ { sum++ } fmt.Println(sum) c <- true } func main() { c := make(chan bool) go display("hello", c) go sum(c) <-c }</code>
Le résultat attendu est uniquement "afficher le premier message : bonjour" car la fonction principale doit se terminer une fois qu'elle reçoit des données du canal. Cependant, la sortie réelle inclut également la somme de 10 milliards de nombres.
Réponse
Le principal problème du code est que le planificateur peut choisir librement entre les deux goroutines (affichage et somme) qui ne sont pas bloqués. Alors que le programmeur s'attend à ce que l'affichage se termine en premier et envoie les données au canal avant la fin de la somme, cela peut ne pas se produire en raison de la nature non déterministe du planificateur.
Dans un scénario d'exécution possible :
Pour résoudre ce problème et garantir que le message « Afficher le premier message : bonjour » est imprimé exclusivement, une approche consiste à utiliser un canal de résultat pour recevoir le message de l'affichage et terminer le programme immédiatement. La fonction principale modifiée serait :
<code class="go">func main() { result := make(chan string) go display("hello", result) fmt.Println(<-result) }</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!