Maison > développement back-end > Golang > Mon Go Main Goroutine devrait-il dormir pour toujours ou s'arrêter gracieusement ?

Mon Go Main Goroutine devrait-il dormir pour toujours ou s'arrêter gracieusement ?

DDD
Libérer: 2024-12-18 14:16:15
original
538 Les gens l'ont consulté

Should My Go Main Goroutine Sleep Forever or Gracefully Quit?

Le dilemme principal de Goroutine : dormir ou arrêter ?

Les développeurs sont souvent confrontés au besoin de maintenir leur projet Go en permanence en cours d'exécution, ressemblant à une flamme éternelle qui ne s'éteint jamais. À l'inverse, il existe des cas où l'on souhaite terminer en douceur l'exécution du programme. Cet article explore les options disponibles pour ces scénarios.

"En veille" la goroutine principale

Pour rendre la goroutine principale dormante, il existe plusieurs constructions qui bloquent efficacement son exécution sans consommer des ressources CPU. Prenons les exemples suivants :

  • Sélection sans cas :

    select{}
    Copier après la connexion
  • Réception à partir d'un vide Chaîne :

    <-make(chan int)
    Copier après la connexion
  • Réception d'une chaîne nulle :

    <-(chan int)(nil)
    Copier après la connexion
  • Envoi vers un néant Chaîne :

    (chan int)(nil) <- 0
    Copier après la connexion
  • Verrouillage d'un mutex verrouillé :

    mu := sync.Mutex{}
    mu.Lock()
    mu.Lock()
    Copier après la connexion

Induction la Fin : Quitter la Goroutine

Si l'objectif est de fournir un moyen de résiliation, l’introduction d’un canal d’abandon est une approche viable. Au sein de la goroutine principale, le code peut attendre indéfiniment un signal provenant de ce canal. Lorsque le moment est venu, le canal de sortie peut être fermé :

var quit = make(chan struct{})

func main() {
    // Startup code...

    // Block until the quit signal arrives:
    <-quit
}

// In a separate goroutine, when termination is requested:
close(quit)
Copier après la connexion

Remarque : La fermeture du canal de sortie peut déclencher la fin immédiate du programme, conformément à la spécification d'exécution du programme Go.

Veille non bloquante

Dans les cas où la goroutine principale est bloquée n'est pas souhaitable, une alternative consiste à utiliser time.Sleep() avec une durée prolongée. La durée maximale autorisée est d'environ 292 ans :

time.Sleep(time.Duration(1<<63 - 1))
Copier après la connexion

Pour les programmes destinés à durer au-delà de cette durée, une boucle infinie peut être mise en place :

for {
    time.Sleep(time.Duration(1<<63 - 1))
}
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal