Semasa menghiris atau memadamkan elemen dalam sekeping penunjuk mungkin menimbulkan potensi kebocoran memori, mari kita terokai sama ada ini berlaku untuk peta juga.
Menyemak sumber masa jalan Go mendedahkan bahawa dalam fungsi mapdelete(), kedua-dua storan kunci dan nilai dikosongkan apabila dipadamkan.
558 fungsi mapdelete(t maptype, h hmap, key unsafe. Pointer) {
// ...
600 memclr(k, uintptr(t.keysize))
601 v := unsafe.Pointer(uintptr(unsafe.Pointer(b)) dataOffset bucketCntuintptr(t.keysize) iuintptr(t.valuesize))
602 memclr(v, uintptr(t.valuesize) ))
// ...
618 }
Ini bermakna sebarang penunjuk dalam kekunci atau nilai disifarkan, melanggar rujukannya kepada struktur data dalaman peta.
Untuk menunjukkan lagi perkara ini, kami boleh membina ujian:
taip struct titik {
X, Y int
}
var m = peta[int ]*titik{}
func main() {
fillMap() delete(m, 1) runtime.GC() time.Sleep(time.Second) fmt.Println(m)
}
func fillMap() {
p := &point{1, 2} runtime.SetFinalizer(p, func(p *point) { fmt.Printf("Finalized: %p %+v\n", p, p) }) m[1] = p fmt.Printf("Put in map: %p %+v\n", p, p)
}
Setelah menjalankan ujian ini, kami memerhatikan bahawa pemuktamad berdaftar dipanggil, mengesahkan penyingkiran penunjuk daripada peta dan kutipan sampah seterusnya.
In Go, memadamkan entri daripada peta penunjuk tidak menyebabkan kebocoran memori. Kedua-dua storan kunci dan nilai dikosongkan selepas pemadaman, mengeluarkan sebarang petunjuk yang dipegangnya, memastikan kutipan sampah yang betul.
Atas ialah kandungan terperinci Adakah Memadamkan Kemasukan Peta Penunjuk Menyebabkan Kebocoran Memori dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!