Mengapakah Pendaraban Titik Terapung Berkelakuan Berbeza dengan Huruf lwn. Pembolehubah dalam Go?
Dalam Go, aritmetik titik terapung mempamerkan satu unik tingkah laku apabila mendarab literal dan pembolehubah. Anomali ini timbul disebabkan oleh perbezaan antara pemalar dan pembolehubah dalam bahasa.
Pemalar dan literal angka, seperti 10.1, mempunyai ketepatan tanpa had dan tidak ditaip. Apabila ditugaskan kepada pembolehubah yang ditaip, mereka mewarisi batasan jenis yang ditetapkan. Oleh itu, mengisytiharkan x := 10.1 menghasilkan pembolehubah float64 x dengan ketepatan yang dikurangkan.
Sebaliknya, pendaraban langsung literal, seperti dalam 10.1*3.0, beroperasi pada nombor dengan ketepatan penuh. Perbezaan dalam ketepatan pengendalian ini membawa kepada perbezaan yang diperhatikan dalam perbandingan x*3.0 == 10.1*3.0.
Perbezaan ini diterangkan dalam bahagian "Terapung" dalam artikel blog Go "Constants." Ia menyatakan bahawa pemalar wujud dalam ruang angka ketepatan arbitrari, tetapi mesti mematuhi jenis destinasi apabila ditugaskan kepada pembolehubah. Walaupun pemalar boleh mewakili nilai yang sangat besar atau kecil, ia tidak boleh dicetak atau ditugaskan kepada pembolehubah tanpa dimuatkan dalam julat jenis sasaran.
Memahami perbezaan ini adalah penting untuk pengiraan titik terapung yang tepat dalam Go. Jika ketepatan mutlak diperlukan, adalah disyorkan untuk menggunakan literal secara langsung semasa melakukan operasi aritmetik.
Atas ialah kandungan terperinci Mengapakah Hasil Pendaraban Titik Terapung Go Berbeza Apabila Menggunakan Huruf berbanding Pembolehubah?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!