recherche
Maisondéveloppement back-endGolangDé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

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!")
}

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

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
}

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

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)
    }
}

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()
}

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
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
Golang vs Python: concurrence et multithreadingGolang vs Python: concurrence et multithreadingApr 17, 2025 am 12:20 AM

Golang convient plus à des tâches de concurrence élevées, tandis que Python présente plus d'avantages dans la flexibilité. 1. Golang gère efficacement la concurrence par le goroutine et le canal. 2. Python repose sur le filetage et l'asyncio, qui est affecté par GIL, mais fournit plusieurs méthodes de concurrence. Le choix doit être basé sur des besoins spécifiques.

Golang et C: les compromis en performanceGolang et C: les compromis en performanceApr 17, 2025 am 12:18 AM

Les différences de performance entre Golang et C se reflètent principalement dans la gestion de la mémoire, l'optimisation de la compilation et l'efficacité du temps d'exécution. 1) Le mécanisme de collecte des ordures de Golang est pratique mais peut affecter les performances, 2) la gestion manuelle de C et l'optimisation du compilateur sont plus efficaces dans l'informatique récursive.

Golang vs Python: applications et cas d'utilisationGolang vs Python: applications et cas d'utilisationApr 17, 2025 am 12:17 AM

ChooseGolangForHighPerformanceAnd Concurrence, IdealForBackendServices andNetworkProgramming; selectPythonForrapidDevelopment, dataScience et MachineLearningDuetOtsSertilityAnStensiveLibrarary.

Golang vs Python: différences et similitudes clésGolang vs Python: différences et similitudes clésApr 17, 2025 am 12:15 AM

Golang et Python ont chacun leurs propres avantages: Golang convient aux performances élevées et à la programmation simultanée, tandis que Python convient à la science des données et au développement Web. Golang est connu pour son modèle de concurrence et ses performances efficaces, tandis que Python est connu pour sa syntaxe concise et son écosystème de bibliothèque riche.

Golang vs Python: Courbe de facilité d'utilisation et d'apprentissageGolang vs Python: Courbe de facilité d'utilisation et d'apprentissageApr 17, 2025 am 12:12 AM

Dans quels aspects Golang et Python sont-ils plus faciles à utiliser et à avoir une courbe d'apprentissage plus lisse? Golang est plus adapté aux besoins élevés de concurrence et de haute performance, et la courbe d'apprentissage est relativement douce pour les développeurs ayant une formation en langue C. Python est plus adapté à la science des données et au prototypage rapide, et la courbe d'apprentissage est très fluide pour les débutants.

La course de performance: Golang vs CLa course de performance: Golang vs CApr 16, 2025 am 12:07 AM

Golang et C ont chacun leurs propres avantages dans les compétitions de performance: 1) Golang convient à une concurrence élevée et à un développement rapide, et 2) C fournit des performances plus élevées et un contrôle fin. La sélection doit être basée sur les exigences du projet et la pile de technologie d'équipe.

Golang vs C: Exemples de code et analyse des performancesGolang vs C: Exemples de code et analyse des performancesApr 15, 2025 am 12:03 AM

Golang convient au développement rapide et à la programmation simultanée, tandis que C est plus adapté aux projets qui nécessitent des performances extrêmes et un contrôle sous-jacent. 1) Le modèle de concurrence de Golang simplifie la programmation de concurrence via le goroutine et le canal. 2) La programmation du modèle C fournit un code générique et une optimisation des performances. 3) La collecte des ordures de Golang est pratique mais peut affecter les performances. La gestion de la mémoire de C est complexe mais le contrôle est bien.

Impact de Golang: vitesse, efficacité et simplicitéImpact de Golang: vitesse, efficacité et simplicitéApr 14, 2025 am 12:11 AM

GOIMIMPACTSDEVENCEMENTSPOSITIVEMENTS INSPECT, EFFICACTION ET APPLICATION.1) VITESSE: GOCOMPILESQUICKLYANDRUNSEFFIÉMENT, IDEALFORLARGEPROROSTS.2) Efficacité: ITSCOMPEHENSIVESTANDARDLIBRARYREDUCEEXTERNEDENDENCES, EnhancingDevelovefficiency.3) Simplicité: Simplicité: Implicité de la manière

See all articles

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

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

Télécharger la version Mac de l'éditeur Atom

Télécharger la version Mac de l'éditeur Atom

L'éditeur open source le plus populaire

Adaptateur de serveur SAP NetWeaver pour Eclipse

Adaptateur de serveur SAP NetWeaver pour Eclipse

Intégrez Eclipse au serveur d'applications SAP NetWeaver.

Listes Sec

Listes Sec

SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

VSCode Windows 64 bits Télécharger

VSCode Windows 64 bits Télécharger

Un éditeur IDE gratuit et puissant lancé par Microsoft