Comment attendre gracieusement la fin des routines Go ?
Dec 07, 2024 pm 04:34 PMComment attendre gracieusement la fin des routines Go
Dans Go, la concurrence est obtenue grâce aux goroutines, qui sont des threads légers qui s'exécutent simultanément avec la routine principale. Pour garantir que le programme ne se termine pas avant que toutes les goroutines n'aient terminé leurs tâches, il est crucial d'attendre correctement qu'elles se terminent.
Utiliser un canal pour signaler l'achèvement
Une approche courante pour attendre les goroutines consiste à utiliser un canal booléen. Lorsqu'une goroutine termine sa tâche, elle envoie une vraie valeur au canal, et la routine principale attend cette valeur en recevant du canal.
func do_stuff(done chan bool) { fmt.Println("Doing stuff") done <- true } func main() { fmt.Println("Main") done := make(chan bool) go do_stuff(done) <-done }
Pourquoi <-done fonctionne-t-il ?
<-done est une opération de réception bloquante. Cela signifie que la routine principale attendra qu'une valeur soit envoyée au canal terminé. Puisque la goroutine do_stuff envoie explicitement une vraie valeur au canal lorsqu'elle est terminée, la routine principale la recevra et continuera l'exécution.
Que se passe-t-il si nous décommentons la dernière ligne ?
Si nous décommentons la dernière ligne, nous obtenons une erreur de blocage car le canal est vide et aucune autre goroutine ne lui envoie de valeurs. Par conséquent, la routine principale attendra indéfiniment qu'une valeur soit reçue, ce qui entraînera un blocage.
Approche alternative utilisant le package de synchronisation
Pour les scénarios de concurrence plus complexes, la synchronisation Le package fournit des mécanismes de synchronisation pratiques. Par exemple, si vous devez paralléliser une série de fonctions de longue durée, l'extrait de code suivant montre comment utiliser le type sync.WaitGroup :
package main import ( "fmt" "sync" "time" ) func main() { var wg sync.WaitGroup for i := 0; i < 10; i++ { wg.Add(1) go func() { longOp() wg.Done() }() } // will wait until wg.Done is called 10 times // since we made wg.Add(1) call 10 times wg.Wait() } func longOp() { time.Sleep(time.Second * 2) fmt.Println("long op done") }
Dans cet exemple, WaitGroup garantit que la routine principale ne se termine pas tant que tous les goroutines n'ont pas appelé wg.Done.
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!

Article chaud

Outils chauds Tags

Article chaud

Tags d'article chaud

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

GO Language Pack Import: Quelle est la différence entre le soulignement et sans soulignement?

Comment mettre en œuvre le transfert d'informations à court terme entre les pages du cadre Beego?

Comment écrire des objets et des talons simulés pour les tests en Go?

Comment puis-je utiliser des outils de traçage pour comprendre le flux d'exécution de mes applications GO?

Comment convertir la liste des résultats de la requête MySQL en une tranche de structure personnalisée dans le langage Go?

Comment puis-je définir des contraintes de type personnalisé pour les génériques en Go?

Comment écrire des fichiers dans GO Language de manière pratique?

Comment rédiger des repères qui reflètent avec précision les performances du monde réel en Go?
