Frage zu Fließkommadarstellung in Java

samhain

Mitglied
Hallo Zusammen,

ich bin gerade am durcharbeiten meines Java Buchs und bin dabei auf folgende Aufgabe gestoßen:

Frage Was ist das Ergebnis der Ausgabe?
1.
Java:
System.out.println(20000000000F == 20000000000F+[B]1[/B]); // Ausgabe: true
2.
Java:
System.out.println(20000000000D == 20000000000D+[B]1[/B]); // Ausgabe: false

Erstmal war ich verdutzt, weil ich beide als false angenommen hatte. Eine kurze Suche bei google ergab dann etwas mit interner Darstellung Mantisse Exp usw. und da fiel mir auch ein das da mal was war...^^. Jetzt wollte ich das aber doch nochmal um es mir zu verdeutlichen einfach nachrechnen und da kommt auch meine erste Frage...

Die 20.000.000.000 + 1 binär dargestellt: 10010.10100.00001.01111.10010.00000.00001 (35 Stellen)

Nun hat die Single Precision Darstellung ja nur 32 Stellen -> 3 Stellen fallen schonmal weg:
10010.10100.00001.01111.10010.00000.00[001]

Durch das VZ-Bit und den Exponenten gehen ja nochmal 9 Bit der eigentlichen Zahl verloren:
10010.10100.00001.01111.100{10.00000.00}[001]

Die Mantisse müsste dann das sein: 10010.10100.00001.01111.100 sprich auch der Wert, der auf Gleichheit geprüft wird. Das mit der 1 ist mir auch soweit klar...Jetzt habe noch geschaut, wann der Wert sich ändert also von true auf false gesetzt wird.
Das passiert bei 1024 (binär: 10000000000)
Die Mantisse müsste dann also so aussehen: 10010.10100.00001.01111.101

Ich muss die 1024 doch nur zur ursprünglichen Zahl addieren, was bei mir so aussieht:
10010.10100.00001.01111.10010.00000.00001 + 10000000000 = 10010.10100.00001.01111.10011.00000.00001 <--- und das hier verstehe ich nicht!? Demnach wäre die Ausgabe immer noch true :bahnhof:


Frage 2 und 3 mach ich kurz:

Der Wertebereich von Float wird bei 4 Byte mit + 3,402...E+38f angegeben. Dies übersteigt das Beispiel von oben aber bei weitem. Wenn das Beispiel von oben aber schon nicht richtig darstellbar ist unter Float wieso hat man dann diesen Bereich? Bzw. wenn das Problem wegen dem 32 Bit System ist wieso geht es bei Double?

Vielleicht liegts auch grad einfach nur an der Uhrzeit, ich geh jetzt erstmal pennen.

Gruß Sam
 

Volvagia

Top Contributor
Liegt das nicht einfach an der Ungenauigkeit von Gleitkommazahlen, dass bei so großen Zahlen der selbe Wert da gestellt wird? Und double sind eben doppelt so genau.
 

Ark

Top Contributor
double und float belegen 64 bzw. 32 Bit an Speicher. Allerdings werden davon nur bis zu 52 bzw. 23 Bit davon benutzt, um die Ziffernfolge binär zu speichern. (Hinzu kommt in diesem Fall noch jeweils ein "hidden bit", aber das ist hier ohne Belang.)

Rechne dir doch mal den Zweierlogarithmus von 20000000001 aus: 34,219… D.h., um diese Zahl im Binärsystem zu speichern, braucht man mehr Bits, als float dafür zur Verfügung stehen. double hat hier aber eine genügend hohe Genauigkeit.

Ark
 

samhain

Mitglied
@Volvagia: So wie ich das verstanden habe bezieht sich die Ungenauigkeit darauf, dass die im Rechner darstellbaren Zahlen eine kleine Teilmenge der reellen Zahlen sind und nicht alle Werte dargestellt werden können bzw. nur bedingt genau dargestellt werden können, wie PI zum Beispiel. Die 20 Milliarden von oben sind aber gut darstellbar.

double und float belegen 64 bzw. 32 Bit an Speicher. Allerdings werden davon nur bis zu 52 bzw. 23 Bit davon benutzt, um die Ziffernfolge binär zu speichern. (Hinzu kommt in diesem Fall noch jeweils ein "hidden bit", aber das ist hier ohne Belang.)
Das war wohl von Belang :) ...in meiner obigen Rechnung habe ich das Hidden Bit vergessen, jetzt stimmt auch endlich mein Ergebnis.

