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!