Maison développement back-end Golang Améliorez la simultanéité et les performances des programmes grâce au mécanisme de synchronisation de Golang

Améliorez la simultanéité et les performances des programmes grâce au mécanisme de synchronisation de Golang

Sep 27, 2023 pm 04:49 PM
golang 并发能力 Mécanisme de synchronisation

Améliorez la simultanéité et les performances des programmes grâce au mécanisme de synchronisation de Golang

Améliorez la simultanéité et les performances des programmes grâce au mécanisme de synchronisation de Golang

Introduction :
Avec le développement rapide d'Internet, de plus en plus d'applications doivent gérer un grand nombre de requêtes simultanées. Dans ce cas, comment améliorer la concurrence et les performances du programme est devenu une tâche clé. En tant que langage de programmation moderne fortement typé statiquement, Golang possède d'excellentes capacités de traitement simultané. Son puissant mécanisme de synchronisation peut améliorer considérablement les capacités de simultanéité et les performances du programme. Cet article présentera le mécanisme de synchronisation de Golang et des exemples de code spécifiques pour aider les lecteurs à comprendre en profondeur comment utiliser ces mécanismes pour améliorer la concurrence et les performances du programme.

Mécanisme de synchronisation de Golang :
Golang possède de puissants mécanismes de synchronisation intégrés, notamment des verrous (Mutex), des variables de condition (Cond), des opérations atomiques (Atomic), des groupes d'attente (WaitGroup), etc. Ces mécanismes peuvent nous aider à obtenir un accès aux données partagées thread-safe, à coordonner la séquence d'exécution de plusieurs coroutines et à attendre que toutes les coroutines se terminent. Les principes et scénarios d’application de ces mécanismes seront présentés ci-dessous.

1. Lock (Mutex) :
Lock est l'un des outils de synchronisation les plus couramment utilisés. Cela garantit qu’une seule coroutine peut accéder aux données partagées en même temps. Golang fournit le type Mutex dans le package de synchronisation. Un accès sécurisé aux données partagées peut être obtenu en utilisant les méthodes Lock() et Unlock() de Mutex. Voici un exemple de code utilisant un verrou :

package main

import (
    "fmt"
    "sync"
)

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

func main() {
    wg.Add(2)

    go increment()
    go increment()

    wg.Wait()

    fmt.Println("Counter:", counter)
}

func increment() {
    defer wg.Done()

    for i := 0; i < 10000; i++ {
        mutex.Lock()
        counter++
        mutex.Unlock()
    }
}
Copier après la connexion

Dans le code ci-dessus, nous utilisons une variable de compteur globale pour simuler une donnée partagée. Dans la fonction incrément(), nous utilisons Mutex pour verrouiller et déverrouiller l'accès au compteur afin de garantir qu'une seule coroutine peut modifier la valeur du compteur en même temps. En exécutant ce programme, nous pouvons voir que la valeur finale du compteur doit être 20 000, indiquant que le mécanisme de verrouillage peut garantir un accès sécurisé aux données partagées.

2. Variable de condition (Cond) :
La variable de condition est utilisée pour implémenter le mécanisme d'attente et de notification entre les coroutines. Il fournit trois méthodes : Wait(), Signal() et Broadcast() pour implémenter l'attente et la notification de la coroutine. La méthode Wait() est utilisée pour faire attendre la coroutine actuelle que les conditions soient remplies, tandis que les méthodes Signal() et Broadcast() sont utilisées pour notifier à la coroutine en attente de poursuivre l'exécution. Voici un exemple de code utilisant des variables de condition :

package main

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

var (
    ready bool
    mutex sync.Mutex
    cond  *sync.Cond
    wg    sync.WaitGroup
)

func main() {
    cond = sync.NewCond(&mutex)
    wg.Add(2)

    go player("Alice")
    go player("Bob")

    time.Sleep(2 * time.Second)
    ready = true

    cond.Broadcast()

    wg.Wait()
}

