Rumah >pembangunan bahagian belakang >Golang >Mengapa Tidak Mengubah Suai Medan Go Struct Dalam Kaedah Penerima Nilai Berterusan?

Mengapa Tidak Mengubah Suai Medan Go Struct Dalam Kaedah Penerima Nilai Berterusan?

DDD
DDDasal
2024-12-13 03:17:13634semak imbas

Why Doesn't Modifying a Go Struct's Field Within a Value Receiver Method Persist?

Mengubah suai Struktur melalui Penerima Nilai: Memahami Kesan Bayangan

Dalam Go, tingkah laku penerima kaedah boleh memberi kesan yang mendalam terhadap kebolehubah daripada struktur. Memahami perbezaan antara penerima nilai dan penerima penunjuk adalah penting untuk memanipulasi struktur dengan betul.

Konteks Masalah

Contoh yang diberikan menunjukkan tingkah laku yang kelihatan tidak dijangka. Medan struct diubah suai dalam kaedah, tetapi pengubahsuaian tidak berterusan di luar kaedah.

type Test struct {
    someStrings []string
}

func (this Test) AddString(s string) {
    this.someStrings = append(this.someStrings, s)
    this.Count() // will print "1"
}

func (this Test) Count() {
    fmt.Println(len(this.someStrings))
}

Apabila kod ini dilaksanakan, ia mencetak:

1
0

Tingkah laku ini timbul kerana kaedah AddString menggunakan penerima nilai, yang pada asasnya mencipta salinan struct apabila kaedah itu digunakan. Pengubahsuaian yang dibuat dalam kaedah digunakan pada salinan ini, bukan struktur asal. Akibatnya, apabila Count digunakan di luar kaedah, ia beroperasi pada struct asal yang tidak diubah suai.

Penerima Penunjuk lwn. Penerima Nilai

Untuk menyelesaikan isu ini, penunjuk penerima mesti digunakan bukannya penerima nilai. Penerima penuding mencipta rujukan kepada struct asal, membenarkan manipulasi langsung.

func (t *Test) AddString(s string) {
    t.someStrings = append(t.someStrings, s)
    t.Count() // will print "1"
}

Dengan penerima penuding, kaedah AddString beroperasi terus pada struct penerima. Oleh itu, pengubahsuaian kepada someStrings dicerminkan dalam struct asal. Akibatnya, apabila Count digunakan di luar kaedah, ia beroperasi pada struct yang diubah suai.

Kesimpulan

Dengan memahami perbezaan antara penerima nilai dan penerima penunjuk, anda boleh memanipulasi struct dengan berkesan dalam Go. Penerima nilai membuat salinan, manakala penerima penunjuk menyediakan akses terus kepada struktur asal. Nuansa ini penting untuk memastikan bahawa perubahan yang dibuat dalam kaedah adalah berterusan di luar kaedah tersebut.

Atas ialah kandungan terperinci Mengapa Tidak Mengubah Suai Medan Go Struct Dalam Kaedah Penerima Nilai Berterusan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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