É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 :
Utilisez la fonction make pour créer une chaîne, par exemple :
ch := make(chan int)
Utilisez le <-
opérateur pour envoyer ou recevoir sur la chaîne Des données, par exemple : <-
运算符向channel发送或接收数据,例如:
// 发送 ch <- 1 // 接收 x := <-ch
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") }
close
pour fermer la chaîne. La chaîne fermée ne peut plus être envoyée. 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.
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.
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.
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.
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!