Rumah > pembangunan bahagian belakang > Golang > Bagaimana untuk memadam elemen dari senarai dalam bahasa go

Bagaimana untuk memadam elemen dari senarai dalam bahasa go

青灯夜游
Lepaskan: 2023-01-16 10:59:09
asal
2692 orang telah melayarinya

Dalam bahasa Go, anda boleh menggunakan fungsi remove() untuk memadamkan elemen senarai Sintaks ialah "objek senarai.Alih keluar(elemen)". Elemen elemen tidak boleh kosong Jika ia tidak kosong, nilai elemen yang dipadam akan dikembalikan Jika ia kosong, pengecualian akan dilaporkan.

Bagaimana untuk memadam elemen dari senarai dalam bahasa go

Persekitaran pengendalian tutorial ini: sistem Windows 7, GO versi 1.18, komputer Dell G3.

go menyediakan pakej senarai, serupa dengan senarai python, yang boleh menyimpan sebarang jenis data dan menyediakan API yang sepadan, seperti berikut:

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{}
Salin selepas log masuk

Antaranya, fungsi remove() menggunakan Padam elemen daripada senarai Elemen yang dipadam tidak boleh kosong Jika ia kosong, pengecualian akan dilaporkan.

Remove(e *Element) interface{}
Salin selepas log masuk
参数描述
e要删除列表元素。

Nilai pulangan

  • Mengembalikan nilai elemen yang dipadamkan.

Contoh mengalih keluar elemen daripada senarai

Contoh 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)
	}
}
Salin selepas log masuk

Bagaimana untuk memadam elemen dari senarai dalam bahasa go

Analisis:

  • Kami mencipta senarai senaraiHaiCoder melalui senarai.Baru, kemudian menggunakan fungsi PushFront untuk memasukkan tiga elemen ke dalam senarai, dan kemudian menggunakan fungsi Alih keluar untuk memadam elemen yang dimasukkan terakhir.

  • Akhir sekali, kami mencetak elemen yang dipadam dan senarai yang dipadamkan mengembalikan nilai elemen yang dipadamkan Pada masa yang sama, kami mendapati bahawa elemen yang dimasukkan terakhir telah berjaya dialih keluar daripada Senarai dipadamkan.

Contoh 2: Padam elemen kosong

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

Selepas program dijalankan, output konsol adalah seperti berikut:

Bagaimana untuk memadam elemen dari senarai dalam bahasa go

Pengetahuan lanjutan: padam semua elemen daripada senarai

Dengan API yang disediakan oleh pakej senarai, senarai sememangnya sangat mudah untuk digunakan, tetapi semasa penggunaan, jika anda tidak' t beri perhatian, anda akan menghadapi beberapa perkara yang sukar ditemui, mengakibatkan keputusan program tidak seperti yang diharapkan. Perangkap di sini ialah masalah yang dihadapi apabila melintasi senarai melalui gelung for dan memadam semua elemen. Contohnya, program contoh berikut mencipta senarai, menyimpan 0-3 dalam urutan, dan kemudian melintasi senarai untuk memadam semua elemen melalui gelung 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")
}
Salin selepas log masuk

Output menjalankan program adalah seperti berikut :

original list:
0 1 2 3
deleted list:
1 2 3
Salin selepas log masuk

Daripada output, kita boleh tahu bahawa elemen dalam senarai belum dipadam sepenuhnya, hanya elemen pertama 0 sahaja yang telah dipadam, yang berbeza daripada idea asal tabiat Go, kaedah penulisan melintasi senarai dan memadam semua elemen hendaklah seperti berikut:

for e := l.Front(); e != nil; e = e.Next() {
    l.Remove(e)
}
Salin selepas log masuk

Tetapi mengikut output kod contoh di atas, memadam semua elemen senarai adalah tidak sah, jadi apa masalahnya? Daripada mekanisme gelung for, kita dapat mengetahui bahawa oleh kerana elemen pertama telah dipadamkan tetapi elemen kedua belum dipadam, mestilah keadaan gelung kedua tidak sah, yang menyebabkan gelung keluar, iaitu selepas melaksanakan penyataan berikut:

l.Remove(e)
Salin selepas log masuk

e sepatutnya sifar, jadi gelung keluar. Tambahkan pernyataan cetakan untuk pengesahan sebelum pernyataan l.Alih keluar(e) dalam gelung untuk Contohnya, tambahkan pernyataan berikut:

fmt.Println("delete a element from list")
Salin selepas log masuk

Output menjalankan program adalah seperti berikut:

.
original list:
0 1 2 3
deleted list:
delete a element from list
1 2 3
Salin selepas log masuk

Seperti yang anda lihat, Ia hanya berkitar sekali, dan kitaran sudah tamat. Iaitu, selepas pernyataan l.Remove(e) dilaksanakan, e adalah sama dengan e.Next() Kerana e.Next() is nol, e is nol dan gelung keluar. Mengapakah e.Next() nil? Dengan melihat kod sumber senarai pergi, ia adalah seperti berikut:

// 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
}
Salin selepas log masuk

Ia boleh dilihat daripada kod sumber bahawa apabila l.Remove(e) dilaksanakan, kaedah l.remove(e) akan dipanggil secara dalaman untuk memadam elemen e , untuk mengelakkan kebocoran memori, e.next dan e.prev akan diberikan nil, yang merupakan punca masalah.

Prosedur yang diperbetulkan adalah seperti berikut:

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")
}
Salin selepas log masuk

Output menjalankan program adalah seperti berikut:

original list:
0 1 2 3
deleted list:
Salin selepas log masuk

Seperti yang anda lihat, semua elemen dalam senarai telah dipadamkan dengan betul.

[Cadangan berkaitan: Pergi tutorial video, Pengajaran pengaturcaraan]

Atas ialah kandungan terperinci Bagaimana untuk memadam elemen dari senarai dalam bahasa go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan