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

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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Crossplay haben?
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

MinGW – Minimalistisches GNU für Windows

MinGW – Minimalistisches GNU für Windows

Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

WebStorm-Mac-Version

WebStorm-Mac-Version

Nützliche JavaScript-Entwicklungstools

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor