Rumah >pembangunan bahagian belakang >masalah PHP >Ralat jumlah tatasusunan titik terapung PHP

Ralat jumlah tatasusunan titik terapung PHP

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBasal
2023-05-07 17:57:091002semak imbas

Dalam keadaan biasa, jumlah tatasusunan titik terapung PHP adalah sangat mudah, hanya gunakan fungsi array_sum(). Walau bagaimanapun, dalam beberapa kes khas, ralat penjumlahan tatasusunan titik terapung mungkin berlaku Keadaan ini biasanya disebabkan oleh isu ketepatan titik terapung. Jadi, bagaimana untuk menyelesaikan ralat jumlah tatasusunan titik terapung?

Pertama, mari kita lihat isu ketepatan nombor titik terapung. Dalam komputer, nombor titik terapung disimpan dalam bentuk binari, tetapi terdapat beberapa perpuluhan yang tidak boleh diwakili oleh nombor perduaan terhad Contohnya, perpuluhan seperti 0.1 tidak boleh diwakili dengan tepat dalam perduaan. Oleh itu, komputer akan menganggarkan perpuluhan ini yang tidak dapat diwakili dengan tepat semasa menyimpannya, yang akan membawa kepada masalah ketepatan dengan nombor titik terapung.

Jika kita menyimpan sekumpulan nombor titik terapung dalam tatasusunan dan kemudian menggunakan fungsi array_sum() untuk menjumlahkannya, mungkin terdapat ralat ketepatan, yang mungkin satu lebih atau kurang daripada satu tempat perpuluhan . Ini kerana fungsi array_sum() tidak mengambil kira ketepatan nombor titik terapung semasa mengira, tetapi secara langsung melaksanakan operasi penambahan.

Jadi, bagaimana untuk menyelesaikan masalah ini?
Satu penyelesaian ialah menggunakan fungsi sprintf() untuk memformat nombor titik terapung, menukarnya kepada rentetan dengan bilangan digit yang sama, dan kemudian melaksanakan operasi jumlah. Kod sampel adalah seperti berikut:

 $arr = [0.1, 0.2, 0.3];
 $sum = 0;
 foreach ($arr as $value) {
     $sum += sprintf("%.2f", $value);
 }
 echo $sum; // 0.60

Dalam kod, kami menggunakan fungsi sprintf() untuk menukar setiap nombor titik terapung kepada rentetan dengan dua tempat perpuluhan, dan kemudian melakukan operasi jumlah, supaya ralat ketepatan boleh dielakkan Masalah.

Selain itu, penyelesaian lain ialah menggunakan perpustakaan matematik BC, yang boleh memberikan pengiraan matematik ketepatan yang lebih tinggi. Kod sampel adalah seperti berikut:

 $arr = [0.1, 0.2, 0.3];
 $sum = 0;
 foreach ($arr as $value) {
     $sum = bcadd($sum, $value, 2);
 }
 echo $sum; // 0.60

Dalam kod, kami menggunakan fungsi bcadd() untuk melaksanakan operasi jumlah nombor titik terapung Fungsi bcadd() boleh memastikan ketepatan operasi matematik parameter 2 bermaksud mengekalkan dua tempat perpuluhan.

Ringkasnya, apabila ralat berlaku dalam penjumlahan tatasusunan titik terapung PHP, kita boleh menggunakan fungsi sprintf() atau perpustakaan matematik BC untuk menyelesaikannya. Dalam pembangunan sebenar, kita perlu memilih penyelesaian yang sesuai mengikut situasi tertentu untuk memastikan ketepatan dan ketepatan pengiraan.

Atas ialah kandungan terperinci Ralat jumlah tatasusunan titik terapung PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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