Comment fonctionnent les threads et les coroutines en Golang
En langage Go (Golang), les threads et les coroutines sont des concepts très importants, et ce sont les composants de base de la programmation simultanée. Comprendre leur fonctionnement est important pour développer des programmes simultanés efficaces. Cet article explorera en profondeur les principes de fonctionnement des threads et des coroutines dans Golang et utilisera des exemples de code spécifiques pour aider les lecteurs à mieux comprendre.
1. Comment fonctionnent les threads
Dans les systèmes d'exploitation traditionnels, les threads sont les plus petites unités d'exécution, et chaque thread a sa propre pile d'exécution et son propre ensemble de registres. Les threads sont planifiés par le noyau du système d'exploitation. Un thread peut être considéré comme une séquence d'exécution indépendante et il peut exécuter plusieurs tâches simultanément.
Dans Golang, il existe un concept de Goroutine, qui est similaire aux threads, mais plus léger. Goroutine est géré par le système d'exécution du langage Go, qui enveloppe une fonction dans un thread léger. Les Goroutines sont exécutées simultanément et plusieurs Goroutines peuvent être exécutées simultanément dans un seul thread. Le moteur d'exécution du langage Go détermine comment planifier ces Goroutines.
Ce qui suit est un exemple simple qui montre comment créer et utiliser Goroutine dans Golang :
package main import ( "fmt" "time" ) func sayHello() { for i := 0; i < 5; i++ { fmt.Println("Hello") time.Sleep(1 * time.Second) } } func main() { go sayHello() // 启动一个新的Goroutine time.Sleep(3 * time.Second) fmt.Println("Main function") }
Dans le code ci-dessus, la fonction sayHello()
sera enveloppée dans une Goroutine et placée dans un nouveau Exécuté dans le fil de discussion. Dans la fonction principale, nous démarrons un nouveau Goroutine via go sayHello()
, puis la fonction principale continue son exécution. Après 3 secondes, la fonction principale imprime "Main function", et la fonction dans Goroutine continuera à imprimer "Bonjour" jusqu'à la fin de la boucle. sayHello()
函数会被包装成一个Goroutine并在一个新的线程中执行。在main函数中,我们通过go sayHello()
启动了一个新的Goroutine,然后main函数继续执行。在3秒后,main函数打印"Main function",而Goroutine中的函数会继续打印"Hello",直到循环结束。
二、协程的工作原理
在Golang中,协程(Coroutine)是一种轻量级、高效的并发处理方式。与线程不同的是,协程是在用户空间下实现的,并由开发者完全控制。协程可以看作是线程的子集,它的切换由程序员在代码中明确地控制。
协程在Golang中由channel
实现通信和同步。通过channel,不同的协程可以安全地互相通信,避免了共享内存的并发访问问题。下面是一个使用channel进行协程通信的示例:
package main import "fmt" func sendData(ch chan int) { ch <- 1 } func main() { ch := make(chan int) go sendData(ch) data := <-ch fmt.Println(data) }
在上面的代码中,我们创建了一个channel,并在sendData()
函数中向channel发送了一个整数,然后在主函数中通过
canal
. Grâce à des canaux, différentes coroutines peuvent communiquer entre elles en toute sécurité, évitant ainsi le problème de l'accès simultané à la mémoire partagée. Voici un exemple d'utilisation de canaux pour la communication coroutine : 🎜rrreee🎜Dans le code ci-dessus, nous créons un canal et envoyons un entier au canal dans la fonction sendData()
, puis dans Dans le principal fonction, les données sont reçues via et imprimées. Grâce aux opérations d'envoi et de réception du canal, les coroutines peuvent communiquer en toute sécurité, réalisant ainsi la collaboration et la synchronisation entre les coroutines. 🎜🎜Résumé : 🎜🎜Dans Golang, les threads et les coroutines sont des composants importants pour réaliser une programmation simultanée. Les threads sont planifiés par le noyau du système d'exploitation et les Goroutines sont des threads légers gérés par le runtime du langage Go. Les coroutines sont une méthode de traitement simultanée légère contrôlée par les développeurs. Grâce à des exemples de code spécifiques, nous pouvons mieux comprendre les principes de fonctionnement des threads et des coroutines dans Golang. J'espère que cet article pourra aider les lecteurs à mieux comprendre et appliquer la programmation simultanée. 🎜
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!