Maison développement back-end Golang Comment supprimer des éléments de la liste en langue Go

Comment supprimer des éléments de la liste en langue Go

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

Dans le langage Go, vous pouvez utiliser la fonction remove() pour supprimer des éléments de liste. La syntaxe est "list object.Remove(element)". L'élément de paramètre indique que l'élément de liste doit être supprimé. L'élément element ne peut pas être vide. S'il n'est pas vide, la valeur de l'élément supprimé sera renvoyée. S'il est vide, une exception sera signalée.

Comment supprimer des éléments de la liste en langue Go

L'environnement d'exploitation de ce tutoriel : système Windows 7, GO version 1.18, ordinateur Dell G3.

go fournit un package list, similaire à la liste de python, qui peut stocker tout type de données et fournit l'API correspondante, comme suit :

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{}
Copier après la connexion

Parmi eux, la fonction remove() est utilisée pour supprimer des éléments de la liste, et les éléments supprimés ne peuvent pas être vides, s'ils sont vides, une exception sera signalée.

Remove(e *Element) interface{}
Copier après la connexion
ParamètresDescription
ePour supprimer des éléments de la liste.

Valeur de retour

  • Renvoie la valeur de l'élément supprimé.

Exemple d'éléments de suppression de liste

Exemple 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)
	}
}
Copier après la connexion

Comment supprimer des éléments de la liste en langue Go

Analyse :

  • Nous avons créé une liste listHaiCoder via list.New, puis avons utilisé la fonction PushFront pour insérer trois éléments dans l’élément de liste, puis utilisez la fonction Supprimer pour supprimer le dernier élément inséré.

  • Enfin, nous imprimons l'élément supprimé et la liste supprimée. La fonction Remove renvoie la valeur de l'élément supprimé. En même temps, nous constatons que le dernier élément inséré a été supprimé avec succès de la liste.

Exemple 2 : Supprimer les éléments vides

package main
import (
	"container/list"
	"fmt"
)
func main() {
	//使用 Remove 在列表中删除空元素,报错
	listHaiCoder := list.New()
	listHaiCoder.PushFront("Hello")
	listHaiCoder.PushFront("HaiCoder")
	listHaiCoder.Remove(nil)
}
Copier après la connexion

Une fois le programme exécuté, la sortie de la console est la suivante :

Comment supprimer des éléments de la liste en langue Go

Connaissances étendues : list supprime tous les éléments

Avec l'API fournie par le package list , la liste est vraiment facile à utiliser C'est pratique, mais lors de l'utilisation, si vous ne faites pas attention, vous rencontrerez des pièges difficiles à trouver, ce qui fera que les résultats du programme ne seront pas ceux attendus. Le piège ici est le problème rencontré lors du parcours de la liste via une boucle for et de la suppression de tous les éléments. Par exemple, l'exemple de programme suivant crée une liste, stocke 0 à 3 dans l'ordre, puis parcourt la liste pour supprimer tous les éléments via une boucle for :

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")
}
Copier après la connexion

Le résultat de l'exécution du programme est le suivant :

original list:
0 1 2 3
deleted list:
1 2 3
Copier après la connexion

Depuis le En sortie, nous pouvons savoir que les éléments de la liste n'ont pas été complètement supprimés, seul le premier élément 0 a été supprimé, ce qui est différent de l'idée originale. Selon les habitudes d'utilisation de Go, parcourir une liste et supprimer tous les éléments devraient être. écrit comme suit :

for e := l.Front(); e != nil; e = e.Next() {
    l.Remove(e)
}
Copier après la connexion

Mais selon le résultat de l'exemple de code ci-dessus, ceci est La suppression de tous les éléments de la liste n'est pas valide, alors quel est le problème ? Grâce au mécanisme de la boucle for, nous pouvons savoir que puisque le premier élément a été supprimé mais que le deuxième élément n'a pas été supprimé, il faut que la condition de la deuxième boucle soit invalide, provoquant la sortie de la boucle, c'est-à-dire après l'exécution l'instruction suivante :

l.Remove(e)
Copier après la connexion

e Should est nulle, donc la boucle se termine. Ajoutez une instruction print à vérifier avant l'instruction l.Remove(e) dans la boucle for. Par exemple, ajoutez l'instruction suivante :

fmt.Println("delete a element from list")
Copier après la connexion

Le résultat de l'exécution du programme est le suivant :

original list:
0 1 2 3
deleted list:
delete a element from list
1 2 3
Copier après la connexion

