Opérations Non Bloquantes Sur Les Canaux

Opérations non-bloquantes sur les canaux #

// Les envois et receptions basiques sur les canaux
// sont bloquants.
// Cependant, on peut utilise `select` avec une clause
// `default` pour implémenter des envois et réceptions
// _non bloquants_, et même des `select` non bloquants
// sur plusieurs canaux.

package main

import "fmt"

func main() {
    messages := make(chan string)
    signals := make(chan bool)

    // Voici une réception non bloquante. Si une valeur
    // est disponible sur `messages`, alors `select` va
    // prendre le cas `<-messages` avec cette valeur.
    // Si non, il prendra immédiatement le cas `default`.
    select {
    case msg := <-messages:
        fmt.Println("received message", msg)
    default:
        fmt.Println("no message received")
    }

    // Un envoi non bloquand marche de manière similaire.
    msg := "hi"
    select {
    case messages <- msg:
        fmt.Println("sent message", msg)
    default:
        fmt.Println("no message sent")
    }

    // On peut utiliser plusieurs `case` au dessus de
    // la clause `default` pour implémenter un select non
    // bloquant multiple. Ici, on essaye de recevoir des
    // messages de manière non bloquante sur les canaux
    // `messages` et `signals` simultanément.
    select {
    case msg := <-messages:
        fmt.Println("received message", msg)
    case sig := <-signals:
        fmt.Println("received signal", sig)
    default:
        fmt.Println("no activity")
    }
}
$ go run non-blocking-channel-operations.go 
no message received
no message sent
no activity