Penggunaan Memori Rentetan dalam Go
Ramai pembangun menghadapi pemerhatian yang mengejutkan apabila mengoptimumkan kod yang melibatkan peta dan rentetan dalam Go. Peta ialah struktur data asas dalam Go, dan pilihan jenis nilai boleh memberi kesan ketara kepada prestasi.
Dalam senario di mana peta menyimpan sejumlah besar elemen (50 juta), setiap satu dengan nilai sama ada " A" atau "B," nampaknya logik untuk menggunakan peta[rentetan]bool di atas peta[rentetan]rentetan. Walau bagaimanapun, bertentangan dengan jangkaan, menggunakan tidak selamat.Sizeof() untuk mengukur penggunaan memori peta ini menunjukkan tiada perbezaan.
Memahami Keputusan
Kunci untuk membongkar perkara ini paradoks yang jelas terletak pada pemahaman bagaimana tidak selamat.Sizeof() beroperasi dalam Go. unsafe.Sizeof() mengukur saiz cetek nilai, bermakna ia hanya mengambil kira saiz nilai itu sendiri, bukan sebarang memori yang dirujuk oleh nilai.
Dalam Go, peta dilaksanakan sebagai penunjuk, yang menerangkan saiz konsisten map[rentetan]bool dan map[string]rentetan yang dilaporkan oleh unsafe.Sizeof(). Kedua-dua peta hanya memegang penunjuk kepada struktur data sebenar yang mengandungi pasangan nilai kunci.
String dalam Go adalah lebih rumit. Mereka diwakili oleh pengepala yang mengandungi penunjuk kepada jujukan bait asas dan panjangnya. unsafe.Sizeof() mengukur saiz pengepala ini, yang kekal sama tanpa mengira panjang rentetan.
Selam Dalam ke dalam Penggunaan Memori
Untuk mendapatkan lebih banyak pengukuran yang tepat bagi keperluan ingatan peta, adalah perlu untuk menyelidiki lebih mendalam struktur data. Ini boleh dicapai melalui refleksi, seperti yang ditunjukkan dalam benang StackOverflow "Berapa banyak memori yang disimpan oleh peta Go?".
Untuk rentetan, penggunaan memori sebenar boleh dikira sebagai jumlah panjang bait rentetan dan saiz pengepala rentetan.
Mengoptimumkan Memori Rentetan
Ia adalah penting untuk mempertimbangkan kemungkinan pembaziran memori akibat penghirisan tali. Apabila hirisan rentetan dibuat, ia mewarisi rujukan kepada tatasusunan sandaran rentetan asal. Oleh itu, walaupun rentetan asal tidak lagi digunakan, tatasusunan sandaran kekal dalam ingatan untuk menyokong hirisan rentetan.
Kesimpulannya, mengoptimumkan penggunaan memori rentetan dalam Go melibatkan pemahaman susun atur memori yang mendasari peta dan rentetan, dan menggunakan teknik yang meminimumkan pengekalan ingatan yang tidak perlu.
Atas ialah kandungan terperinci Mengapakah `unsafe.Sizeof()` Menunjukkan Tiada Perbezaan Memori Antara `map[string]bool` dan `map[string]string` dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!