func player(name string) {
    defer wg.Done()

    mutex.Lock()
    for !ready {
        cond.Wait()
    }

    fmt.Printf("%s is playing.
", name)
    mutex.Unlock()
}
Copier après la connexion

Dans le code ci-dessus, nous utilisons une variable globale ready et une variable de condition cond pour simuler le processus d'attente et de notification de deux coroutines. Dans la fonction principale, nous définissons ready sur true après une veille de 2 secondes et utilisons la méthode Broadcast() de cond pour avertir toutes les coroutines en attente de poursuivre l'exécution. Dans la fonction player(), obtenez d'abord le verrou de la variable de condition via la méthode Lock(), attendez que la condition soit satisfaite via la méthode Wait() dans la boucle, puis relâchez le verrou via la méthode Unlock() . En exécutant le programme, nous pouvons voir que les deux coroutines sont capables d'effectuer avec succès des opérations d'impression.

3. Opération atomique :
L'opération atomique fait référence à une opération qui ne peut pas être interrompue. Golang fournit le package sync/atomic pour prendre en charge les opérations atomiques. Grâce aux opérations atomiques, nous pouvons obtenir un accès sécurisé aux données partagées sans utiliser de verrous. Voici un exemple de code utilisant des opérations atomiques :

package main

import (
    "fmt"
    "sync/atomic"
    "time"
)

var (
    counter int32
    wg      sync.WaitGroup
)

func main() {
    wg.Add(2)

    go increment()
    go increment()

    wg.Wait()

    fmt.Println("Counter:", counter)
}

func increment() {
    defer wg.Done()

    for i := 0; i < 10000; i++ {
        atomic.AddInt32(&counter, 1)
    }
}
Copier après la connexion

Dans le code ci-dessus, nous utilisons une variable de compteur globale et effectuons des opérations d'addition atomique dessus via la méthode AddInt32() dans le package atomique. En exécutant ce programme, nous pouvons voir que la valeur finale du compteur doit être 20 000, ce qui indique que les opérations atomiques peuvent garantir un accès sécurisé aux données partagées.

4. Waiting Group (WaitGroup) :
Waiting Group est un mécanisme utilisé pour attendre qu'un groupe de coroutines termine son exécution. Golang fournit le type WaitGroup dans le package de synchronisation pour implémenter la fonction de groupe d'attente. Utilisez la méthode Add() pour augmenter le nombre de coroutines en attente, utilisez la méthode Done() pour réduire le nombre de coroutines en attente et utilisez la méthode Wait() pour attendre que toutes les coroutines terminent leur exécution. Voici un exemple de code utilisant un groupe d'attente :

package main

import (
    "fmt"
    "sync"
)

var (
    counter int
    wg      sync.WaitGroup
)

func main() {
    wg.Add(2)

    go increment()
    go increment()

    wg.Wait()

    fmt.Println("Counter:", counter)
}

func increment() {
    defer wg.Done()

    for i := 0; i < 10000; i++ {
        counter++
    }
}
Copier après la connexion

Dans le code ci-dessus, nous utilisons une variable de compteur globale et attendons que les deux coroutines terminent leur exécution via waitGroup. Dans la fonction incrément(), nous utilisons la méthode Done() de waitGroup pour indiquer la fin de l'exécution de la coroutine. En exécutant ce programme, nous pouvons voir que la valeur finale du compteur doit être 20 000, ce qui indique que nous pouvons attendre que toutes les coroutines terminent leur exécution via le groupe d'attente.

Conclusion : 
Grâce aux exemples de code ci-dessus, nous pouvons voir que le mécanisme de synchronisation de Golang peut nous aider à obtenir un accès aux données partagées sécurisé par les threads, à coordonner l'ordre d'exécution de plusieurs coroutines et à attendre que toutes les coroutines se terminent. En utilisant rationnellement ces mécanismes, nous pouvons améliorer la concurrence et les performances du programme. Par conséquent, lors du développement d'applications simultanées à grande échelle, nous pouvons envisager d'utiliser Golang pour utiliser son puissant mécanisme de synchronisation afin d'améliorer les capacités et les performances de concurrence du programme.

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

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 mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

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 lire et écrire des fichiers en toute sécurité avec Golang ? Comment lire et écrire des fichiers en toute sécurité avec Golang ? Jun 06, 2024 pm 05:14 PM

Lire et écrire des fichiers en toute sécurité dans Go est crucial. Les directives incluent : Vérification des autorisations de fichiers Fermeture de fichiers à l'aide de reports Validation des chemins de fichiers Utilisation de délais d'attente contextuels Le respect de ces directives garantit la sécurité de vos données et la robustesse de vos applications.

Comment configurer le pool de connexions pour la connexion à la base de données Golang ? Comment configurer le pool de connexions pour la connexion à la base de données Golang ? Jun 06, 2024 am 11:21 AM

Comment configurer le pool de connexions pour les connexions à la base de données Go ? Utilisez le type DB dans le package base de données/sql pour créer une connexion à la base de données ; définissez MaxOpenConns pour contrôler le nombre maximum de connexions simultanées ; définissez MaxIdleConns pour définir le nombre maximum de connexions inactives ; définissez ConnMaxLifetime pour contrôler le cycle de vie maximum de la connexion ;

Golang Framework vs Go Framework : comparaison de l'architecture interne et des fonctionnalités externes Golang Framework vs Go Framework : comparaison de l'architecture interne et des fonctionnalités externes Jun 06, 2024 pm 12:37 PM

La différence entre le framework GoLang et le framework Go se reflète dans l'architecture interne et les fonctionnalités externes. Le framework GoLang est basé sur la bibliothèque standard Go et étend ses fonctionnalités, tandis que le framework Go se compose de bibliothèques indépendantes pour atteindre des objectifs spécifiques. Le framework GoLang est plus flexible et le framework Go est plus facile à utiliser. Le framework GoLang présente un léger avantage en termes de performances et le framework Go est plus évolutif. Cas : gin-gonic (framework Go) est utilisé pour créer l'API REST, tandis qu'Echo (framework GoLang) est utilisé pour créer des applications Web.

Comment enregistrer les données JSON dans la base de données dans Golang ? Comment enregistrer les données JSON dans la base de données dans Golang ? Jun 06, 2024 am 11:24 AM

Les données JSON peuvent être enregistrées dans une base de données MySQL à l'aide de la bibliothèque gjson ou de la fonction json.Unmarshal. La bibliothèque gjson fournit des méthodes pratiques pour analyser les champs JSON, et la fonction json.Unmarshal nécessite un pointeur de type cible pour désorganiser les données JSON. Les deux méthodes nécessitent la préparation d'instructions SQL et l'exécution d'opérations d'insertion pour conserver les données dans la base de données.

Comment trouver la première sous-chaîne correspondant à une expression régulière Golang ? Comment trouver la première sous-chaîne correspondant à une expression régulière Golang ? Jun 06, 2024 am 10:51 AM

La fonction FindStringSubmatch recherche la première sous-chaîne correspondant à une expression régulière : la fonction renvoie une tranche contenant la sous-chaîne correspondante, le premier élément étant la chaîne entière correspondante et les éléments suivants étant des sous-chaînes individuelles. Exemple de code : regexp.FindStringSubmatch(text,pattern) renvoie une tranche de sous-chaînes correspondantes. Cas pratique : Il peut être utilisé pour faire correspondre le nom de domaine dans l'adresse email, par exemple : email:="user@example.com", pattern:=@([^\s]+)$ pour obtenir la correspondance du nom de domaine [1].

Transformant du développement frontal au développement back-end, est-il plus prometteur d'apprendre Java ou Golang? Transformant du développement frontal au développement back-end, est-il plus prometteur d'apprendre Java ou Golang? Apr 02, 2025 am 09:12 AM

Chemin d'apprentissage du backend: le parcours d'exploration du front-end à l'arrière-end en tant que débutant back-end qui se transforme du développement frontal, vous avez déjà la base de Nodejs, ...

Comment utiliser un fuseau horaire prédéfini avec Golang ? Comment utiliser un fuseau horaire prédéfini avec Golang ? Jun 06, 2024 pm 01:02 PM

L'utilisation de fuseaux horaires prédéfinis dans Go comprend les étapes suivantes : Importez le package « time ». Chargez un fuseau horaire spécifique via la fonction LoadLocation. Utilisez le fuseau horaire chargé dans des opérations telles que la création d'objets Time, l'analyse de chaînes horaires et l'exécution de conversions de date et d'heure. Comparez les dates en utilisant différents fuseaux horaires pour illustrer l'application de la fonctionnalité de fuseau horaire prédéfini.

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