Rumah >Java >javaTutorial >Mengapa Perbandingan Kesamaan Titik Terapung Langsung di Jawa Bermasalah, dan Bagaimanakah Kami Boleh Membandingkan Terapung dengan Betul?
Perangkap Perbandingan Kesamaan Titik Terapung di Jawa
Pemaju Java sering mengalami kekeliruan apabila menggunakan operator kesamaan (==) untuk membandingkan terapung -nombor mata. Walaupun dokumentasi menyatakan kesahihannya untuk perbandingan titik terapung, alat analisis statik menandakan perbandingan tersebut sebagai tidak betul.
Mengapa == Bermasalah untuk Terapung?
Nombor titik terapung mewakili nilai perpuluhan dalam format binari dengan tahap ketepatan tertentu. Disebabkan oleh ketidaktepatan yang wujud ini, hasil pengiraan titik terapung boleh mengandungi ralat kecil. Ralat ini boleh membawa kepada perbandingan yang tidak dijangka di bawah semakan kesaksamaan.
Cara Yang Betul untuk Membandingkan Terapung
Untuk mengurangkan perangkap kesamaan titik terapung, disyorkan untuk menggunakan pendekatan berasaskan toleransi sebaliknya. Penyelesaian yang disyorkan adalah untuk menguji sama ada perbezaan mutlak antara kedua-dua terapung adalah kurang daripada ambang yang telah ditetapkan, yang dikenali sebagai epsilon. Berikut ialah kod yang disyorkan:
if(Math.abs(sectionID - currentSectionID) < epsilon)
Epsilon ialah nombor yang sangat kecil, biasanya sekitar 0.00000001, yang mewakili tahap ketaktepatan yang boleh diterima. Pendekatan ini bertolak ansur dengan kesilapan kecil dalam pengiraan titik terapung, memastikan semakan kesaksamaan yang tepat. Dengan menggunakan perbandingan yang diubah suai ini, anda boleh mengelakkan perangkap menggunakan == untuk kesamaan titik terapung di Jawa.
Atas ialah kandungan terperinci Mengapa Perbandingan Kesamaan Titik Terapung Langsung di Jawa Bermasalah, dan Bagaimanakah Kami Boleh Membandingkan Terapung dengan Betul?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!