Heim >Backend-Entwicklung >Golang >gmap in GoFrame: Ein tiefer Einblick in leistungsstarke gleichzeitige Karten
Haben Sie schon einmal mit dem gleichzeitigen Kartenzugriff in Go zu kämpfen gehabt? Du bist nicht allein! Obwohl sync.Map in Go integriert ist, benötigen wir manchmal etwas Leistungsstärkeres. Geben Sie gmap aus dem GoFrame-Framework ein – eine leistungsstarke, gleichzeitig sichere Karte, die genau das sein könnte, wonach Sie suchen.
In diesem Artikel beschäftigen wir uns mit Folgendem:
Lass uns eintauchen! ?♂️
gmap ist eine gleichzeitig sichere Kartenimplementierung von GoFrame, die speziell für Szenarien mit hoher Parallelität entwickelt wurde. Wenn Sie Anwendungen erstellen, die viele gleichzeitige Lese-/Schreibvorgänge auf freigegebenen Karten verarbeiten müssen, ist dies Ihre Aufmerksamkeit wert.
Sehen wir uns zunächst an, wie Sie mit gmap loslegen:
import "github.com/gogf/gf/v2/container/gmap" func main() { m := gmap.New() // Set some values m.Set("hello", "world") m.Set("foo", "bar") // Get values safely fmt.Println(m.Get("hello")) // Output: world }
Ganz einfach, oder? Aber warten Sie, es gibt noch mehr! ?
gmap ist vollgepackt mit nützlichen Funktionen. Hier sind einige, die Sie wahrscheinlich oft verwenden werden:
// Batch set multiple values m.Sets(g.MapAnyAny{ "key1": "value1", "key2": "value2", }) // Check if a key exists if m.Contains("key1") { fmt.Println("Found it!") } // Remove a key m.Remove("key1") // Get the map size size := m.Size() // Clear everything m.Clear() // Iterate over all items m.Iterator(func(k interface{}, v interface{}) bool { fmt.Printf("%v: %v\n", k, v) return true })
Schauen wir uns ein praktisches Beispiel an. So können Sie mit gmap eine einfache Caching-Ebene erstellen:
func Cache(key string) (interface{}, error) { data := gmap.New() // Try cache first if cached := data.Get(key); cached != nil { return cached, nil } // Cache miss - get from database result := db.GetSomething(key) if result != nil { data.Set(key, result) } return result, nil }
Jetzt zum spannenden Teil: Wie schneidet Gmap im Vergleich zu Gos integrierter sync.Map ab? Schauen wir uns einige Szenarien an.
Hier ist ein Benchmark, der eine High-Key-Kollision simuliert:
func BenchmarkKeyConflict(b *testing.B) { m1 := gmap.New() m2 := sync.Map{} b.RunParallel(func(pb *testing.PB) { for pb.Next() { key := rand.Intn(10) // Limited key range m1.Set(key, key) m2.Store(key, key) } }) }
Ergebnisse? gmap ist etwa 3x schneller! ? Dies ist dem intelligenten Sharding-Design zu verdanken, das Sperrkonflikte reduziert.
Hier sind einige Dinge, die ich auf die harte Tour gelernt habe, damit Sie es nicht tun müssen:
Speichernutzung: gmap benötigt aufgrund seines gleichzeitig sicheren Designs mehr Speicher als normale Karten. Bleiben Sie bei kleinen Karten oder Szenarien mit geringer Parallelität bei regulären Karten.
Schlüsseltypen: Ihre Schlüssel müssen vergleichbar sein (Unterstützung == und !=). Für benutzerdefinierte Typen müssen Sie die Methoden Hash() und Equal() implementieren.
Iteratorverhalten: Der Iterator erstellt einen Schnappschuss, sodass Änderungen während der Iteration erst bei der nächsten Iteration sichtbar sind.
// Example of iterator behavior m := gmap.New() m.Set("key1", "value1") go func() { time.Sleep(time.Millisecond) m.Set("key2", "value2") // Won't be seen in current iteration }() m.Iterator(func(k, v interface{}) bool { fmt.Printf("%v: %v\n", k, v) return true })
gmap leuchtet, wenn:
gmap ist ein leistungsstarkes Tool im Go-Entwickler-Toolkit. Obwohl es sich nicht um eine Einheitslösung handelt, kann sie in den richtigen Szenarien die Leistung erheblich verbessern.
Denken Sie daran:
Haben Sie gmap in Ihren Projekten verwendet? Ich freue mich über eure Erfahrungen in den Kommentaren! ?
Viel Spaß beim Codieren! ?
Das obige ist der detaillierte Inhalt vongmap in GoFrame: Ein tiefer Einblick in leistungsstarke gleichzeitige Karten. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!