Rumah >Java >javaTutorial >Mengapa Penolakan Berganda dalam Java Membawa kepada Keputusan Tidak Tepat, dan Bagaimana BigDecimal Boleh Menyelesaikan Ini?

Mengapa Penolakan Berganda dalam Java Membawa kepada Keputusan Tidak Tepat, dan Bagaimana BigDecimal Boleh Menyelesaikan Ini?

Linda Hamilton
Linda Hamiltonasal
2024-12-02 01:05:11581semak imbas

Why Does Double Subtraction in Java Lead to Inaccurate Results, and How Can BigDecimal Solve This?

Cara Menyelesaikan Isu Berganda Pembundaran Java

Apabila bekerja dengan beregu, ketidaktepatan ketepatan boleh timbul, yang membawa kepada hasil pengiraan yang tidak dijangka. Satu isu sedemikian ialah pembundaran yang berlaku semasa penolakan berganda, seperti yang ditunjukkan dalam coretan kod yang disediakan.

Dalam contoh ini, penolakan tempCommission daripada targetPremium menghasilkan nilai 708.75, manakala nilai yang dijangkakan ialah 708.76. Perbezaan ini disebabkan oleh penggunaan nombor titik terapung berketepatan dua kali, yang mempunyai batasan yang wujud dalam ketepatannya.

Untuk menyelesaikan isu ini dan memastikan pengiraan yang betul, pertimbangkan untuk menggunakan kelas java.math.BigDecimal, yang menyediakan aritmetik perpuluhan yang tepat. BigDecimal menawarkan kawalan yang lebih besar ke atas ketepatan operasi titik terapung, menghapuskan ralat pembundaran yang dikaitkan dengan penolakan berganda.

Dalam coretan kod yang disemak, BigDecimal digunakan untuk melakukan penolakan netToCompany daripada premium, menghasilkan jangkaan nilai 877.85. Ini menunjukkan keberkesanan BigDecimal dalam mengendalikan pengiraan perpuluhan yang tepat, menghapuskan isu pembundaran yang dihadapi dengan beregu:

import java.math.BigDecimal;

BigDecimal premium = BigDecimal.valueOf("1586.6");
BigDecimal netToCompany = BigDecimal.valueOf("708.75");
BigDecimal commission = premium.subtract(netToCompany);
System.out.println(commission + " = " + premium + " - " + netToCompany);

Atas ialah kandungan terperinci Mengapa Penolakan Berganda dalam Java Membawa kepada Keputusan Tidak Tepat, dan Bagaimana BigDecimal Boleh Menyelesaikan Ini?. 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