Wie kann ich Dezimalstellen in einem Java-Double genau verschieben?
Nov 26, 2024 am 04:00 AMDezimalstellen 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);
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);
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!

Heißer Artikel

Hot-Tools-Tags

Heißer Artikel

Heiße Artikel -Tags

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Top 4 JavaScript -Frameworks in 2025: React, Angular, Vue, Svelte

Wie funktioniert der Klassenladungsmechanismus von Java, einschließlich verschiedener Klassenloader und deren Delegationsmodelle?

Wie benutze ich Maven oder Gradle für das fortschrittliche Java -Projektmanagement, die Erstellung von Automatisierung und Abhängigkeitslösung?

Node.js 20: wichtige Leistungssteigerung und neue Funktionen

ICEBERG: Die Zukunft von Data Lake Tabellen

Wie kann ich JPA (Java Persistence-API) für Objektrelationszuordnungen mit erweiterten Funktionen wie Caching und faulen Laden verwenden?

Wie implementiere ich mehrstufige Caching in Java-Anwendungen mit Bibliotheken wie Koffein oder Guava-Cache?

Spring Boot Snakeyaml 2.0 CVE-2022-1471 Problem behoben