Irgendwie war ich bisher immer der Meinung single precision bei 32 Bit Systemen und double precision bei 64 Bit Systemen. Jetzt hab ich es aber kapiert, dass es nicht vom System abhängt.

Damit sind meine Fragen geklärt bis auf: Wieso hat Float dann diesen großen Wertebereich, wenn es gar nicht dargestellt werden kann? Dann kann ich von Haus aus immer gleich Double nehmen...
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
Zrebna Frage zu Test-Driven Development (TDD) Java Basics - Anfänger-Themen 3
I Frage Thymeleaf -> Fehler ignorieren und mit "" ersetzen? Java Basics - Anfänger-Themen 15
I Frage Thymeleaf -> Prefix / Suffix ändern? Java Basics - Anfänger-Themen 11
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
T Frage zu Parse Java Basics - Anfänger-Themen 2
H Frage an die Profis Java Basics - Anfänger-Themen 4
J Eine konzeptionelle Frage zu OOP Java Basics - Anfänger-Themen 3
P Frage zu Rekursion und Backtracking Java Basics - Anfänger-Themen 2
H Frage zur Ausgabe Java Basics - Anfänger-Themen 4
H Frage zu arithmetischen Operationen Java Basics - Anfänger-Themen 20
F Kurze Frage zu replace() Java Basics - Anfänger-Themen 19
JavaSchmecktLecker Polymorphie Frage zur Methodenüberschreibung Java Basics - Anfänger-Themen 21
J Frage zu einem "Taschenrechner" code Java Basics - Anfänger-Themen 9
B Erste Schritte Frage zu Instanzierung und Referenzen Java Basics - Anfänger-Themen 8
DoubleM Runtime.getRuntime().exec Frage Java Basics - Anfänger-Themen 2
J Eine theoretische Frage zur Praxis - JPanel oder Canvas Java Basics - Anfänger-Themen 5
O Frage: Formaler Typbezeichner? Java Basics - Anfänger-Themen 3
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
N Verständnis Frage zu Variablen Java Basics - Anfänger-Themen 3
N Spezielle frage zum Comparator Java Basics - Anfänger-Themen 6
L Frage zum Array Java Basics - Anfänger-Themen 1
A Frage zum UML Design Java Basics - Anfänger-Themen 1
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
izoards Drucken Frage zu FAQ Beitrag Java Basics - Anfänger-Themen 2
J Frage zu meinem Code (OOP) Java Basics - Anfänger-Themen 4
sserio Split() -> Regex Frage. Java Basics - Anfänger-Themen 7
A OCA Study Guide: 2. Frage aus Kapitel 3 Java Basics - Anfänger-Themen 9
sserio Date Library Frage Java Basics - Anfänger-Themen 9
Max246Sch Frage zu Währungsrechner Code Java Basics - Anfänger-Themen 2
sserio Frage zu HashMaps Java Basics - Anfänger-Themen 20
sserio Frage zu Threading - Multithreading Java Basics - Anfänger-Themen 2
sserio Frage zu Lambda Ausdrücken Java Basics - Anfänger-Themen 7
sserio Frage zu BigInteger Java Basics - Anfänger-Themen 1
D Frage bzgl. Enum-Handhabung Java Basics - Anfänger-Themen 16
xxx12 Frage Java Basics - Anfänger-Themen 2
I Generelle Frage zu Mikroservices (Spring Boot?), Docker... Java Basics - Anfänger-Themen 7
R Frage zu Methoden (Rückgabewert u. ohne.) Java Basics - Anfänger-Themen 2
A Frage zur programmierung Java Basics - Anfänger-Themen 12
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
R Input/Output Frage zu Java IO Java Basics - Anfänger-Themen 6
M Frage zu printWriter Java Basics - Anfänger-Themen 5
C Frage zu OLSMultipleLinearRegression Java Basics - Anfänger-Themen 31
KogoroMori21 Frage zum Euklidischen Algorithmus Java Basics - Anfänger-Themen 11
S Verständnis-Frage zu einer HÜ? Java Basics - Anfänger-Themen 1
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
L Frage zur Ticket Maschine Java Basics - Anfänger-Themen 1
J Frage zu OOP-Klassendiagramm Java Basics - Anfänger-Themen 8
OSchriever Frage zu Compiler Java Basics - Anfänger-Themen 8
H Frage zu Throw Exception Java Basics - Anfänger-Themen 2
TimoN11 Frage zu Java-Vererbung (Cast) Java Basics - Anfänger-Themen 5
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
F Frage betreff Programmierbücher zu Lagerverwaltung als Konsolenprogramm Java Basics - Anfänger-Themen 3
dieter000 Kurze Frage kann mir ejmand kurz diesen Code erklären, bzw wie man die zeilen erklärt und so Java Basics - Anfänger-Themen 1
I String.split regex Frage Java Basics - Anfänger-Themen 2
N Best Practice Frage zum MVC-Pattern Java Basics - Anfänger-Themen 2
dieter000 Frage zu einem Beispiel... Java Basics - Anfänger-Themen 5
J Frage zum Loggen Java Basics - Anfänger-Themen 18
J Methoden Frage: Array-Werte in anderer Methode ändern Java Basics - Anfänger-Themen 4
Zrebna Frage zum "Referenzen-konzept" in Java Java Basics - Anfänger-Themen 8
JD_1998 Array-Position aus einer Methode in einer anderen ausgeben (Kurze Frage) Java Basics - Anfänger-Themen 2
marcooooo Frage zu bestimmten Beispiel Java Basics - Anfänger-Themen 31
NeoLexx equals()-Methode Verständnis Frage anhand Code Beispiel Java Basics - Anfänger-Themen 22
N Input/Output Eine Frage über system.out.println. Java Basics - Anfänger-Themen 10
B Erste Schritte Learning Coding (!) Frage an erfahrene Programmierer. Java Basics - Anfänger-Themen 23
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8
B Frage zum Code verständnis im Resultat Java Basics - Anfänger-Themen 10
C Exception-Frage Java Basics - Anfänger-Themen 3
J Eine Frage zur Schreibweise == ? : Java Basics - Anfänger-Themen 3
S Frage des Designs Java Basics - Anfänger-Themen 1
JavaTalksToMe Extends/Implements Frage Java Basics - Anfänger-Themen 3
pkm Frage zu Servletfunktion Java Basics - Anfänger-Themen 0
B Frage zur Währungsumrechnung Java Basics - Anfänger-Themen 3
S Allgemeine Frage über Generics und Vererbungen Java Basics - Anfänger-Themen 5
Kirby.exe Frage zur Verwendung von Interfaces Java Basics - Anfänger-Themen 6
D Frage zu Strings einer Exception Java Basics - Anfänger-Themen 4
L Wie frage ich ab, ob in einem Array, Werte doppelt vorkommen? Java Basics - Anfänger-Themen 4
D Frage zur IDE IntelliJ IDEA Java Basics - Anfänger-Themen 6
H Frage zum 2d Array Java Basics - Anfänger-Themen 1
N Frage zum Newton-Fraktal Java Basics - Anfänger-Themen 1
H Frage zu interfaces Java Basics - Anfänger-Themen 1
J Frage dazu Variablen klassenübergreifend zu verändern Java Basics - Anfänger-Themen 22
I Frage zu SkipList Java Basics - Anfänger-Themen 4
G Frage zu JScrollPane Java Basics - Anfänger-Themen 12
Kirby.exe Allgemeine Frage Java Basics - Anfänger-Themen 3
W Frage zu anonymen Klassen Java Basics - Anfänger-Themen 4
J Kleine Frage zu OOP Java Basics - Anfänger-Themen 371
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
F Frage zu Iteratoren Java Basics - Anfänger-Themen 2
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
J Frage zur Vererbung Java Basics - Anfänger-Themen 1
H Frage zur ermittlung eines doppelte Paars aus Sotieralgorithmus Java Basics - Anfänger-Themen 4
H Frage zum Array Java Basics - Anfänger-Themen 17
G Schach -Frage 2- Maussteuerung Java Basics - Anfänger-Themen 7
G Schach in Java - Allgemeine Frage zur Architektur Java Basics - Anfänger-Themen 7
B Fachliche Frage bei Rechnungen Java Basics - Anfänger-Themen 16
B Frage zu: String... strings -> Ungleiche Anzahl an Parameter? Java Basics - Anfänger-Themen 4
B Frage zu Datenbank Design - Rechnungen, Angebote... und deren Positionen Java Basics - Anfänger-Themen 4
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 2
H Einfache Frage zur Punktnotation objektname.methode(wert) Java Basics - Anfänger-Themen 2
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 3

Ähnliche Java Themen

Neue Themen


Oben