Maison > Article > développement back-end > Comment les principes de concurrence de Go peuvent-ils être appliqués pour créer des cartes partagées sûres et efficaces ?
Techniques efficaces de mise en œuvre de cartes partagées dans Go
L'accès simultané aux structures de données partagées nécessite un examen attentif pour garantir l'intégrité des données. Prenons le cas d'une carte à laquelle plusieurs goroutines accèdent simultanément, comme le montre l'exemple ci-dessous.
<code class="go">func getKey(r *http.Request) string { ... } values := make(map[string]int) http.HandleFunc("/get", func(w http.ResponseWriter, r *http.Request) { key := getKey(r) fmt.Fprint(w, values[key]) }) http.HandleFunc("/set", func(w http.ResponseWriter, r *http.Request) { key := getKey(r) values[key] = rand.Int() })</code>
La manipulation directe de la carte via des écritures simultanées peut entraîner une incohérence des données. L'utilisation d'un mutex, comme démontré ci-dessous, résout le problème de l'atomicité mais introduit un autre problème.
<code class="go">func getKey(r *http.Request) string { ... } values := make(map[string]int) var lock sync.RWMutex http.HandleFunc("/get", func(w http.ResponseWriter, r *http.Request) { key := getKey(r) lock.RLock() fmt.Fprint(w, values[key]) lock.RUnlock() }) http.HandleFunc("/set", func(w http.ResponseWriter, r *http.Request) { key := getKey(r) lock.Lock() values[key] = rand.Int() lock.Unlock() })</code>
Bien que les mutex fournissent une synchronisation fiable, ils introduisent la complexité du verrouillage et du déverrouillage manuels. Une approche plus idiomatique dans Go consiste à utiliser des canaux. Par défaut, il est recommandé de donner la priorité aux canaux plutôt qu'aux mutex, comme l'illustre la devise de Go : "Partagez la mémoire en communiquant, ne communiquez pas en partageant la mémoire."
Voici quelques considérations clés :
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!