Maison  >  Article  >  développement back-end  >  Compétences en programmation asynchrone en langage Go

Compétences en programmation asynchrone en langage Go

WBOY
WBOYoriginal
2023-06-01 14:21:061270parcourir

En tant que langage de programmation moderne, le langage Go offre de puissantes capacités de programmation asynchrone, permettant aux programmeurs de gérer des tâches simultanées de manière plus efficace. Cet article présentera les techniques de programmation asynchrone en langage Go, notamment les coroutines, les pipelines, les minuteries et la gestion des erreurs.

  1. Coroutine

Coroutine en langage Go est un thread léger qui peut exécuter plusieurs fonctions simultanément dans le même processus. L'utilisation de coroutines peut éviter des problèmes tels que la concurrence entre les ressources et les verrous causés par la concurrence multithread. La méthode de création d'une coroutine est très simple, il suffit d'ajouter le mot-clé go avant la fonction.

Exemple de code :

func main() {
    go func() {
        fmt.Println("Hello, world!")
    }()
    // 等待协程执行完毕
    time.Sleep(time.Second)
}

Dans le code ci-dessus, nous créons une fonction anonyme et ajoutons le mot-clé go avant la fonction pour créer une coroutine. Étant donné que la coroutine est exécutée de manière asynchrone, dans la fonction principale, nous devons utiliser la méthode Sleep fournie par le package time pour attendre que la coroutine termine son exécution.

  1. Pipeline

Pipeline (canal) en langage Go est un moyen important de communication entre les coroutines. Grâce à des tuyaux, différentes coroutines peuvent transférer des données en toute sécurité et éviter les problèmes causés par l'utilisation de technologies de synchronisation telles que les verrous multi-threads.

Les pipelines peuvent être créés via la fonction make et spécifier le type et la capacité.

Exemple de code :

func main() {
    ch := make(chan int, 1)
    go func() {
        ch <- 1
    }()
    val := <-ch
    fmt.Println(val)
}

Dans le code ci-dessus, nous créons un tube entier d'une capacité de 1 et envoyons une valeur au tube dans la coroutine. La fonction principale reçoit la valeur du tube via l'opérateur < et génère le résultat.

  1. Timer

Le timer (timer) du langage Go peut être utilisé pour exécuter régulièrement une certaine fonction ou opération, et utilise également des coroutines pour réaliser une exécution asynchrone. Dans la bibliothèque standard du langage Go, des minuteries peuvent être créées via les fonctions NewTimer ou After fournies par le package time. Parmi eux, NewTimer nécessite une réinitialisation manuelle de la minuterie, tandis que la fonction After ne nécessite pas d'opération manuelle.

Exemple de code :

func main() {
    timer := time.NewTimer(2 * time.Second)
    <-timer.C
    fmt.Println("Hello, world!")
}

Dans le code ci-dessus, nous créons une minuterie de 2 secondes et utilisons l'opérateur <- pour lire la notification du canal C de la minuterie. Lorsque la minuterie expire, le programme Hello, world ! sera émis.

  1. Gestion des erreurs

Dans le langage Go, la gestion des erreurs est un élément très important pour éviter les plantages du programme ou les problèmes de sécurité lors de la gestion des exceptions. Dans la programmation asynchrone, il faut prêter attention à la livraison et à la gestion des erreurs.

Exemple de code :

func main() {
    result, err := doSomething()
    if err != nil {
        log.Fatal(err)
    }
    fmt.Println(result)
}

func doSomething() (int, error) {
    return 0, errors.New("error occurred")
}

Dans le code ci-dessus, nous définissons une fonction doSomething pour démontrer la gestion des erreurs. Après avoir exécuté la fonction dans la fonction principale, vérifiez les informations d'erreur dans la valeur de retour. Si elle n'est pas vide, affichez les informations d'erreur et terminez le programme.

Résumé

Cet article présente les techniques de programmation asynchrone en langage Go, notamment les coroutines, les pipelines, les minuteries et la gestion des erreurs. En apprenant ces techniques, les programmeurs peuvent gérer plus efficacement les tâches simultanées et améliorer les performances et la stabilité du programme. Si vous n'avez pas encore essayé la programmation asynchrone, vous pouvez suivre l'exemple de code dans cet article pour en faire l'expérience maintenant !

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!

Déclaration:
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