Maison  >  Article  >  développement back-end  >  Comment puis-je créer des canaux Go pouvant accepter des valeurs de plusieurs types différents ?

Comment puis-je créer des canaux Go pouvant accepter des valeurs de plusieurs types différents ?

Linda Hamilton
Linda Hamiltonoriginal
2024-11-04 03:08:02793parcourir

How can I create Go channels that can accept values of multiple different types?

Canaux indépendants du type dans Go

Les canaux dans Go sont un puissant mécanisme de communication qui permet aux goroutines d'envoyer et de recevoir des données. Dans la plupart des cas, les canaux sont utilisés pour transmettre des valeurs d'un type spécifique. Cependant, il est possible de créer des canaux pouvant accepter plusieurs types différents.

Considérons l'exemple suivant :

<code class="go">package main

import (
    "fmt"
    "time"
)

func main() {
    ch := make(chan interface{})
    go func() {
        for {
            select {
            case p := <-ch:
                fmt.Printf("Received a %q\n", reflect.TypeOf(p).Name())
            case <-time.After(time.Second):
                fmt.Println("Empty Loop")
                return
            }
        }
    }()
    ch <- "Hello"
    time.Sleep(time.Second)
    ch <- 123
    time.Sleep(time.Second)
    ch <- struct{}{}
    time.Sleep(time.Second)
    ch <- []string{"Go", "programming"}
    time.Sleep(time.Second)
}</code>

Ce code crée un canal de type chan interface{} qui peut accepter n'importe quel type de valeur. Lorsque la goroutine reçoit une valeur sur le canal, elle utilise la réflexion pour déterminer le type de la valeur et l'imprime.

Vous pouvez également utiliser un commutateur de type pour gérer différents types de valeurs sur le canal, comme indiqué ci-dessous :

<code class="go">package main

import (
    "fmt"
    "reflect"
    "time"
)

func main() {
    ch := make(chan interface{})
    go func() {
        for {
            select {
            case p := <-ch:
                switch p := p.(type) {
                case string:
                    fmt.Printf("Got a string %q\n", p)
                case int:
                    fmt.Printf("Got an int %d\n", p)
                case struct{}:
                    fmt.Println("Got an empty struct")
                case []string:
                    fmt.Printf("Got a slice of strings %+v\n", p)
                default:
                    fmt.Printf("Type of p is %T. Value %v\n", p, p)
                }
            case <-time.After(time.Second):
                fmt.Println("Empty Loop")
                return
            }
        }
    }()
    ch <- "Hello"
    time.Sleep(time.Second)
    ch <- 123
    time.Sleep(time.Second)
    ch <- struct{}{}
    time.Sleep(time.Second)
    ch <- []string{"Go", "programming"}
    time.Sleep(time.Second)
}</code>

Cet exemple montre comment utiliser les commutateurs de type pour gérer différents types de valeurs sur un canal.

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