Maison développement back-end Golang Démarrage rapide de la programmation réseau : programmation simultanée en langage Go

Démarrage rapide de la programmation réseau : programmation simultanée en langage Go

Jun 18, 2023 am 10:01 AM
go语言 并发编程 网络编程

Démarrage rapide de la programmation réseau : programmation simultanée en langage Go

Avec le développement d'Internet, la programmation réseau est progressivement devenue l'une des compétences que les programmeurs doivent maîtriser. La programmation simultanée est un élément indispensable de la programmation réseau, en particulier dans les situations de forte concurrence. Le langage Go est un langage de programmation caractérisé par une programmation concurrente efficace, et son modèle de concurrence est plus simple et plus clair que les autres langages. Cet article présentera la programmation simultanée en langage Go pour aider les débutants à démarrer rapidement.

  1. Goroutine

Goroutine est un thread léger en langage Go. La concurrence en langage Go est implémentée via Goroutine. Chaque Goroutine peut exécuter différents codes simultanément, et la surcharge de Goroutine est très faible. Des dizaines de milliers de Goroutines peuvent être facilement ouvertes sans se soucier de la consommation de mémoire. L'utilisation de base de Goroutine est très simple. Ajoutez simplement le mot-clé go avant l'appel de fonction pour démarrer un Goroutine.

Par exemple, nous pouvons créer une Goroutine via le code suivant :

func main() {
    go printHello()
}

func printHello() {
    fmt.Println("Hello, world!")
}
Copier après la connexion

Dans le code ci-dessus, lorsque le programme Go s'exécute pour aller printHello(), il démarrera une nouvelle Goroutine pour exécuter la fonction printHello. Étant donné que la fonction printHello s'exécute indépendamment de la fonction principale, le programme affiche immédiatement "Bonjour tout le monde !"

  1. Channel

La communication entre les Goroutines se fait via Channel. Le canal peut être considéré comme un pipeline entre les Goroutines et peut être utilisé pour envoyer et recevoir des données. Channel in Go peut transmettre des données de manière synchrone et peut également être utilisé pour mettre en œuvre une programmation asynchrone. La création et l'utilisation de Channel sont également très simples. Utilisez simplement la fonction make pour le créer, puis utilisez l'opérateur <- pour envoyer et recevoir des données.

Par exemple, nous pouvons créer un canal et transmettre des données via le code suivant :

func main() {
    ch := make(chan int)
    go send(ch)
    fmt.Println(<-ch)
}

func send(ch chan int) {
    ch <- 1
}
Copier après la connexion

Dans le code ci-dessus, nous créons un canal entier et démarrons une Goroutine pour la transmission de données. La fonction principale bloque et attend que le canal transmette les données via l'instruction <-ch. Après avoir reçu les données, le programme affichera "1".

Channel peut être utilisé pour transmettre des données entre plusieurs Goroutines, évitant ainsi les problèmes de synchronisation qui doivent être pris en compte lors de l'utilisation de la mémoire partagée. De plus, la coordination et la synchronisation entre plusieurs Goroutines peuvent être réalisées via Channel, réalisant ainsi des tâches de programmation simultanées complexes.

  1. Select

Lors de la lecture de données de plusieurs canaux dans plusieurs Goroutines, vous pouvez utiliser la syntaxe de sélection dans le langage Go pour le traitement. La syntaxe de sélection est similaire à la syntaxe Switch. Elle peut surveiller l'interaction des données de plusieurs canaux. Lorsque des données apparaissent dans l'un des canaux, le bloc de code correspondant sera déclenché.

Par exemple, nous pouvons créer deux Goroutines via le code suivant et utiliser la syntaxe select pour traiter la lecture de Chanenl :

func main() {
    ch1 := make(chan int)
    ch2 := make(chan int)
    go func() {
        ch1 <- 1
    }()
    go func() {
        ch2 <- 2
    }()
    select {
        case x := <- ch1:
            fmt.Println("Received from ch1:", x)
        case x := <- ch2:
            fmt.Println("Received from ch2:", x)
    }
}
Copier après la connexion

Dans le code ci-dessus, nous créons deux Goroutines pour envoyer des données à deux canaux respectivement. Utilisez l'instruction select pour surveiller la transmission des données des deux canaux. Tant que l'un des canaux transmet des données, le bloc de code correspondant sera exécuté et les données reçues seront sorties.

  1. Mutex

Le langage Go prend en charge plusieurs threads pour accéder simultanément à la même variable Afin de résoudre le problème d'incohérence des données lors de l'écriture d'une variable en même temps, le langage Go fournit un mutex Mutex pour le verrouillage. Lorsque nous modifions la variable, nous ouvrons d'abord le verrou via la méthode Mutex.Lock(). À ce moment, un seul thread a obtenu le verrou, et les autres threads seront bloqués lorsqu'ils tenteront d'obtenir le verrou à ce moment-là ; Après avoir fini d'utiliser la variable, nous devons utiliser manuellement la méthode Mutex.Unlock() pour déverrouiller afin de libérer la ressource de verrouillage.

Par exemple, nous pouvons démontrer l'utilisation de Mutex à travers le code suivant :

