Maison développement back-end Golang Comment implémenter des verrous à l'aide de Golang

Comment implémenter des verrous à l'aide de Golang

Apr 25, 2023 pm 04:28 PM

Golang est un langage de programmation très populaire qui prend en charge la programmation simultanée. Afin de répondre aux exigences de sécurité simultanée, Golang fournit un mécanisme de verrouillage. Un verrou est un mécanisme de synchronisation qui peut être utilisé pour contrôler l'accès aux ressources partagées. Dans cet article, nous présenterons comment implémenter des verrous à l'aide de Golang.

1. Types de verrous

Dans Golang, il existe trois principaux types de verrous : les verrous mutex, les verrous en lecture-écriture et les variables de condition.

1. Verrouillage Mutex (Mutex)

Le verrouillage Mutex est le type de verrouillage le plus simple et le plus couramment utilisé. Sa fonction est de permettre à un seul thread d'accéder aux ressources partagées en même temps. Si d'autres threads tentent d'accéder à la ressource, ils sont bloqués jusqu'à ce que le verrou soit libéré.

2. Verrouillage en lecture-écriture (RWMutex)

Le verrouillage en lecture-écriture est un autre type de verrou qui permet à plusieurs threads de lire une ressource partagée en même temps, mais n'autorise qu'un seul thread à écrire la ressource. Ce verrou est plus efficace qu'un mutex car il autorise des lectures simultanées, mais les écritures doivent occuper exclusivement la ressource.

3. Variable de condition (Cond)

La variable de condition est un mécanisme de synchronisation avancé qui fournit un mécanisme d'attente et de communication entre plusieurs threads. Les variables de condition ont deux méthodes principales : Wait et Signal. La méthode Wait peut mettre le thread en veille pour attendre des conditions spécifiques, tandis que la méthode Signal informe le thread en attente que la condition est remplie.

2. Implémentation de verrous mutex

La bibliothèque standard de Golang fournit l'implémentation de verrous mutex. Vous pouvez utiliser le type Mutex dans le package de synchronisation pour implémenter des verrous mutex. Voici un exemple de programme :

package main

import (
    "fmt"
    "sync"
)

var (
    count int
    lock  sync.Mutex
)

func main() {
    var wg sync.WaitGroup
    for i := 0; i < 100; i++ {
        wg.Add(1)
        go func() {
            lock.Lock()
            count++
            lock.Unlock()
            wg.Done()
        }()
    }
    wg.Wait()
    fmt.Println(count)
}
Copier après la connexion

Dans le code ci-dessus, nous définissons un compteur et créons un verrou mutex. Ensuite, 100 goroutines sont démarrées et le compteur est incrémenté de 1 dans chaque goroutine. Étant donné que l'accès au décompte est simultané, nous devons utiliser un verrou mutex pour éviter que des conditions de concurrence critique ne se produisent.

Il convient de noter que pour les opérations impliquant des ressources partagées, l'opération doit être effectuée après l'acquisition du verrou, et le verrou doit être libéré une fois l'opération terminée pour garantir que toutes les opérations sont atomiques.

3. Implémentation du verrouillage en lecture-écriture

Semblable aux verrous mutex, la bibliothèque standard de Golang fournit également l'implémentation de verrous en lecture-écriture. Vous pouvez utiliser le type RWMutex dans le package de synchronisation pour implémenter des verrous en lecture-écriture. Voici un exemple de programme :

package main

import (
    "fmt"
    "sync"
)

var (
    count int
    rw    sync.RWMutex
)

func main() {
    var wg sync.WaitGroup
    for i := 0; i < 100; i++ {
        wg.Add(1)
        go func() {
            rw.Lock()
            count++
            rw.Unlock()
            wg.Done()
        }()
    }
    for i := 0; i < 100; i++ {
        wg.Add(1)
        go func() {
            rw.RLock()
            fmt.Println(count)
            rw.RUnlock()
            wg.Done()
        }()
    }
    wg.Wait()
}
Copier après la connexion

Dans le code ci-dessus, nous utilisons le type RWMutex pour implémenter des verrous en lecture-écriture. Tout d'abord, démarrez 100 goroutines pour ajouter 1 au compteur. Pendant cette période, le compteur ne peut être occupé que par un seul thread. Ensuite, démarrez 100 goroutines pour lire la valeur du compteur. Ces goroutines peuvent lire la valeur du compteur en même temps.

Par rapport aux verrous mutex, les verrous en lecture-écriture ont une concurrence plus élevée et moins de conflits de verrouillage. Si la plupart des opérations sont des opérations de lecture, l'utilisation de verrous en lecture-écriture au lieu de verrous mutex peut améliorer les performances.

4. Implémentation de variables de condition

