PHP, sebagai bahasa skrip sebelah pelayan yang biasa digunakan, selalunya melibatkan operasi perbandingan nombor titik terapung. Walau bagaimanapun, disebabkan oleh ketepatan nombor titik terapung, penggunaan yang tidak betul boleh membawa kepada hasil perbandingan yang tidak dijangka dengan mudah. Dalam artikel ini, kami akan membincangkan langkah berjaga-jaga dan teknik untuk perbandingan nombor titik terapung PHP, dan menyediakan contoh kod khusus untuk rujukan pembaca.
Pertama sekali, perlu diingat bahawa nombor titik terapung diwakili dalam binari dalam komputer dan bukan nombor perpuluhan tepat. Ini mengakibatkan ralat yang mungkin berlaku semasa membandingkan nombor titik terapung. Berikut adalah beberapa langkah berjaga-jaga dan teknik yang biasa:
Disebabkan ketepatan nombor titik terapung, gunakan terus "==" untuk membandingkan sama ada dua nombor titik terapung. adalah sama. Margin ralat yang lebih kecil harus digunakan untuk menilai sama ada ia cukup hampir.
Setiap kali anda melakukan operasi titik terapung, ralat akan terkumpul, jadi bilangan berbilang operasi titik terapung harus diminimumkan.
Disebabkan isu ketepatan, menggunakan nombor titik terapung untuk pengiraan gelung mungkin membawa kepada keputusan yang tidak tepat.
Fungsi bcadd ialah fungsi yang disediakan dalam PHP untuk pengiraan ketepatan tinggi, yang boleh mengurangkan ralat operasi titik terapung.
$num1 = '1.1'; $num2 = '2.2'; $sum = bcadd($num1, $num2, 1); echo $sum; // 输出3.3
Fungsi bcmul juga merupakan salah satu fungsi yang digunakan untuk pengiraan ketepatan tinggi, yang boleh mengurangkan ralat operasi titik terapung.
$num1 = '0.1'; $num2 = '0.2'; $product = bcmul($num1, $num2, 1); echo $product; // 输出0.02
Mendarab nombor titik terapung dengan gandaan integer yang cukup besar dan kemudian menukar keputusan kepada integer untuk perbandingan boleh mengurangkan ralat perbandingan nombor terapung.
$num1 = 1.1; $num2 = 1.2; $multiplier = 1000; if ((int)($num1 * $multiplier) == (int)($num2 * $multiplier)) { echo "相等"; } else { echo "不相等"; }
Ringkasnya, walaupun terdapat kesukaran tertentu dalam perbandingan nombor terapung dalam PHP, dengan memerhatikan langkah berjaga-jaga dan menggunakan kemahiran, kami boleh mengurangkan ralat yang disebabkan oleh perbandingan nombor terapung dengan berkesan dan meningkatkan ketepatan perbandingan. Apabila kita perlu membandingkan nombor titik terapung semasa membangunkan program PHP, kita mesti memberi perhatian kepada langkah berjaga-jaga dan teknik di atas untuk mengelakkan ralat yang disebabkan oleh isu ketepatan.
Atas ialah kandungan terperinci Langkah berjaga-jaga dan petua untuk membandingkan nombor titik terapung PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!