Mehrere Methoden zur Kartendeduplizierung in Golang
Go-Sprache ist eine stark typisierte, statische Sprache, die als „C-Sprache des Internetzeitalters“ bekannt ist. In der Standardbibliothek der Go-Sprache ist Map eine sehr häufig verwendete Datenstruktur, die häufig zum Speichern von Schlüssel-Wert-Paaren verwendet wird. Die Karte kann mit der Make-Funktion erstellt werden und bietet umfangreiche Betriebsmethoden. Wenn jedoch die Anzahl der Elemente in der Karte zunimmt, wird der von ihr belegte Speicher immer größer. Wenn dies nicht kontrolliert wird, kann dies zu einer zu hohen Speichernutzung des Programms führen. In diesem Artikel werden verschiedene Methoden zur Implementierung der Golang-Map-Deduplizierung vorgestellt, damit Sie den Programmspeicher besser steuern können.
Methode 1: Durchqueren und zählen
Um bestimmte Elemente in der Karte zu löschen, müssen Sie die integrierte Löschfunktion verwenden. In Situationen, in denen jedoch alle Elemente in der Karte dedupliziert werden müssen, können wir eine Kartendeduplizierung erreichen, indem wir die Karte durchlaufen und die Anzahl der Elemente zählen.
Der spezifische Prozess ist wie folgt:
- Definieren Sie eine Karte vom Typ map[string]int;
- Durchlaufen Sie die ursprüngliche Karte und zählen Sie die Anzahl der Vorkommen jedes Elements.
- Erstellen Sie eine neue Karte und fügen Sie Elemente hinzu Anzahl der Vorkommen 1 Fügen Sie es in die Karte ein.
- Geben Sie die neue Karte zurück.
Der Beispielcode lautet wie folgt:
func removeDuplicate(m map[string]string) map[string]string { counts := make(map[string]int) for _, v := range m { counts[v] += 1 } res := make(map[string]string) for k, v := range m { if counts[v] == 1 { res[k] = v } } return res }
Methode 2: Slice als Hilfsspeicher verwenden
Eine andere Möglichkeit, Golang Map zu deduplizieren, besteht darin, Slice als Hilfsspeicher zu verwenden. Der Prozess ist wie folgt:
- Definieren Sie eine Karte vom Typ „map[string]bool“.
- Durchlaufen Sie die ursprüngliche Karte und speichern Sie alle Schlüssel-Wert-Paare in der Karte Alle Schlüssel-Wert-Paare in der Hilfskarte. Der Schlüssel wird im Slice gespeichert.
- gibt den neuen Slice zurück.
- Der Beispielcode lautet wie folgt:
func removeDuplicate(m map[string]string) []string { res := make([]string, 0, len(m)) temp := make(map[string]bool) for _, v := range m { if _, ok := temp[v]; !ok { temp[v] = true res = append(res, v) } } return res }
Methode 3: Struktur zum Filtern verwenden
Die Verwendung von Struktur zum Filtern ist auch eine der Möglichkeiten, eine Kartendeduplizierung zu erreichen. Die spezifischen Schritte sind wie folgt:
Definieren Sie eine Struktur. Jedes Element enthält zwei Attribute, Schlüssel und Wert.- Definieren Sie eine Karte vom Typ „map[string]struct“. , und erstellen Sie eine neue Map[string]struct;
- Gibt die neue Map zurück.
- Der Beispielcode lautet wie folgt:
func removeDuplicate(m map[string]string) map[string]struct{} { res := make(map[string]struct{}, len(m)) for _, v := range m { res[v] = struct{}{} } return res }
Nach dem Login kopierenZusammenfassung
Die oben genannten sind drei Methoden zur Implementierung der Golang-Map-Deduplizierung, nämlich Durchlaufen und Zählen, Verwenden von Slice als Hilfsspeicher und Verwenden von Struct zum Filtern. Achten Sie bei der Verwendung von Map darauf, die Anzahl der Elemente zu kontrollieren, um eine übermäßige Speichernutzung und eine Beeinträchtigung der Programmleistung zu vermeiden. Ich hoffe, dieser Artikel ist hilfreich für Sie.
Das obige ist der detaillierte Inhalt vonMehrere Methoden zur Kartendeduplizierung in Golang. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Dieser Artikel erläutert die Paketimportmechanismen von Go: benannte Importe (z. B. importieren & quot; fmt & quot;) und leere Importe (z. B. Import _ & quot; fmt & quot;). Benannte Importe machen Paketinhalte zugänglich, während leere Importe nur T ausführen

In diesem Artikel werden die Newflash () -Funktion von BeEGO für die Übertragung zwischen PAGE in Webanwendungen erläutert. Es konzentriert sich auf die Verwendung von Newflash (), um temporäre Nachrichten (Erfolg, Fehler, Warnung) zwischen den Controllern anzuzeigen und den Sitzungsmechanismus zu nutzen. Limita

Dieser Artikel beschreibt die effiziente Konvertierung von MySQL -Abfrageergebnissen in GO -Strukturscheiben. Es wird unter Verwendung der SCAN -Methode von Datenbank/SQL zur optimalen Leistung hervorgehoben, wobei die manuelle Parsen vermieden wird. Best Practices für die Struktur -Feldzuordnung mithilfe von DB -Tags und Robus

Dieser Artikel zeigt, dass Mocks und Stubs in GO für Unit -Tests erstellen. Es betont die Verwendung von Schnittstellen, liefert Beispiele für Mock -Implementierungen und diskutiert Best Practices wie die Fokussierung von Mocks und die Verwendung von Assertion -Bibliotheken. Die Articl

In diesem Artikel werden die benutzerdefinierten Typ -Einschränkungen von GO für Generika untersucht. Es wird beschrieben, wie Schnittstellen die minimalen Typanforderungen für generische Funktionen definieren und die Sicherheitstypsicherheit und die Wiederverwendbarkeit von Code verbessern. Der Artikel erörtert auch Einschränkungen und Best Practices

Dieser Artikel beschreibt effizientes Dateischreiben in Go und vergleicht OS.WriteFile (geeignet für kleine Dateien) mit OS.openfile und gepufferter Schreibvorgänge (optimal für große Dateien). Es betont eine robuste Fehlerbehandlung, die Verwendung von Aufschub und Überprüfung auf bestimmte Fehler.

In dem Artikel werden Schreiben von Unit -Tests in GO erörtert, die Best Practices, Spottechniken und Tools für ein effizientes Testmanagement abdecken.

In diesem Artikel wird die Verwendung von Tracing -Tools zur Analyse von GO -Anwendungsausführungsfluss untersucht. Es werden manuelle und automatische Instrumentierungstechniken, den Vergleich von Tools wie Jaeger, Zipkin und Opentelemetrie erörtert und die effektive Datenvisualisierung hervorheben
