Rumah >pembangunan bahagian belakang >C++ >Bilakah Persamaan Titik Terapung Boleh Diterima?
Kesaksamaan Titik Terapung: Bila dan Mengapa
Walaupun pada umumnya tidak disukai, terdapat keadaan di mana perbandingan titik terapung boleh dianggap boleh diterima .
Perwakilan Tepat Keseluruhan Nombor
IEEE 754, standard untuk aritmetik titik terapung, menjamin bahawa integer (nombor bulat) dalam julat tertentu diwakili tepat dalam format titik terapung. Ini bermakna perbandingan yang melibatkan nombor bulat, termasuk 0.0, boleh dibuat menggunakan operator kesamaan (==).
Awas dengan Nilai Dikira
Walau bagaimanapun, berhati-hati dinasihatkan. apabila bekerja dengan nilai titik terapung yang diperoleh daripada pengiraan. Penetapan nombor bulat kepada pembolehubah titik terapung adalah selamat, tetapi melakukan sebarang operasi aritmetik pada nombor titik terapung boleh menyebabkan ralat pembundaran. Oleh itu, perbandingan kesamaan antara nilai yang dikira harus dielakkan.
Harta Malar
Apabila membandingkan pembolehubah dengan literal malar, adalah penting untuk memastikan bahawa literal ditakrifkan sebagai pemalar berganda (cth., 3.14L) untuk mengekalkan ketepatan dua kali ketepatan.
Contoh
Dalam coretan kod yang disediakan, BAR const statik ditakrifkan sebagai dua kali ganda. Jika d juga adalah dua kali ganda, maka perbandingan d == BAR akan sentiasa kembali benar dengan mengandaikan kedua-dua d dan BAR mewakili nombor bulat dalam julat yang sah untuk perwakilan titik terapung.
Atas ialah kandungan terperinci Bilakah Persamaan Titik Terapung Boleh Diterima?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!