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.
Eine einfache Implementierung mithilfe einer Schleife ist:
func memsetLoop(a []int, v int) { for i := range a { a[i] = v } }
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]) } }
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.
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.
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!