Memahami Penukaran Float64 kepada Uint64
Dalam Go, menukar float64 kepada uint64 melibatkan penghantaran float64 kepada jenis data uint64, yang mungkin mengakibatkan tingkah laku yang tidak dijangka kerana perbezaan dalam perwakilan.
Pertimbangkan contoh berikut:
package main func main() { n := float64(6161047830682206209) println(uint64(n)) }
Outputnya ialah:
6161047830682206208
Ini kelihatan berlawanan dengan intuitif, kerana kita mungkin menjangkakan nilai uint64 adalah sama sebagai pelampung64. Percanggahan ini berpunca daripada perwakilan dalaman jenis data ini.
Nombor Pemalar dan Titik Terapung
Pemalar dalam Go diwakili dengan ketepatan arbitrari, manakala nombor titik terapung ikut piawaian IEEE 754.
Dalam IEEE 754, a nombor titik terapung berketepatan ganda (64 bit) menyimpan 53 bit untuk digit. Dalam contoh yang diberikan:
6161047830682206209
Nombor melebihi nombor maksimum yang boleh diwakili sebagai integer 53-bit:
2^52 : 9007199254740992
Oleh itu, pemalar tidak boleh diwakili tepat sebagai float64, dan digit hilang semasa penukaran kepada a uint64.
Pengesahan
Ini boleh disahkan dengan mencetak nilai float64 asal:
fmt.Printf("%f\n", n) fmt.Printf("%d\n", uint64(n))
Ini akan menghasilkan:
6161047830682206208.000000 6161047830682206208
Masalahnya bukan dengan penukaran itu sendiri, tetapi dengan kehilangan ketepatan apabila float64 pada asalnya ditetapkan disebabkan oleh batasan perwakilannya.
Contoh dengan Penukaran Sah
Untuk nombor yang lebih kecil yang boleh diwakili dengan tepat menggunakan 53 bit:
n := float64(7830682206209) fmt.Printf("%f\n", n) fmt.Printf("%d\n", uint64(n))
Outputnya ialah:
7830682206209.000000 7830682206209
Dalam kes ini, float64 boleh diwakili dengan tepat dan ditukar kepada uint64 tanpa kehilangan ketepatan.
Atas ialah kandungan terperinci Bagaimanakah Kehilangan Ketepatan Mempengaruhi Penukaran float64 kepada uint64 Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!