Dalam Go, fungsi tambah terbina dalam menambahkan elemen pada kepingan dengan mencipta tatasusunan pendasar baharu, menyalin elemen sedia ada, dan menambahkan elemen baharu. Jika hirisan asal dan hirisan yang digunakan dalam fungsi tambah berkongsi tatasusunan asas yang sama, perubahan yang dibuat pada mana-mana kepingan akan ditunjukkan dalam kedua-duanya.
Pertimbangkan coretan kod berikut:
func someFunc(A []int) int { ... tempA := A // copy the slice by value ... newArr = remove(tempA, i) ... } func remove(slice []int, s int) []int { return append(slice[:s], slice[s+1:]...) }
Di sini, fungsi someFunc mengambil kepingan A dan mencipta salinannya yang dipanggil tempA. Fungsi alih keluar kemudian melaksanakan fungsi tambah pada tempA untuk mengalih keluar elemen pada indeks s.
Memandangkan kepingan tempA pada asalnya merujuk tatasusunan asas yang sama seperti A, pengubahsuaian yang dibuat kepada tempA (melalui fungsi tambah) juga dicerminkan dalam A. Ini kerana fungsi append mencipta tatasusunan asas baharu dan menyalin elemen sedia ada ke dalamnya. Memandangkan A dan tempA berkongsi tatasusunan asas yang sama, sebarang perubahan yang dibuat pada satu juga disebarkan kepada yang lain.
Tingkah laku ini dijangka dalam Go disebabkan oleh cara hirisan dilaksanakan secara dalaman:
Untuk mengelakkan perkongsian ini tingkah laku rujukan, anda boleh membuat kepingan baharu dan menyalin elemen secara eksplisit seperti berikut:
tempA := make([]int, len(A)) copy(tempA, A)
Atas ialah kandungan terperinci Mengapakah Melampirkan pada Slice Copy in Go Kadangkala Mengubah suai yang Asal?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!