Rumah pembangunan bahagian belakang masalah PHP Mengapakah pengiraan titik terapung PHP tidak tepat?

Mengapakah pengiraan titik terapung PHP tidak tepat?

Apr 23, 2023 am 10:09 AM

Dalam pengaturcaraan PHP, anda mungkin menghadapi pengiraan titik terapung yang tidak tepat. Memahami punca dan penyelesaian masalah ini boleh meningkatkan kebolehpercayaan dan ketepatan kod anda.

1. Punca masalah

Nombor titik terapung ialah cara yang sangat mudah untuk mewakili nombor titik terapung, tetapi ia juga mempunyai beberapa kekurangan. Sebab utama ialah komputer menggunakan binari untuk menyimpan nombor dan tidak boleh mewakili semua nombor titik terapung dengan tepat. Ini mengakibatkan ralat pembundaran dan kehilangan ketepatan.

Sebagai contoh, bayangkan pengiraan titik terapung yang mudah:

0.1 + 0.2 = 0.3
Salin selepas log masuk

Dalam PHP, hasil kod ini adalah seperti berikut:

echo 0.1 + 0.2; //0.30000000000000004
Salin selepas log masuk

Jelas sekali, hasil ini Bukan apa yang kami jangkakan. Ini kerana 0.1 dan 0.2 tidak boleh diwakili dengan tepat sebagai nombor binari, yang mengakibatkan ralat pembundaran. Walaupun ralat ini biasanya kecil, ia sudah cukup untuk menyebabkan kehilangan ketepatan atau mencipta ralat dalam beberapa pengiraan ketepatan tinggi.

2. Penyelesaian

Untuk menangani masalah pengiraan titik terapung yang tidak tepat, kita boleh menerima pakai penyelesaian berikut:

  1. Gunakan pengiraan integer

Apabila melakukan pengiraan yang tepat, anda boleh menukar nombor titik terapung kepada integer dahulu sebelum melakukan pengiraan. Selepas pengiraan selesai, hasilnya ditukar kembali kepada nombor titik terapung.

Sebagai contoh, pertimbangkan pengiraan titik terapung berikut:

1.23 + 4.56 = 5.79
Salin selepas log masuk

Anda boleh menukar nombor titik terapung kepada integer untuk pengiraan:

$num1 = 123;
$num2 = 456;

$result = ($num1 + $num2) / 100; // 5.79
Salin selepas log masuk
  1. Gunakan BCMath

PHP menyediakan sambungan BCMath yang boleh digunakan untuk mengira nombor ketepatan arbitrari dengan tepat. Pengiraan titik terapung boleh dilakukan menggunakan perpustakaan BCMath, yang menggunakan rentetan untuk mewakili nombor dan bukannya nombor titik terapung.

Sebagai contoh, gunakan pustaka fungsi BCMath untuk mengira:

$val1 = '0.1';
$val2 = '0.2';

echo bcadd($val1, $val2, 1); // 0.3
Salin selepas log masuk

Dalam contoh ini, kami menggunakan fungsi bcadd() untuk melakukan penambahan titik terapung yang tepat.

  1. Gunakan fungsi round()

Dalam sesetengah kes, fungsi round() boleh digunakan untuk mengurangkan ralat ketepatan. Fungsi round() membundarkan nombor titik terapung ke nombor tempat perpuluhan yang ditentukan.

Sebagai contoh, pertimbangkan pengiraan berikut:

$num1 = 0.1;
$num2 = 0.2;

$result = round($num1 + $num2, 1); // 0.3
Salin selepas log masuk

Contoh ini menggunakan fungsi round() untuk membundarkan hasil kepada satu tempat perpuluhan. Walaupun ini tidak menghapuskan ralat ketepatan sepenuhnya, hasilnya lebih dekat dengan apa yang dijangkakan.

  1. Elakkan perbandingan terus nombor titik terapung

Apabila membandingkan nombor titik terapung, beberapa mekanisme toleransi kesalahan harus digunakan. Oleh kerana ketepatan nombor titik terapung boleh mengalami ralat pembundaran, secara amnya tidak boleh dipercayai untuk membandingkan secara langsung nilai dua nombor titik terapung.

Sebagai contoh, pertimbangkan perbandingan titik terapung berikut:

$val1 = 3.14159265;
$val2 = 3.14159267;

if ($val1 == $val2) {
  echo 'val1 等于 val2';
} else {
  echo 'val1 不等于 val2';
}
Salin selepas log masuk

Dalam contoh ini, kita sedang membandingkan dua nombor titik terapung. Walaupun kedua-dua nombor ini hampir, ia tidak sama. Oleh itu, kod mengeluarkan "val1 tidak sama dengan val2".

Jika anda perlu membandingkan dua nombor titik terapung, anda boleh menggunakan nilai toleransi atau nilai delta. Nilai toleransi ialah nombor kecil yang boleh bertolak ansur dengan ralat kecil dalam nombor titik terapung.

Sebagai contoh, kita boleh mentakrifkan nilai delta, mewakili ralat ketepatan maksimum yang dibenarkan:

$delta = 0.00000001;
Salin selepas log masuk

Dengan nilai delta, kita boleh menggunakan kod berikut untuk membandingkan nombor titik terapung:

$val1 = 3.14159265;
$val2 = 3.14159267;

if (abs($val1 - $val2) < $delta) {
  echo 'val1 等于 val2';
} else {
  echo 'val1 不等于 val2';
}
Salin selepas log masuk

Dalam contoh ini, kami menggunakan fungsi abs() untuk mengira perbezaan antara dua nombor titik terapung dan membandingkannya dengan nilai delta. Jika perbezaan antara dua nombor kurang daripada nilai delta, ia dianggap sama.

Ringkasnya, masalah pengiraan titik terapung yang tidak tepat adalah masalah biasa. Dalam PHP, masalah ini boleh diselesaikan menggunakan kaedah seperti aritmetik integer, perpustakaan fungsi BCMath, fungsi bulat() dan toleransi nilai delta. Bergantung pada keadaan, penyelesaian yang berbeza boleh dipilih.

Atas ialah kandungan terperinci Mengapakah pengiraan titik terapung PHP tidak tepat?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Apakah amalan terbaik untuk deduplikasi tatasusunan php Apakah amalan terbaik untuk deduplikasi tatasusunan php Mar 03, 2025 pm 04:41 PM

Artikel ini meneroka deduplikasi array PHP yang cekap. Ia membandingkan fungsi terbina dalam seperti array_unique () dengan pendekatan hashmap tersuai, menonjolkan prestasi perdagangan berdasarkan saiz array dan jenis data. Kaedah optimum bergantung pada profili

Bolehkah PHP Array Deduplication memanfaatkan keunikan nama utama? Bolehkah PHP Array Deduplication memanfaatkan keunikan nama utama? Mar 03, 2025 pm 04:51 PM

Artikel ini meneroka deduplikasi PHP Array menggunakan keunikan utama. Walaupun bukan kaedah penyingkiran pendua langsung, memanfaatkan keunikan utama membolehkan membuat array baru dengan nilai yang unik dengan nilai pemetaan ke kekunci, menimpa duplikat. AP ini

Adakah Deduplication Array PHP perlu dipertimbangkan untuk kerugian prestasi? Adakah Deduplication Array PHP perlu dipertimbangkan untuk kerugian prestasi? Mar 03, 2025 pm 04:47 PM

Artikel ini menganalisis PHP Array Deduplication, menonjolkan kemunculan prestasi pendekatan naif (O (N²)). Ia meneroka alternatif yang cekap menggunakan array_unique () dengan fungsi tersuai, splobjectstorage, dan pelaksanaan hashset, mencapai

Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP? Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP? Mar 10, 2025 pm 06:15 PM

Butiran artikel ini melaksanakan beratur mesej dalam PHP menggunakan RabbitMQ dan Redis. Ia membandingkan seni bina mereka (AMQP vs dalam memori), ciri-ciri, dan mekanisme kebolehpercayaan (pengesahan, urus niaga, kegigihan). Amalan terbaik untuk reka bentuk, kesilapan

Apakah piawaian pengekodan PHP terkini dan amalan terbaik? Apakah piawaian pengekodan PHP terkini dan amalan terbaik? Mar 10, 2025 pm 06:16 PM

Artikel ini mengkaji piawaian pengekodan PHP semasa dan amalan terbaik, memberi tumpuan kepada cadangan PSR (PSR-1, PSR-2, PSR-4, PSR-12). Ia menekankan peningkatan kebolehbacaan dan kebolehkerjaan kod melalui gaya yang konsisten, penamaan bermakna, dan EFF

Bagaimana saya bekerja dengan sambungan php dan pecl? Bagaimana saya bekerja dengan sambungan php dan pecl? Mar 10, 2025 pm 06:12 PM

Butiran artikel ini memasang dan menyelesaikan masalah PHP, memberi tumpuan kepada PECL. Ia meliputi langkah pemasangan (mencari, memuat turun/menyusun, membolehkan, memulakan semula pelayan), teknik penyelesaian masalah (memeriksa log, mengesahkan pemasangan,

Apakah teknik pengoptimuman untuk deduplikasi tatasusunan php Apakah teknik pengoptimuman untuk deduplikasi tatasusunan php Mar 03, 2025 pm 04:50 PM

Artikel ini meneroka mengoptimumkan deduplikasi array PHP untuk dataset yang besar. Ia mengkaji teknik-teknik seperti array_unique (), array_flip (), splobjectstorage, dan pra-sorting, membandingkan kecekapan mereka. Untuk dataset besar -besaran, ia mencadangkan pemotongan, pangkalan data

Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP? Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP? Mar 10, 2025 pm 06:12 PM

Artikel ini menerangkan API Refleksi PHP, membolehkan pemeriksaan runtime dan manipulasi kelas, kaedah, dan sifat. IT memperincikan kes penggunaan biasa (penjanaan dokumentasi, ORM, suntikan pergantungan) dan memberi amaran terhadap prestasi overhea

See all articles