Les variables de condition sont un mécanisme de synchronisation avancé qui peut mettre les threads en veille et attendre que des conditions spécifiques soient remplies. Les variables de condition sont également fournies dans le package de synchronisation et peuvent être implémentées à l'aide du type Cond. Voici un exemple de programme :

package main

import (
    "fmt"
    "sync"
)

var (
    count   int
    waiters int
    lock    sync.Mutex
    cond    *sync.Cond = sync.NewCond(&lock)
)

func main() {
    var wg sync.WaitGroup
    for i := 0; i < 10; i++ {
        wg.Add(1)
        go func() {
            lock.Lock()
            for count < 5 {
                waiters++
                cond.Wait()
                waiters--
            }
            fmt.Println("Count:", count)
            lock.Unlock()
            wg.Done()
        }()
    }
    for i := 0; i < 5; i++ {
        wg.Add(1)
        go func() {
            lock.Lock()
            count++
            if waiters > 0 {
                cond.Signal()
            }
            lock.Unlock()
            wg.Done()
        }()
    }
    wg.Wait()
}
Copier après la connexion

Dans le code ci-dessus, nous définissons un compteur et un compteur de threads en attente. Ensuite, démarrez 10 goroutines pour attendre que le compteur atteigne 5 et affichez la valeur du compteur lorsque le compteur atteint 5. Démarrez 5 goroutines supplémentaires pour en ajouter 1 au compteur. Lorsque le compteur atteint 5, appelez cond.Signal() pour réveiller la goroutine en attente.

Il convient de noter que le verrou mutex doit être acquis avant d'utiliser la variable de condition, sinon un blocage se produira.

5. Résumé

Cet article présente trois types de verrous courants dans Golang : les verrous mutex, les verrous en lecture-écriture et les variables de condition. Les verrous mutex sont les verrous les plus couramment utilisés pour empêcher plusieurs threads d'accéder simultanément aux ressources partagées. Les verrous en lecture-écriture autorisent plusieurs opérations de lecture, mais uniquement des opérations d'écriture exclusives. Les variables de condition sont un mécanisme de synchronisation avancé qui permet aux threads d'attendre que des conditions spécifiques soient remplies.

Lors de l'écriture de programmes Golang, le choix du type de verrouillage approprié est crucial pour garantir la sécurité de la concurrence. Il est nécessaire de sélectionner le type de verrou approprié en fonction du scénario d'application et des besoins spécifiques pour améliorer les performances de 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)

Quelles sont les vulnérabilités de Debian OpenSSL Quelles sont les vulnérabilités de Debian OpenSSL Apr 02, 2025 am 07:30 AM

OpenSSL, en tant que bibliothèque open source largement utilisée dans les communications sécurisées, fournit des algorithmes de chiffrement, des clés et des fonctions de gestion des certificats. Cependant, il existe des vulnérabilités de sécurité connues dans sa version historique, dont certaines sont extrêmement nocives. Cet article se concentrera sur les vulnérabilités et les mesures de réponse communes pour OpenSSL dans Debian Systems. DebianopenSSL CONNUTS Vulnérabilités: OpenSSL a connu plusieurs vulnérabilités graves, telles que: la vulnérabilité des saignements cardiaques (CVE-2014-0160): cette vulnérabilité affecte OpenSSL 1.0.1 à 1.0.1F et 1.0.2 à 1.0.2 Versions bêta. Un attaquant peut utiliser cette vulnérabilité à des informations sensibles en lecture non autorisées sur le serveur, y compris les clés de chiffrement, etc.

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 ...

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. � ...

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, ...

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 spécifier la base de données associée au modèle de Beego ORM? Comment spécifier la base de données associée au modèle de Beego ORM? Apr 02, 2025 pm 03:54 PM

Dans le cadre du cadre de beegoorm, comment spécifier la base de données associée au modèle? De nombreux projets Beego nécessitent que plusieurs bases de données soient opérées simultanément. Lorsque vous utilisez Beego ...

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 ...

Méthode de surveillance postgresql sous Debian Méthode de surveillance postgresql sous Debian Apr 02, 2025 am 07:27 AM

Cet article présente une variété de méthodes et d'outils pour surveiller les bases de données PostgreSQL sous le système Debian, vous aidant à saisir pleinement la surveillance des performances de la base de données. 1. Utilisez PostgreSQL pour reprendre la surveillance Afficher PostgreSQL lui-même offre plusieurs vues pour surveiller les activités de la base de données: PG_STAT_ACTIVITY: affiche les activités de la base de données en temps réel, y compris les connexions, les requêtes, les transactions et autres informations. PG_STAT_REPLIcation: surveille l'état de réplication, en particulier adapté aux grappes de réplication de flux. PG_STAT_DATABASE: Fournit des statistiques de base de données, telles que la taille de la base de données, les temps de validation / recul des transactions et d'autres indicateurs clés. 2. Utilisez l'outil d'analyse de journaux pgbadg

See all articles