Comprendre les blocages dans Go simultané : canal sans tampon au sein d'une Goroutine
Dans le modèle de concurrence de Go, les canaux sont un outil crucial pour la communication entre les goroutines. Cependant, une utilisation inappropriée des canaux peut entraîner des blocages, comme illustré dans cet extrait de code :
package main import "fmt" func main() { c := make(chan int) c <- 1 fmt.Println(<-c) }
Une fois exécuté, ce code entraîne un blocage avec le message d'erreur suivant :
fatal error: all goroutines are asleep - deadlock!
Pourquoi ce blocage se produit-il ?
Le problème réside dans l'utilisation d'un canal sans tampon au sein du même goroutine. Les canaux sans tampon n'ont pas de stockage interne, ce qui signifie que l'envoi d'une valeur à un canal sans tampon est bloqué jusqu'à ce qu'un autre goroutine lise la valeur.
Dans ce cas, le goroutine envoie une valeur au canal c et tente de recevoir une valeur du canal c. même canal de manière séquentielle. Puisqu'il n'y a pas d'autre goroutine pour recevoir la valeur, la goroutine de l'expéditeur se bloque indéfiniment, ce qui entraîne un blocage.
Comment pouvez-vous y remédier ?
Il existe deux solutions :
c := make(chan int, 1)
Cela crée un canal avec une taille de tampon de 1, permettant de stocker une valeur sans blocage.
package main import "fmt" func main() { c := make(chan int) go func() { c <- 1 }() fmt.Println(<-c) }
Dans cet exemple, la goroutine de l'expéditeur envoie une valeur au canal c de manière asynchrone. La goroutine principale reçoit ensuite la valeur du canal sans rencontrer de blocage.
Comprendre le comportement des canaux sans tampon et éviter une utilisation inappropriée est essentiel pour écrire des programmes Go simultanés efficaces et non bloquants.
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!