Maison >développement back-end >Golang >time.Sleep bloque-t-il une goroutine dans Go ?
Introduction
Le package time dans Go fournit diverses fonctions liées au temps, y compris time.Sleep, qui suspend l'exécution d'une goroutine pendant une durée spécifiée. Cette question explore si time.Sleep bloque réellement une goroutine et examine le comportement du planificateur Go lorsque les goroutines utilisent time.Sleep.
Explication
Selon les informations fournies réponse, temps. Le sommeil bloque en effet une goroutine. Cependant, il est important de noter que la notion de « blocage » dans Go n’est pas strictement définie. Dans ce contexte, « blocage » signifie que l'exécution de l'instruction suivante ne peut pas avoir lieu immédiatement car l'instruction en cours est toujours en cours.
Planification des goroutines
Les goroutines sont planifiées sur les threads par le planificateur Go. Le planificateur suit le « modèle MPG », où P représente le nombre de processeurs, M représente le nombre de threads du système d'exploitation et G représente le nombre de goroutines. Lorsqu'une goroutine est bloquée, le planificateur la détache de son M actuel et trouve un M inactif sur lequel la planifier ou crée un nouveau M si nécessaire.
Observation du nombre de threads
L'observation selon laquelle le nombre de threads augmente lorsque la valeur de n augmente est une conséquence du comportement du planificateur. Au fur et à mesure que de nouvelles goroutines sont créées, le planificateur crée des threads M supplémentaires pour les gérer. Cependant, le fait que seul un nombre limité de threads supplémentaires soit créé est dû à la capacité du planificateur à déterminer que toutes les goroutines ne nécessitent pas de threads séparés.
Comparaison avec Real IO
L'exemple fourni utilisant de vraies IO (ioutil.WriteFile) illustre que lorsque les goroutines effectuent des opérations de blocage qui impliquent des ressources système réelles, telles que IO, le nombre de threads créés est nettement plus élevé. En effet, le planificateur ne peut pas éviter de créer des threads pour gérer ces opérations de blocage.
Conclusion
Bien que time.Sleep bloque les goroutines, il est de la responsabilité du planificateur de gérer efficacement le mappage des goroutines aux threads. Les développeurs n'ont pas à se soucier des spécificités du comportement du planificateur et peuvent compter sur le runtime Go pour gérer ces problèmes efficacement.
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!