Rumah >pembangunan bahagian belakang >Golang >Menghiris lwn. menghiris dalam Go
Dalam dokumentasi fungsi tidak selamat.SliceData dalam pergi, ia berkata:
SliceData returns a pointer to the underlying array of the argument slice. If cap(slice) > 0, SliceData returns &slice[:1][0].
Apakah logik di sebalik mengembalikan &slice[:1][0]
dan bukannya &slice[0]
? Setakat yang saya tahu (dan ujian saya mengesahkan), kedua-duanya mengembalikan alamat yang sama. Adakah terdapat sebarang sebab khusus mengapa pembangun Go memilih untuk menggunakan yang pertama daripada yang terakhir? &slice[:1][0]
而不是 &slice[0]
背后的逻辑是什么?据我所知(并且我的测试证实),两者都会返回相同的地址。 Go 开发者选择使用前者而不是后者有什么具体原因吗?
切片可能具有正容量(cap(slice) > 0
),但同时可能具有 0
长度。像 slice[0]
slice[:1]
那样对其进行切片,这将产生长度为 1
的切片,并且您可以像 result[0]
Sekeping mungkin mempunyai kapasiti positif (cap(slice) > 0
), tetapi pada masa yang sama ia mungkin mempunyai 0 kod> panjang. Mengindeksnya seperti slice[0]
akan menyebabkan panik masa jalan.
Jika hirisan mempunyai kapasiti positif, anda boleh mengindeks hasil seperti
tanpa menyebabkan panik masa larian.Contohnya:
slice := make([]int, 0, 5) fmt.Println(&slice[0])Ini menghasilkan: 🎜
panic: runtime error: index out of range [0] with length 0🎜Tetapi ini berkesan: 🎜
fmt.Println(&slice[:1][0])
Atas ialah kandungan terperinci Menghiris lwn. menghiris dalam Go. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!