Apabila menukar nilai float64 kepada int dalam Go, hasil yang tidak dijangka boleh timbul disebabkan oleh pengehadan ketepatan titik terapung. Memahami had ini adalah kunci untuk mengelakkan ralat.
Perwakilan Titik Terapung
Komputer menyimpan nombor float64 menggunakan piawaian IEEE-754. Perwakilan binari ini melibatkan bilangan bit yang terhad (64 dalam kes ini), yang mungkin tidak mewakili semua nombor perpuluhan dengan tepat. Apabila menukar apungan perpuluhan seperti 100.55 kepada apungan64, hasilnya ialah anggaran yang mungkin berbeza sedikit daripada nilai asal.
Contoh: Isu Ketepatan Titik Terapung
Yang berikut coretan kod menggambarkan isu ini:
package main import "fmt" func main() { x := 100.55 fmt.Println(x - float64(int(x))) // Output: 0.5499999999999972 }
Seperti yang ditunjukkan dalam output, penolakan float64(int(x)) daripada nilai float64 asal memberikan 0.5499999999999972 dan bukannya 0.55 yang dijangkakan. Perbezaan ini timbul kerana bentuk float64 100.55 adalah anggaran binari yang berbeza sedikit daripada nilai asal.
Mengelakkan Ralat Titik Terapung
Untuk mengelakkan ralat titik terapung apabila menukar float64 kepada int, pertimbangkan perkara berikut pendekatan:
Kesimpulan
Dengan memahami batasan ketepatan titik terapung dan menggunakan teknik yang sesuai, pembangun boleh berkesan menukar nilai float64 kepada int dalam Go sambil meminimumkan ralat dan mengekalkan tahap yang diingini ketepatan.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Menukar float64 kepada int dalam Go dengan Selamat, Mempertimbangkan Isu Ketepatan Titik Terapung?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!