Maison >développement back-end >Golang >Développement Golang : Maîtriser la programmation concurrente basée sur le passage de messages

Développement Golang : Maîtriser la programmation concurrente basée sur le passage de messages

WBOY
WBOYoriginal
2023-09-20 12:49:58511parcourir

Développement Golang : Maîtriser la programmation concurrente basée sur le passage de messages

Développement Golang : Maîtriser la programmation concurrente basée sur le passage de messages nécessite des exemples de code spécifiques

Introduction :
Golang, en tant que langage de programmation efficace et concis, fournit de riches fonctionnalités de programmation concurrente, parmi lesquelles la programmation concurrente basée sur le passage de messages fait partie de sa singularité. Dans cet article, nous discuterons en détail de la programmation simultanée basée sur la transmission de messages dans Golang et donnerons des exemples de code spécifiques pour aider les lecteurs à mieux comprendre et maîtriser cette technologie.

1. Qu'est-ce que la programmation concurrente basée sur la transmission de messages ?
Dans la programmation concurrente traditionnelle, les threads du programme utilisent la mémoire partagée pour communiquer, ce qui peut facilement entraîner des problèmes tels que des blocages et des conditions de concurrence. La programmation concurrente basée sur la transmission de messages utilise des messages pour communiquer entre différents threads. Les threads sont relativement indépendants et évitent le problème de la mémoire partagée.

Dans Golang, la programmation concurrente basée sur la transmission de messages repose principalement sur la goroutine et le canal. Une goroutine est un thread léger qui peut être géré par le planificateur d'exécution Go. Le canal est une structure de données utilisée pour transférer des messages entre goroutines.

2. Utilisez des canaux pour transmettre des messages
Dans Golang, en créant des objets de canal, les messages peuvent être transmis entre différentes goroutines. Voici un exemple de code simple qui montre comment utiliser les canaux pour transmettre des messages :

func main() {
    // 创建一个int类型的channel
    ch := make(chan int)
    
    // 启动一个goroutine发送消息
    go func() {
        ch <- 1
    }()
    
    // 接收goroutine发送的消息
    num := <-ch
    fmt.Println(num)
}

Dans l'exemple ci-dessus, un objet canal de type int est d'abord créé. Ensuite, utilisez ch dans une nouvelle goroutine pour envoyer un message au canal. Enfin, recevez le message du canal via l'instruction <code>num := et imprimez-le. <code>ch。接下来,在一个新的goroutine中使用ch 向channel发送消息。最后,通过<code>num := 语句从channel中接收消息,并将其打印出来。

三、channel的阻塞和非阻塞操作
在使用channel进行消息传递时,有两种基本的操作方式:阻塞和非阻塞。

阻塞操作是指当channel中没有消息可用时,接收操作会一直阻塞,直到有消息可用。同样地,发送操作也会阻塞直到有接收者接收消息。

非阻塞操作是指当channel中没有消息可用时,接收操作会立即返回一个空值。发送操作则会在channel已满时立即返回一个错误。

下面是一个示例代码,展示了如何使用阻塞和非阻塞操作:

func main() {
    ch := make(chan int, 1)
    ch <- 1 // 向channel发送消息
    
    // 阻塞操作
    num := <-ch
    fmt.Println(num)
    
    // 非阻塞操作
    select {
    case num := <-ch:
        fmt.Println(num)
    default:
        fmt.Println("channel中没有消息可用")
    }
}

在上述示例中,首先创建了一个有缓冲区大小为1的channel对象,并向其发送了一个消息。接下来,通过接收操作和非阻塞的选择语句来展示阻塞和非阻塞操作的效果。

四、使用select语句进行多路复用
Golang中的select语句提供了一种方式,可以从多个channel中选择一个可用的channel进行操作。下面是一个示例代码,展示了如何使用select语句进行多路复用:

func main() {
    ch1 := make(chan int)
    ch2 := make(chan int)
    
    go func() {
        ch1 <- 1
    }()
    
    go func() {
        ch2 <- 2
    }()
    
    // 使用select语句选择可用的channel
    select {
    case num := <-ch1:
        fmt.Println(num)
    case num := <-ch2:
        fmt.Println(num)
    }
}

在上述示例中,首先创建了两个不同的channel对象ch1ch2。然后分别向ch1ch2

3. Opérations de blocage et de non-blocage des canaux

Lors de l'utilisation de canaux pour la transmission de messages, il existe deux méthodes de fonctionnement de base : le blocage et le non-blocage.

L'opération de blocage signifie que lorsqu'aucun message n'est disponible dans le canal, l'opération de réception se bloquera jusqu'à ce qu'un message soit disponible. De même, les opérations d'envoi bloquent jusqu'à ce qu'un destinataire reçoive le message.

L'opération non bloquante signifie que lorsqu'aucun message n'est disponible dans le canal, l'opération de réception renverra immédiatement une valeur nulle. L'opération d'envoi renverra une erreur immédiatement lorsque le canal est plein.

Voici un exemple de code qui montre comment utiliser les opérations bloquantes et non bloquantes :
    rrreee
  1. Dans l'exemple ci-dessus, un objet canal avec une taille de tampon de 1 est d'abord créé et un message lui est envoyé. Ensuite, les effets des opérations bloquantes et non bloquantes sont démontrés par le biais d'opérations de réception et d'instructions de sélection non bloquantes.
  2. 4. Utilisez les instructions select pour le multiplexage
  3. L'instruction select dans Golang fournit un moyen de sélectionner un canal disponible parmi plusieurs canaux pour l'exploitation. Vous trouverez ci-dessous un exemple de code qui montre comment utiliser les instructions select pour le multiplexage :
rrreee🎜Dans l'exemple ci-dessus, deux objets de canal différents ch1 et ch2 sont d'abord du code créé>. Envoyez ensuite des messages à ch1 et ch2 respectivement. Enfin, sélectionnez les canaux disponibles à l'aide de l'instruction select et imprimez le message correspondant. 🎜🎜5. Résumé🎜Cet article présente les concepts et les fonctionnalités de la programmation simultanée basée sur la transmission de messages dans Golang et donne des exemples de code spécifiques. En utilisant goroutine et canal pour implémenter la transmission de messages, des opérations concurrentes relativement indépendantes sont réalisées entre plusieurs goroutines. Dans le même temps, grâce à l'utilisation d'opérations bloquantes et non bloquantes et d'instructions de sélection, la flexibilité et la maintenabilité de la programmation simultanée sont encore améliorées. 🎜🎜J'espère que grâce à l'introduction de cet article, les lecteurs pourront mieux comprendre et maîtriser la programmation simultanée basée sur le passage de messages dans Golang, tirer pleinement parti des avantages de la programmation simultanée Golang et améliorer les performances et la fiabilité du programme. 🎜🎜Matériel de référence : 🎜🎜🎜Documentation officielle de Golang (https://golang.org/doc/) 🎜🎜Go pratique de la programmation simultanée (https://www.imooc.com/learn/927)🎜🎜

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