Heim Backend-Entwicklung Golang So löschen Sie Elemente aus der Liste in der Go-Sprache

So löschen Sie Elemente aus der Liste in der Go-Sprache

Jan 16, 2023 am 10:59 AM
golang go语言

In der Go-Sprache können Sie die Funktion „remove()“ verwenden, um Listenelemente zu löschen. Die Syntax lautet „list object.Remove(element)“. Das Elementelement darf nicht leer sein. Wenn es nicht leer ist, wird der Wert des gelöschten Elements zurückgegeben. Wenn es leer ist, wird eine Ausnahme gemeldet.

So löschen Sie Elemente aus der Liste in der Go-Sprache

Die Betriebsumgebung dieses Tutorials: Windows 7-System, GO Version 1.18, Dell G3-Computer.

go bietet ein Listenpaket, ähnlich der Liste von Python, das beliebige Datentypen speichern kann und die entsprechende API wie folgt bereitstellt:

type Element
    func (e *Element) Next() *Element
    func (e *Element) Prev() *Element
type List
    func New() *List
    func (l *List) Back() *Element
    func (l *List) Front() *Element
    func (l *List) Init() *List
    func (l *List) InsertAfter(v interface{}, mark *Element) *Element
    func (l *List) InsertBefore(v interface{}, mark *Element) *Element
    func (l *List) Len() int
    func (l *List) MoveAfter(e, mark *Element)
    func (l *List) MoveBefore(e, mark *Element)
    func (l *List) MoveToBack(e *Element)
    func (l *List) MoveToFront(e *Element)
    func (l *List) PushBack(v interface{}) *Element
    func (l *List) PushBackList(other *List)
    func (l *List) PushFront(v interface{}) *Element
    func (l *List) PushFrontList(other *List)
    func (l *List) Remove(e *Element) interface{}
Nach dem Login kopieren

Unter anderem wird die Funktion „remove()“ zum Löschen von Elementen aus der Liste verwendet Die gelöschten Elemente können nicht leer sein. Wenn es leer ist, wird eine Ausnahme gemeldet.

Remove(e *Element) interface{}
Nach dem Login kopieren
ParameterBeschreibung
eZum Entfernen von Listenelementen.

Rückgabewert

  • Gibt den Wert des gelöschten Elements zurück.

Beispiel für Listenlöschelemente

Beispiel 1:

package main
import (
	"container/list"
	"fmt"
)
func main() {
	//使用 Remove 在列表中删除元素
	listHaiCoder := list.New()
	listHaiCoder.PushFront("Hello")
	listHaiCoder.PushFront("HaiCoder")
	element := listHaiCoder.PushFront("Hello")
	removeEle := listHaiCoder.Remove(element)
	fmt.Println("RemoveElement =", removeEle)
	for i := listHaiCoder.Front(); i != nil; i = i.Next() {
		fmt.Println("Element =", i.Value)
	}
}
Nach dem Login kopieren

So löschen Sie Elemente aus der Liste in der Go-Sprache

Analyse:

  • Wir haben eine Liste listHaiCoder über list.New erstellt und dann die PushFront-Funktion zum Einfügen verwendet drei Artikel in das Listenelement und verwenden Sie dann die Funktion „Entfernen“, um das zuletzt eingefügte Element zu löschen.

  • Abschließend drucken wir das gelöschte Element und die gelöschte Liste. Die Funktion „Entfernen“ gibt den Wert des gelöschten Elements zurück. Gleichzeitig stellen wir fest, dass das zuletzt eingefügte Element erfolgreich aus der Liste gelöscht wurde.

Beispiel 2: Leere Elemente löschen

package main
import (
	"container/list"
	"fmt"
)
func main() {
	//使用 Remove 在列表中删除空元素,报错
	listHaiCoder := list.New()
	listHaiCoder.PushFront("Hello")
	listHaiCoder.PushFront("HaiCoder")
	listHaiCoder.Remove(nil)
}
Nach dem Login kopieren

Nachdem das Programm ausgeführt wurde, lautet die Konsolenausgabe wie folgt:

So löschen Sie Elemente aus der Liste in der Go-Sprache

Erweitertes Wissen: Liste löscht alle Elemente

Mit der vom Listenpaket bereitgestellten API Die Liste ist wirklich einfach zu verwenden. Es ist praktisch, aber wenn Sie während der Verwendung nicht aufpassen, werden Sie auf einige schwer zu findende Fallstricke stoßen, die dazu führen, dass die Programmergebnisse nicht den Erwartungen entsprechen. Die Gefahr hierbei ist das Problem, das beim Durchlaufen der Liste durch eine for-Schleife und beim Löschen aller Elemente auftritt. Das folgende Beispielprogramm erstellt beispielsweise eine Liste, speichert 0-3 der Reihe nach und durchläuft dann die Liste, um alle Elemente über eine for-Schleife zu löschen:

package main
import (
    "container/list"
    "fmt"
)
func main() {
    l := list.New()
    l.PushBack(0)
    l.PushBack(1)
    l.PushBack(2)
    l.PushBack(3)
    fmt.Println("original list:")
    prtList(l)
    fmt.Println("deleted list:")
    for e := l.Front(); e != nil; e = e.Next() {
        l.Remove(e)
    }
    prtList(l)
}
func prtList(l *list.List) {
    for e := l.Front(); e != nil; e = e.Next() {
        fmt.Printf("%v ", e.Value)
    }
    fmt.Printf("n")
}
Nach dem Login kopieren

Die Ausgabe beim Ausführen des Programms lautet wie folgt:

original list:
0 1 2 3
deleted list:
1 2 3
Nach dem Login kopieren

From the Ausgabe, wir können wissen, dass die Elemente in der Liste nicht vollständig gelöscht wurden, sondern nur das erste Element 0 gelöscht wurde, was sich von der ursprünglichen Idee unterscheidet. Gemäß den Nutzungsgewohnheiten von Go sollte das Durchlaufen einer Liste und das Löschen aller Elemente erfolgen wie folgt geschrieben:

for e := l.Front(); e != nil; e = e.Next() {
    l.Remove(e)
}
Nach dem Login kopieren

Aber laut der Ausgabe des obigen Beispielcodes ist das Löschen aller Elemente der Liste ungültig. Was ist also das Problem? Aus dem for-Schleifenmechanismus können wir erkennen, dass, da das erste Element gelöscht wurde, das zweite Element jedoch nicht gelöscht wurde, die Bedingung der zweiten Schleife ungültig sein muss, was dazu führt, dass die Schleife beendet wird, d. h. nach der Ausführung die folgende Anweisung:

l.Remove(e)
Nach dem Login kopieren

e sollte Null sein, also wird die Schleife beendet. Fügen Sie eine print-Anweisung zur Überprüfung vor der l.Remove(e)-Anweisung in der for-Schleife hinzu. Fügen Sie beispielsweise die folgende Anweisung hinzu:

fmt.Println("delete a element from list")
Nach dem Login kopieren

Die Ausgabe beim Ausführen des Programms lautet wie folgt:

original list:
0 1 2 3
deleted list:
delete a element from list
1 2 3
Nach dem Login kopieren

Wie Sie sehen können wird tatsächlich nur einmal wiederholt und die Schleife ist beendet. Das heißt, nachdem die Anweisung l.Remove(e) ausgeführt wurde, ist e gleich e.Next(). Da e.Next() gleich Null ist, ist e Null und die Schleife wird beendet. Warum ist e.Next() Null? Wenn Sie sich den Quellcode der Go-Liste ansehen, sieht er wie folgt aus:

// remove removes e from its list, decrements l.len, and returns e.
func (l *List) remove(e *Element) *Element {
    e.prev.next = e.next
    e.next.prev = e.prev
    e.next = nil // avoid memory leaks
    e.prev = nil // avoid memory leaks
    e.list = nil
    l.len--
    return e
}
// Remove removes e from l if e is an element of list l.
// It returns the element value e.Value.
func (l *List) Remove(e *Element) interface{} {
    if e.list == l {
        // if e.list == l, l must have been initialized when e was inserted
        // in l or l == nil (e is a zero Element) and l.remove will crash
        l.remove(e)
    }
    return e.Value
}
Nach dem Login kopieren

Sie können dem Quellcode entnehmen, dass bei der Ausführung von l.Remove(e) die Methode l.remove(e) intern aufgerufen wird, um Element e zu löschen . Um Speicherlecks zu vermeiden, werden e.next und e.prev auf Null gesetzt, was die Ursache des Problems ist.

Das korrigierte Programm lautet wie folgt:

package main
import (
    "container/list"
    "fmt"
)
func main() {
    l := list.New()
    l.PushBack(0)
    l.PushBack(1)
    l.PushBack(2)
    l.PushBack(3)
    fmt.Println("original list:")
    prtList(l)
    fmt.Println("deleted list:")
    var next *list.Element
    for e := l.Front(); e != nil; e = next {
        next = e.Next()
        l.Remove(e)
    }
    prtList(l)
}
func prtList(l *list.List) {
    for e := l.Front(); e != nil; e = e.Next() {
        fmt.Printf("%v ", e.Value)
    }
    fmt.Printf("n")
}
Nach dem Login kopieren

Die Ausgabe des Programmlaufs lautet wie folgt:

original list:
0 1 2 3
deleted list:
Nach dem Login kopieren

Wie Sie sehen können, wurden alle Elemente in der Liste korrekt gelöscht.

【Verwandte Empfehlungen: Go-Video-Tutorial, Programmierunterricht

Das obige ist der detaillierte Inhalt vonSo löschen Sie Elemente aus der Liste in der Go-Sprache. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Was ist das Problem mit Warteschlangen -Thread in Go's Crawler Colly? Was ist das Problem mit Warteschlangen -Thread in Go's Crawler Colly? Apr 02, 2025 pm 02:09 PM

Das Problem der Warteschlange Threading In Go Crawler Colly untersucht das Problem der Verwendung der Colly Crawler Library in Go -Sprache. Entwickler stoßen häufig auf Probleme mit Threads und Anfordern von Warteschlangen. � ...

Welche Bibliotheken werden für die Operationen der schwimmenden Punktzahl in Go verwendet? Welche Bibliotheken werden für die Operationen der schwimmenden Punktzahl in Go verwendet? Apr 02, 2025 pm 02:06 PM

In der Bibliothek, die für den Betrieb der Schwimmpunktnummer in der GO-Sprache verwendet wird, wird die Genauigkeit sichergestellt, wie die Genauigkeit ...

Warum hat das Drucken von Saiten mit Println und String () -Funktionen unterschiedliche Effekte? Warum hat das Drucken von Saiten mit Println und String () -Funktionen unterschiedliche Effekte? Apr 02, 2025 pm 02:03 PM

Der Unterschied zwischen Stringdruck in GO -Sprache: Der Unterschied in der Wirkung der Verwendung von Println und String () ist in Go ...

Wie löste ich das Problem des Typs des user_id -Typs bei der Verwendung von Redis -Stream, um Nachrichtenwarteschlangen in GO -Sprache zu implementieren? Wie löste ich das Problem des Typs des user_id -Typs bei der Verwendung von Redis -Stream, um Nachrichtenwarteschlangen in GO -Sprache zu implementieren? Apr 02, 2025 pm 04:54 PM

Das Problem der Verwendung von RETISTREAM zur Implementierung von Nachrichtenwarteschlangen in der GO -Sprache besteht darin, die Go -Sprache und Redis zu verwenden ...

Was soll ich tun, wenn die benutzerdefinierten Strukturbezeichnungen in Goland nicht angezeigt werden? Was soll ich tun, wenn die benutzerdefinierten Strukturbezeichnungen in Goland nicht angezeigt werden? Apr 02, 2025 pm 05:09 PM

Was soll ich tun, wenn die benutzerdefinierten Strukturbezeichnungen in Goland nicht angezeigt werden? Bei der Verwendung von Goland für GO -Sprachentwicklung begegnen viele Entwickler benutzerdefinierte Struktur -Tags ...

Golangs Zweck: Aufbau effizienter und skalierbarer Systeme Golangs Zweck: Aufbau effizienter und skalierbarer Systeme Apr 09, 2025 pm 05:17 PM

Go Language funktioniert gut beim Aufbau effizienter und skalierbarer Systeme. Zu den Vorteilen gehören: 1. hohe Leistung: Kompiliert in den Maschinencode, schnelle Laufgeschwindigkeit; 2. gleichzeitige Programmierung: Vereinfachen Sie Multitasking durch Goroutinen und Kanäle; 3. Einfachheit: präzise Syntax, Reduzierung der Lern- und Wartungskosten; 4. plattform: Unterstützt die plattformübergreifende Kompilierung, einfache Bereitstellung.

Welche Bibliotheken in GO werden von großen Unternehmen entwickelt oder von bekannten Open-Source-Projekten bereitgestellt? Welche Bibliotheken in GO werden von großen Unternehmen entwickelt oder von bekannten Open-Source-Projekten bereitgestellt? Apr 02, 2025 pm 04:12 PM

Welche Bibliotheken in GO werden von großen Unternehmen oder bekannten Open-Source-Projekten entwickelt? Bei der Programmierung in Go begegnen Entwickler häufig auf einige häufige Bedürfnisse, ...

Wie kann ich das Problem der Einschränkungen des generischen Funktionstyps der Golang -Funktionstypen lösen, die automatisch in VSCODE gelöscht werden? Wie kann ich das Problem der Einschränkungen des generischen Funktionstyps der Golang -Funktionstypen lösen, die automatisch in VSCODE gelöscht werden? Apr 02, 2025 pm 02:15 PM

Automatische Löschung von Golang Generic -Funktionstypeinschränkungen in VSCODE -Benutzern kann auf ein seltsames Problem beim Schreiben von Golang -Code mit VSCODE stoßen. Wann...

See all articles