import (
    "fmt"
    "sync"
    "time"
)

var wg sync.WaitGroup
var mutex sync.Mutex
var counter int

func main() {
  for i := 0; i < 10; i++ {
    wg.Add(1)
    go increment()
  }
  wg.Wait()
  fmt.Println("Final counter:", counter)
}

func increment() {
  mutex.Lock()
  defer mutex.Unlock()
  counter++
  time.Sleep(time.Second)
  fmt.Println("Counter value:", counter)
  wg.Done()
}
Copier après la connexion

Dans le code ci-dessus, nous créons 10 Goroutines, chaque Goroutine incrémentera la variable compteur de un. Afin de garantir l'exactitude des données, nous utilisons Mutex pour protéger le compteur. Appelez la méthode Mutex.Lock() dans Goroutine pour obtenir le verrou, puis appelez la méthode Mutex.Unlock() pour le déverrouiller après l'opération. Après avoir utilisé WaitGroup pour attendre la fin de toutes les exécutions de Goroutine, affichez la valeur finale du compteur.

Résumé

La programmation simultanée en langage Go utilise Goroutine et Channel pour la transmission de données, la synchronisation et la protection des variables via Mutex, et la lecture de plusieurs canaux via select. En utilisant ces mécanismes de manière rationnelle, nous pouvons écrire des programmes concurrents efficaces, clairs et faciles à maintenir qui jouent un rôle puissant dans les scénarios d’applications à forte concurrence.

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 de ce site Web
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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment convertir XML en PDF sur votre téléphone? Comment convertir XML en PDF sur votre téléphone? Apr 02, 2025 pm 10:18 PM

Il n'est pas facile de convertir XML en PDF directement sur votre téléphone, mais il peut être réalisé à l'aide des services cloud. Il est recommandé d'utiliser une application mobile légère pour télécharger des fichiers XML et recevoir des PDF générés, et de les convertir avec des API Cloud. Les API Cloud utilisent des services informatiques sans serveur et le choix de la bonne plate-forme est crucial. La complexité, la gestion des erreurs, la sécurité et les stratégies d'optimisation doivent être prises en compte lors de la gestion de l'analyse XML et de la génération de PDF. L'ensemble du processus nécessite que l'application frontale et l'API back-end fonctionnent ensemble, et il nécessite une certaine compréhension d'une variété de technologies.

Quel est le problème avec le fil de file d'attente dans GO's Crawler Colly? Quel est le problème avec le fil de file d'attente dans GO's Crawler Colly? Apr 02, 2025 pm 02:09 PM

Problème de threading de file d'attente dans Go Crawler Colly explore le problème de l'utilisation de la bibliothèque Crawler Crawler dans le langage Go, les développeurs rencontrent souvent des problèmes avec les threads et les files d'attente de demande. � ...

Quelles bibliothèques sont utilisées pour les opérations du numéro de point flottantes en Go? Quelles bibliothèques sont utilisées pour les opérations du numéro de point flottantes en Go? Apr 02, 2025 pm 02:06 PM

La bibliothèque utilisée pour le fonctionnement du numéro de point flottante dans le langage go présente comment s'assurer que la précision est ...

Dans Go, pourquoi les chaînes d'impression avec println et string () ont-elles des effets différents? Dans Go, pourquoi les chaînes d'impression avec println et string () ont-elles des effets différents? Apr 02, 2025 pm 02:03 PM

La différence entre l'impression de chaîne dans le langage go: la différence dans l'effet de l'utilisation de fonctions println et string () est en Go ...

Comment résoudre le problème de conversion de type user_id lors de l'utilisation du flux redis pour implémenter les files d'attente de messages dans le langage Go? Comment résoudre le problème de conversion de type user_id lors de l'utilisation du flux redis pour implémenter les files d'attente de messages dans le langage Go? Apr 02, 2025 pm 04:54 PM

Le problème de l'utilisation de Redessstream pour implémenter les files d'attente de messages dans le langage GO consiste à utiliser le langage GO et redis ...

Quelle est la différence entre la structure de définition des mots clés `var` et« type »dans le langage Go? Quelle est la différence entre la structure de définition des mots clés `var` et« type »dans le langage Go? Apr 02, 2025 pm 12:57 PM

Deux façons de définir les structures dans le langage GO: la différence entre les mots clés VAR et le type. Lorsque vous définissez des structures, GO Language voit souvent deux façons d'écrire différentes: d'abord ...

Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées? Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées? Apr 02, 2025 pm 05:09 PM

Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées? Lorsque vous utilisez Goland pour le développement du langage GO, de nombreux développeurs rencontreront des balises de structure personnalisées ...

Quelles bibliothèques de GO sont développées par de grandes entreprises ou fournies par des projets open source bien connus? Quelles bibliothèques de GO sont développées par de grandes entreprises ou fournies par des projets open source bien connus? Apr 02, 2025 pm 04:12 PM

Quelles bibliothèques de GO sont développées par de grandes entreprises ou des projets open source bien connus? Lors de la programmation en Go, les développeurs rencontrent souvent des besoins communs, ...

See all articles