Maison >développement back-end >Golang >Qu'est-ce que Mutex et comment l'utiliser dans Golang ?

Qu'est-ce que Mutex et comment l'utiliser dans Golang ?

Patricia Arquette
Patricia Arquetteoriginal
2024-12-30 15:42:11690parcourir

Lors du développement de LiveAPI, un outil de génération de documentation Auto API, j'avais besoin d'implémenter un mécanisme de file d'attente robuste qui évoluait en fonction du nombre de cœurs de machine serveur. Cela était crucial pour éviter une utilisation excessive des ressources (mémoire et processeur) qui pourrait entraîner une pénurie de ressources, des pannes et une mauvaise expérience utilisateur.

Dans cet article, j'expliquerai comment j'ai utilisé les mutex dans Golang pour relever ce défi.

Qu'est-ce qu'un Mutex ?
En programmation simultanée, un Mutex (Mutual Exclusion) est un mécanisme de verrouillage qui empêche les conditions de concurrence en garantissant qu'un seul goroutine peut accéder à une ressource partagée à la fois. C'est comme la clé d'une pièce : une seule personne peut détenir la clé et entrer en même temps.

What is Mutex and How to Use it in Golang?

Utilisation du mutex dans Golang
Illustrons comment un Mutex peut gérer l'exécution de tâches simultanées :
Le package de synchronisation de Go fournit plusieurs primitives pour la synchronisation, Mutex étant l'un des outils les plus couramment utilisés.

var (
    maxConcurrentJobs int
    activeJobs        int
    jobMutex          sync.Mutex
)

Dans ce code, la variable activeJobs suit le nombre de tâches en cours d'exécution. Étant donné que plusieurs goroutines peuvent tenter de modifier cette variable simultanément, conduisant à des conditions de concurrence, nous utilisons un Mutex pour synchroniser l'accès.

// Check if we can process more jobs
jobMutex.Lock()
if activeJobs >= maxConcurrentJobs {
    jobMutex.Unlock()
    // Wait before checking again
    time.Sleep(time.Second)
    continue
}
jobMutex.Unlock()

Comment fonctionne un Mutex
Verrouillage : La méthode Lock() acquiert un accès exclusif à la section critique.

Déverrouillage : La méthode Unlock() libère le verrou.

Section critique : Le code entre Lock et Unlock où l'on accède à la **ressource partagée.

Types de mutex à Golang
sync.Mutex : Il s'agit du verrouillage d'exclusion mutuelle de base dans Go. Il permet à une seule goroutine d'accéder à la section critique à la fois.

type SafeCounter struct {
    mu    sync.Mutex
    count int
}

sync.RWMutex : Il s'agit d'un mutex lecteur/écrivain qui permet à plusieurs lecteurs d'accéder simultanément à la ressource partagée, mais un seul écrivain à la fois.

var rwMutex sync.RWMutex
// Reader methods
rwMutex.RLock()   // Lock for reading
rwMutex.RUnlock() // Unlock for reading

// Writer methods
rwMutex.Lock()    // Lock for writing
rwMutex.Unlock()  // Unlock for writing

Les mutex sont des outils essentiels pour gérer les ressources partagées dans les programmes Go simultanés. Ils préviennent les conditions de concurrence et garantissent l'intégrité des données en contrôlant l'accès aux sections critiques du code.

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