Golang prend en charge le multi-threading. Golang dispose d'un mécanisme de concurrence léger appelé "goroutine". Il fournit également un mécanisme de communication "canal" qui peut être utilisé pour la communication entre les threads.
Le système d'exploitation de ce tutoriel : système Windows 10, version Go1.20.1, ordinateur Dell G3.
golang prend en charge le multi-threading. Golang dispose d'un mécanisme de concurrence léger appelé « goroutine », et fournit également un mécanisme de communication « canal » qui peut être utilisé pour la communication entre les threads.
Goroutine est un thread léger (coroutine) géré par la bibliothèque d'exécution du langage Go. Il est différent des threads du système d'exploitation et peut être exécuté sur un seul thread du système d'exploitation et peut utiliser le processeur efficacement. Vous pouvez créer une nouvelle goroutine en ajoutant go avant le mot-clé go, par exemple :
go func() { // some code here }()
Goroutine est très approprié pour gérer des tâches simultanées et asynchrones, telles que des requêtes réseau, des opérations d'E/S, ou lors de l'exécution de tâches gourmandes en calcul. pour éviter de bloquer l’intégralité du programme. De plus, Goroutine peut également aider à mettre en œuvre des modèles de concurrence, tels que la mise en œuvre de files d'attente basées sur le modèle producteur-consommateur, ou la décomposition des tâches via plusieurs Goroutines pour la compression de fichiers.
Channel est le mécanisme de communication inter-thread fourni par Golang, qui peut transférer en toute sécurité des données entre Goroutines. En créant un canal, plusieurs Goroutines peuvent s'envoyer et recevoir des données. Lorsqu'un Goroutine souhaite envoyer des données au canal, il copiera les données sur le canal ; lorsqu'un autre Goroutine aura besoin de recevoir des données du canal, il copiera les données du canal dans son propre espace mémoire.
Voici un exemple montrant comment utiliser goroutine et canal :
package main import "fmt" func worker(id int, jobs <-chan int, results chan<- int) { for j := range jobs { fmt.Println("worker", id, "processing job", j) results <- j * 2 } } func main() { jobs := make(chan int, 100) results := make(chan int, 100) // 创建3个goroutine并行处理jobs for w := 1; w <= 3; w++ { go worker(w, jobs, results) }
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!