Heim >Java >javaLernprogramm >Wie kann ich Rundungsfehler bei der Berechnung mit Doubles in Java vermeiden?

Wie kann ich Rundungsfehler bei der Berechnung mit Doubles in Java vermeiden?

Susan Sarandon
Susan SarandonOriginal
2024-12-22 05:11:14475Durchsuche

How Can I Avoid Rounding Errors When Calculating with Doubles in Java?

Probleme mit der doppelten Rundung in Java lösen

In Java kann die Durchführung von Berechnungen mit Gleitkommazahlen mit doppelter Genauigkeit aufgrund von manchmal zu unerwarteten Ergebnissen führen Rundungsfehler. Um dieses Problem zu lösen, ist es wichtig, die Gleitkomma-Arithmetik von Java zu verstehen und entsprechende Lösungen zu übernehmen.

Beim Subtrahieren doppelter Werte können sich kleine Rundungsfehler ansammeln, was zu falschen Berechnungen führt. Betrachten Sie den folgenden Codeausschnitt:

double tempCommission = targetPremium.doubleValue()*rate.doubleValue()/100d;
double netToCompany = targetPremium.doubleValue() - tempCommission;
double dCommission = request.getPremium().doubleValue() - netToCompany;

In diesem Beispiel beträgt das erwartete Provisionsergebnis 877,85, aber die Berechnung ergibt aufgrund von Rundungsfehlern 877,8499999999999.

Lösung: Verwendung von BigDecimal

Um genaue Berechnungen zu gewährleisten, Es wird empfohlen, java.math.BigDecimal zu verwenden. Diese Klasse bietet präzise Gleitkomma-Arithmetik, die die Einschränkungen doppelter Datentypen berücksichtigt.

Umschreiben der letzten Codezeile mit BigDecimal:

BigDecimal commission = premium.subtract(netToCompany);

Dieser Ansatz eliminiert Rundungsfehler und erzeugt das Richtige Ergebnis:

System.out.println(commission + " = " + premium + " - " + netToCompany);

Ausgabe:

877.85 = 1586.6 - 708.75

Das obige ist der detaillierte Inhalt vonWie kann ich Rundungsfehler bei der Berechnung mit Doubles in Java vermeiden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn