Maison >développement back-end >Golang >Étude approfondie de la technologie de programmation simultanée Select Channels Go dans Golang

Étude approfondie de la technologie de programmation simultanée Select Channels Go dans Golang

WBOY
WBOYoriginal
2023-09-28 22:49:52722parcourir

深入研究golang中的Select Channels Go并发式编程技术

Étude approfondie de la technologie de programmation simultanée Select Channels Go dans Golang

Introduction :
Le langage Go (Golang) a attiré l'attention et l'utilisation de plus en plus de développeurs grâce à ses excellentes performances de concurrence et son style de syntaxe concis. Golang fournit de nombreuses fonctionnalités et outils pour la programmation simultanée, dont la sélection et les canaux sont l'une des parties les plus importantes et les plus puissantes. Cet article se penchera sur la technologie de programmation simultanée de certains canaux dans Golang et fournira des exemples de code spécifiques pour aider les lecteurs à mieux comprendre et appliquer cette technologie.

1. Introduction aux canaux en Golang
Le canal est un type spécial utilisé pour la communication entre les goroutines dans la langue Golang. En utilisant des canaux, nous pouvons transmettre des messages et partager des données entre différentes coroutines. Dans Golang, un canal peut être sans tampon (pas de mise en mémoire tampon) ou tamponné (bufferisé). Les canaux sans tampon ne peuvent terminer la communication que lorsque les opérations d'envoi et de réception sont prêtes en même temps. Cette méthode garantit la livraison synchrone des messages. Un canal mis en mémoire tampon peut terminer l'opération d'envoi lorsque le tampon n'est pas plein et terminer l'opération de réception lorsque le tampon n'est pas vide. Cette forme peut réaliser une communication asynchrone.

Lors de l'utilisation des chaînes, nous devons prêter une attention particulière aux points suivants :

  1. Utilisez la fonction make pour créer une chaîne, par exemple :

    ch := make(chan int)
  2. Utilisez le <- opérateur pour envoyer ou recevoir sur la chaîne Des données, par exemple : <- 运算符向channel发送或接收数据,例如:

    // 发送
    ch <- 1
    // 接收
    x := <-ch
  3. 使用 close
    ch1 := make(chan int)
    ch2 := make(chan int)
    go func() {
        ch1 <- 1
    }()
    go func() {
        ch2 <- 2
    }()
    select {
        case <-ch1:
            fmt.Println("Received from ch1")
        case <-ch2:
            fmt.Println("Received from ch2")
    }
Utilisez la fonction close pour fermer la chaîne. La chaîne fermée ne peut plus être envoyée.


2. Comprendre l'application des instructions select en simultanéité

Semblable aux instructions switch, mais l'instruction select utilisée pour les canaux peut avoir pour effet d'exécuter quelle branche lorsque le canal est prêt, ce qui la rend très appropriée pour la programmation simultanée. Voici un exemple simple d'utilisation de select :

ch := make(chan int)
timeout := time.After(3 * time.Second)
select {
    case <-ch:
        fmt.Println("Received data from channel")
    case <-timeout:
        fmt.Println("Timeout")
}

Dans cet exemple, nous créons deux canaux et envoyons un message à chaque canal. Dans l'instruction select, selon lequel des deux canaux est prêt en premier, le programme affichera les informations correspondantes.

3. Utilisez des instructions select pour gérer les opérations de délai d'attente

En programmation simultanée, nous rencontrons souvent la situation d'attendre qu'une opération soit terminée. Si le temps d'attente est trop long, cela peut affecter les performances de l'ensemble du programme. Afin de résoudre ce problème, vous pouvez utiliser l'instruction select combinée avec le timer dans le package time pour implémenter une opération de délai d'attente. Voici un exemple simple :

ch1 := make(chan int)
ch2 := make(chan int)
go func() {
    time.Sleep(1 * time.Second)
    ch1 <- 1
}()
go func() {
    time.Sleep(2 * time.Second)
    ch2 <- 2
}()
select {
    case <-ch1:
        fmt.Println("Received data from ch1")
    case <-ch2:
        fmt.Println("Received data from ch2")
}

Dans cet exemple, nous créons un délai d'attente et le définissons sur un délai d'expiration après 3 secondes. Écoutez ensuite les deux événements de canal et de délai d'attente via l'instruction select. Si les données sont reçues du canal dans les 3 secondes, la branche correspondante sera traitée, sinon la branche de délai d'attente sera déclenchée.

4. Instruction Select pour implémenter le multiplexage

Dans la programmation simultanée, nous rencontrons souvent des situations où nous devons surveiller plusieurs canaux en même temps, dans ce cas, nous pouvons utiliser l'instruction select pour implémenter le multiplexage. Voici un exemple d'utilisation de select pour implémenter le multiplexage :

ch1 := make(chan int)
ch2 := make(chan int)
timeout := time.After(2 * time.Second)
select {
    case <-ch1:
        fmt.Println("Received data from ch1")
    case <-ch2:
        fmt.Println("Received data from ch2")
    case <-timeout:
        fmt.Println("Timeout")
}

Dans cet exemple, nous créons deux canaux et envoyons des données aux deux canaux dans deux coroutines. Dans l'instruction select, tant qu'un canal est prêt, la branche correspondante peut être exécutée. Étant donné que les données de ch2 sont envoyées plus tard que celles de ch1, les « Données reçues de ch2 » seront affichées dans le programme.

5. Implémenter le multiplexage avec timeout

Sur la base du contenu précédent, nous pouvons combiner l'instruction select et le timer pour implémenter le multiplexage avec timeout. Voici un exemple :

rrreee

Dans cet exemple, nous créons un timeout timeout avec un timeout de 2 secondes. Ensuite, l'instruction select est utilisée pour surveiller les trois événements ch1, ch2 et timeout en même temps. Quel que soit celui qui est prêt en premier, le programme exécutera la branche correspondante. Si aucune donnée n'est reçue dans les 2 secondes, la branche timeout est déclenchée.

6. Conclusion 🎜 Cet article mène une étude approfondie de la technologie de programmation simultanée de certains canaux dans Golang et fournit quelques exemples de code spécifiques, dans l'espoir d'aider les lecteurs à mieux comprendre et appliquer cette technologie. L'utilisation de select et de canaux peut facilement réaliser une transmission synchrone et asynchrone de données, améliorant ainsi les performances de concurrence et la lisibilité du programme. Si les lecteurs rencontrent des difficultés dans la pratique, ils peuvent déboguer et vérifier sur la base des exemples de code fournis dans cet article. Je pense qu'ils auront une bonne expérience d'apprentissage et d'utilisation. 🎜

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