Heim > Java > javaLernprogramm > Hauptteil

Wie kann ich Dezimalstellen in einem Java-Double genau verschieben?

Patricia Arquette
Freigeben: 2024-11-26 04:00:13
Original
959 Leute haben es durchsucht

How Can I Accurately Move Decimal Places in a Java Double?

Dezimalstellen im Doppel verschieben

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);
Nach dem Login kopieren

Diese Methode führt jedoch zu Rundungsfehlern, was zu einem Wert von „12,340000000000002“ führt, wie in der Ausgabe zu sehen ist .

Präzision erreichen

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);
Nach dem Login kopieren

Dieser modifizierte Ansatz verschiebt die Dezimalstelle effektiv um das Doppelte, was den gewünschten Wert von 12,34 ergibt.

Präzision in Gleitkomma-Arithmetik

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.

Rundungsdifferenzen

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!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage