Heim > Backend-Entwicklung > Golang > Wie initialisiert man Arrays in Go effizient: Memset-Alternativen?

Wie initialisiert man Arrays in Go effizient: Memset-Alternativen?

Barbara Streisand
Freigeben: 2024-12-31 05:00:12
Original
959 Leute haben es durchsucht

How to Efficiently Initialize Arrays in Go: memset Alternatives?

Analog zu Memset in Go

In C initialisiert die Memset-Funktion effizient ein Array mit einem angegebenen Wert. Go fehlt jedoch die direkte Memset-Unterstützung. In diesem Artikel werden mehrere alternative Ansätze zum Erreichen einer ähnlichen Funktionalität untersucht.

Iterative Schleifenlösung

Eine einfache Implementierung mithilfe einer Schleife ist:

func memsetLoop(a []int, v int) {
    for i := range a {
        a[i] = v
    }
}
Nach dem Login kopieren

Kopierbasierte Lösung

Ein optimierter Ansatz nutzt die effiziente Funktion copy():

func memsetRepeat(a []int, v int) {
    if len(a) == 0 {
        return
    }
    a[0] = v
    for bp := 1; bp < len(a); bp *= 2 {
        copy(a[bp:], a[:bp])
    }
}
Nach dem Login kopieren

Diese Lösung ähnelt der Implementierung von bytes.Repeat(). Zum Erstellen eines neuen []Bytes, das mit demselben Wert gefüllt ist, wird bytes.Repeat() empfohlen.

Benchmark-Vergleich

Leistungsbenchmarks zeigen die Überlegenheit von memsetRepeat() gegenüber memsetLoop() als Array-Größe nimmt zu:

Array Size memsetLoop memsetRepeat Improvement
100 ~1.15x slower ~1.15x faster
1,000 ~2.5x slower ~2.5x faster
10,000 ~2x slower ~2x faster
100,000 ~1.5x slower ~1.5x faster

Bei etwa 3800-4000 Elementen bietet memsetRepeat() eine erhebliche ~3,2-fache Leistungssteigerung.

Fazit

Während memset in Go nicht nativ unterstützt wird, bieten memsetLoop() und memsetRepeat() effiziente Alternativen zum Initialisieren von Arrays mit Werten ungleich Null. memsetRepeat() mit copy() erweist sich als optimale Lösung für größere Arrays.

Das obige ist der detaillierte Inhalt vonWie initialisiert man Arrays in Go effizient: Memset-Alternativen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage