Maison >développement back-end >Golang >Qu'est-ce que Mutex et comment l'utiliser dans Golang ?
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.
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!