Comme vous pouvez le voir. n'est en effet bouclé qu'une seule fois et la boucle est terminée. Autrement dit, une fois l'instruction l.Remove(e) exécutée, e est égal à e.Next() car e.Next() est nul, e est nul et la boucle se termine. Pourquoi e.Next() est-il nul ? En visualisant le code source de la go list, il se présente comme suit :

// 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
}
Copier après la connexion

On peut voir à partir du code source que lorsque l.Remove(e) est exécuté, la méthode l.remove(e) sera appelée en interne pour supprimer l'élément e. Afin d'éviter les fuites de mémoire, attribuera e.next et e.prev à nil, ce qui est la source du problème.

Le programme corrigé est le suivant :

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")
}
Copier après la connexion

Le résultat de l'exécution du programme est le suivant :

original list:
0 1 2 3
deleted list:
Copier après la connexion

Comme vous pouvez le voir, tous les éléments de la liste ont été correctement supprimés.

【Recommandations associées : Tutoriel vidéo Go, Enseignement de la programmation

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quel est le problème avec le fil de file d'attente dans GO's Crawler Colly? Quel est le problème avec le fil de file d'attente dans GO's Crawler Colly? Apr 02, 2025 pm 02:09 PM

Problème de threading de file d'attente dans Go Crawler Colly explore le problème de l'utilisation de la bibliothèque Crawler Crawler dans le langage Go, les développeurs rencontrent souvent des problèmes avec les threads et les files d'attente de demande. � ...

Quelles bibliothèques sont utilisées pour les opérations du numéro de point flottantes en Go? Quelles bibliothèques sont utilisées pour les opérations du numéro de point flottantes en Go? Apr 02, 2025 pm 02:06 PM

La bibliothèque utilisée pour le fonctionnement du numéro de point flottante dans le langage go présente comment s'assurer que la précision est ...

Dans Go, pourquoi les chaînes d'impression avec println et string () ont-elles des effets différents? Dans Go, pourquoi les chaînes d'impression avec println et string () ont-elles des effets différents? Apr 02, 2025 pm 02:03 PM

La différence entre l'impression de chaîne dans le langage go: la différence dans l'effet de l'utilisation de fonctions println et string () est en Go ...

Comment résoudre le problème de conversion de type user_id lors de l'utilisation du flux redis pour implémenter les files d'attente de messages dans le langage Go? Comment résoudre le problème de conversion de type user_id lors de l'utilisation du flux redis pour implémenter les files d'attente de messages dans le langage Go? Apr 02, 2025 pm 04:54 PM

Le problème de l'utilisation de Redessstream pour implémenter les files d'attente de messages dans le langage GO consiste à utiliser le langage GO et redis ...

Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées? Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées? Apr 02, 2025 pm 05:09 PM

Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées? Lorsque vous utilisez Goland pour le développement du langage GO, de nombreux développeurs rencontreront des balises de structure personnalisées ...

Objectif de Golang: Construire des systèmes efficaces et évolutifs Objectif de Golang: Construire des systèmes efficaces et évolutifs Apr 09, 2025 pm 05:17 PM

GO Language fonctionne bien dans la construction de systèmes efficaces et évolutifs. Ses avantages incluent: 1. Haute performance: compilé en code machine, vitesse de course rapide; 2. Programmation simultanée: simplifier le multitâche via les goroutines et les canaux; 3. Simplicité: syntaxe concise, réduction des coûts d'apprentissage et de maintenance; 4. Plate-forme multipliée: prend en charge la compilation multiplateforme, déploiement facile.

Quelles bibliothèques de GO sont développées par de grandes entreprises ou fournies par des projets open source bien connus? Quelles bibliothèques de GO sont développées par de grandes entreprises ou fournies par des projets open source bien connus? Apr 02, 2025 pm 04:12 PM

Quelles bibliothèques de GO sont développées par de grandes entreprises ou des projets open source bien connus? Lors de la programmation en Go, les développeurs rencontrent souvent des besoins communs, ...

Comment résoudre le problème des contraintes de type de fonction générique de Golang en cours de suppression automatique dans VSCODE? Comment résoudre le problème des contraintes de type de fonction générique de Golang en cours de suppression automatique dans VSCODE? Apr 02, 2025 pm 02:15 PM

La suppression automatique des contraintes de type de fonction générique Golang dans les utilisateurs de VScode peut rencontrer un problème étrange lors de l'écriture de code Golang à l'aide de VScode. quand...

See all articles