Beim Umgang mit Gleitkommazahlen wird die genaue Darstellung von Zahlen oft zu einer Herausforderung. Vor allem Doubles haben ihre Grenzen bei der genauen Darstellung von Dezimalzahlen.
Stellen Sie sich ein Szenario vor, in dem Sie ein Double auf 1234 eingestellt haben und versuchen, eine Dezimalstelle um das Doppelte zu verschieben, um 12,34 zu erhalten. Ein gängiger Ansatz besteht darin, 1234 zweimal mit 0,1 zu multiplizieren, wie im bereitgestellten Codeausschnitt zu sehen ist:
double x = 1234; for(int i=1;i<=2;i++) { x = x*.1; } System.out.println(x);
Diese Methode führt jedoch zu Rundungsfehlern, was zu einem Wert von „12,340000000000002“ führt, wie in der Ausgabe zu sehen ist .
Um Um den Wert 12,34 genau zu speichern, ist es wichtig, die Verwendung von 0,1 bei der Multiplikation zu vermeiden. Erwägen Sie stattdessen die Verwendung von 100, die genau in einem Double dargestellt werden kann:
double x = 1234; x /= 100; System.out.println(x);
Dieser modifizierte Ansatz verschiebt die Dezimalstelle effektiv um das Doppelte, was den gewünschten Wert von 12,34 ergibt.
Doppelte Genauigkeit hat ihre Grenzen, sodass einige Rundungsfehler auch ohne explizite Rundung unvermeidbar sind. Für präzisere Operationen wird die Verwendung von BigDecimal empfohlen, das eine genauere Dezimaldarstellung bietet.
Beim Runden ist es wichtig zu beachten, dass das Teilen durch 100 und das Multiplizieren mit 0,01 ergeben aufgrund des mit 0,01 verbundenen festen Rundungsfehlers leicht unterschiedliche Ergebnisse.
Das obige ist der detaillierte Inhalt vonWie kann ich Dezimalstellen in einem Java-Double genau verschieben?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!