Table des matières
Utilisation du verrouillage mutex
例子
Maison développement back-end Golang Pourquoi les valeurs des variables de mon programme Go sont-elles désynchronisées sur différents threads ?

Pourquoi les valeurs des variables de mon programme Go sont-elles désynchronisées sur différents threads ?

Jun 09, 2023 pm 04:51 PM
go语言 变量值 线程同步

En langage Go, l'utilisation de coroutines pour implémenter des opérations simultanées est devenue un moyen très populaire. Cependant, lorsque les variables sont partagées entre plusieurs coroutines, des problèmes de course aux données peuvent facilement survenir. Une course aux données est un bug de programmation simultané qui se produit lorsque deux ou plusieurs threads tentent de lire ou d'écrire le même emplacement mémoire en même temps. Dans ce cas, le programme peut produire des résultats imprévisibles et erronés.

En langage Go, afin d'éviter cette situation, vous pouvez utiliser des mécanismes tels que les verrous mutex pour la résoudre.

Utilisation du verrouillage mutex

Le verrouillage mutex est une sorte de verrou en langage Go utilisé pour l'accès synchrone aux ressources partagées. Lorsqu'une coroutine doit accéder à une ressource partagée, elle doit d'abord obtenir un mutex, puis effectuer l'opération. Une fois l'opération terminée, le verrou mutex doit être libéré afin que d'autres coroutines puissent continuer à accéder aux ressources partagées.

Le verrou mutex est utilisé comme suit :

import "sync"

var mu sync.Mutex // 互斥锁

func main() {
    // ...

    mu.Lock() // 获取互斥锁
    // 访问共享资源
    mu.Unlock() // 释放互斥锁

    // ...
}
Copier après la connexion

Dans le code ci-dessus, la méthode Lock() est utilisée pour obtenir le verrou mutex, et la méthode Unlock() est utilisée. Libérez le verrou mutex. Lorsqu'une coroutine acquiert un verrou mutex, les autres coroutines doivent attendre qu'elle libère le verrou mutex avant de pouvoir acquérir le verrou mutex. Cela évite les problèmes de course aux données. Lock()方法用于获取互斥锁,Unlock()方法用于释放互斥锁。当一个协程获取到互斥锁后,其他协程必须等待它释放互斥锁之后,才能获取到互斥锁。这样就可以避免数据竞争的问题。

例子

下面是一个例子,演示了如何使用互斥锁来解决数据竞争的问题。

package main

import (
    "fmt"
    "sync"
)

func main() {
    var wg sync.WaitGroup

    count := 0
    mu := sync.Mutex{}

    for i := 0; i < 100; i++ {
        wg.Add(1)
        go func() {
            mu.Lock()
            count++
            mu.Unlock()
            wg.Done()
        }()
    }

    wg.Wait()
    fmt.Println("count: ", count)
}
Copier après la connexion

在上面的代码中,我们首先定义了一个WaitGroup对象,用于记录协程的数量。然后定义一个互斥锁mu和一个计数器count。接着启动100个协程,每个协程对计数器进行加一的操作。由于计数器count是共享资源,所以需要在操作前获取互斥锁,在操作完成后释放互斥锁。最后使用Wait()

Exemple

Ce qui suit est un exemple qui montre comment utiliser un verrou mutex pour résoudre le problème de la course aux données.

count:  100
Copier après la connexion
Dans le code ci-dessus, nous définissons d'abord un objet WaitGroup pour enregistrer le nombre de coroutines. Définissez ensuite un mutex mu et un compteur count. Démarrez ensuite 100 coroutines, et chaque coroutine incrémente le compteur de un. Puisque le compteur count est une ressource partagée, il est nécessaire d'obtenir le verrou mutex avant l'opération et de libérer le verrou mutex une fois l'opération terminée. Enfin, utilisez la méthode Wait() pour attendre la fin de toutes les coroutines et imprimer la valeur du compteur.

Les résultats de l'opération sont les suivants :

rrreee

A en juger par les résultats, l'opération a été un succès. À ce stade, les valeurs des variables sont synchronisées dans différents threads. 🎜🎜Résumé🎜🎜Lors de l'utilisation de coroutines pour des opérations simultanées dans le langage Go, plusieurs coroutines peuvent accéder à la même ressource partagée, vous devez donc faire attention à la question de la concurrence entre les données. Le verrouillage Mutex est une sorte de verrou utilisé pour résoudre la concurrence en matière de données, ce qui peut efficacement éviter le problème de plusieurs coroutines accédant à la même ressource partagée en même temps. En utilisant des verrous mutex, il est possible de garantir que les valeurs des variables seront synchronisées dans différents threads. 🎜

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)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Repo: Comment relancer ses coéquipiers
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD

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)

Quel est le statut d'audience actuel du framework Go? Est-il plus adapté aux différents besoins de l'entreprise pour choisir GRPC ou GoZero? Quel est le statut d'audience actuel du framework Go? Est-il plus adapté aux différents besoins de l'entreprise pour choisir GRPC ou GoZero? Apr 02, 2025 pm 03:57 PM

Analyse de l'état d'audience du cadre GO dans l'écosystème de programmation GO actuel, les développeurs sont souvent confrontés à choisir le bon cadre pour répondre aux besoins de leurs entreprises. Aujourd'hui, nous ...

Comment implémenter des opérations sur les listes liées Linux Iptables à Golang? Comment implémenter des opérations sur les listes liées Linux Iptables à Golang? Apr 02, 2025 am 10:18 AM

Utilisation de Golang pour implémenter Linux ...

Quelle est la meilleure façon d'implémenter le stockage efficace de la paire de valeurs de clé dans GO? Quelle est la meilleure façon d'implémenter le stockage efficace de la paire de valeurs de clé dans GO? Apr 02, 2025 pm 01:54 PM

La bonne façon d'implémenter le stockage efficace de la paire de valeurs de clé dans le langage go comment obtenir les meilleures performances lors du développement de la mémoire de paire de valeurs clés similaire à Redis dans le langage Go ...

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

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

Le langage GO est inefficace dans le traitement de l'accès à URL massif, comment l'optimiser? Le langage GO est inefficace dans le traitement de l'accès à URL massif, comment l'optimiser? Apr 02, 2025 am 10:15 AM

Stratégie d'optimisation des performances pour l'accès à URL massif du langage GO Cet article propose une solution d'optimisation des performances pour le problème de l'utilisation du langage GO pour traiter l'accès massif de l'URL. Programmes existants de CSV ...

See all articles