Variablen Genauigkeit von float

vjung

Aktives Mitglied
Java:
public class Hello
{
public static void main(String[] args)
{
    float x = -1283.56789f, y = 9.87654321f;
    double a = 3., b = .2;

    System.out.printf("%f // %.2f // %12.4fab%%\n", x, y, x);
    System.out.printf("%8.2f // %+-12.3f // %.3f\n", a, b, a);
    System.out.printf("Achtung: %6f %.6f\n", a, a);
}
}
$ java Test
-1283,567871 // 9,88 // -1283,5679ab%
3,00 // +0,200 // 3,000
Achtung: 3,000000 3,000000


Frage:

Warum wird in der Ausgabe für
System.out.printf("%f // %.2f // %12.4fab%%\n", x, y, x);
$ java Test
-1283,567871 // 9,88 // -1283,5679ab%
angezeigt, anstatt
System.out.printf("%f // %.2f // %12.4fab%%\n", x, y, x);
$ java Test
-1283,567890// 9,88 // -1283,5679ab%

Was ich zu wissen glaube ist: bei der printf werden, wenn nicht in %f anders angegeben, immer mindestens 6 Nachkommastellen für float und double Zahlen angezeigt. Somit wäre ja 3.0 in %f dann 3.000000 (Wie in dem Code in letzter Zeile "Achtung....")
Wieso wird hier dann jedoch nicht auch x in der Ausgabe mit Nullern aufgefüllt. Woher kommen diese Nachkommastellen auf einmal?
 
Zuletzt bearbeitet:

prise1993

Mitglied
Das liegt an der Darstellung vom float 32 Bit davon 1 Vorzeichen Bit 8 Bit Exponent (in Exzess Darstellung) und 23 Bit Mantisse
Die das sieht dann so aus VZ Mantisse*2^Exponent.
Also nichts anderes wie wenn du z.B. 1,3*10^-3 =0,0013 im Dezimalsystem
1(VZ) 10001001 (Exponet) 01000000111001000101100 (Mantisse) So sieht deine Zahl Binär dargestellt aus!
Durch die Umwandlung in eine 32Bit Binär Zahl geht Information verloren nicht zwingend aber in diesem Fall schon.
Führende der Mantisse 1 wird nicht gespeichert!
 

prise1993

Mitglied
Ich Probiers mal einfacher :D
Die Zahl 43,75 ist ja 4*10¹+3*10⁰+7*10⁻¹+5*10⁻².
Binär funktioniert das gleich 101011,11 ist 1*2⁵+0*2⁴+1*2³+0*2²+1*2¹+1*2⁰+1+2⁻¹+1*2⁻²
2⁻¹ = 1/2¹ = 1/2 = 0,5;
2⁻²=1/2²= 1/4=025;
2⁻³ = 1/8 = 0,125usw.
Die Zahl wird dann normalisiert d.h. das Komma wird so lange verschoben bis nur mehr eine 1 vorm Komma steht.
Dezimal 4,375 * 10¹ Binär 1,0101111 * 2⁵ die Zahlen nachdem Komma werden in der Mantisse gespeichert.
Die Hochzahl gibt an wie weit das Komma verschoben wurde und wird im Exponent gespeichert
Es kann nun passieren das du binär mehr Stellen brauchen würdest, um die Zahl akkurat darzustellen, als du zur Verfügung hast. Sobald du mehr als 23 Stellen nach dem Komma hast kann nicht mehr alles gespeichert werden.
Die Stellen die nicht mehr in die Zahl passen werden dann ins Nirvana geschoben :D
Deswegen stehn da manchmal andere Zahlen drin wie man wollte
Ich hoffe das machts nicht noch schlimmer
http://www.binaryconvert.com/ hier kannst du mal sehen wie die umgewandelten Zahlen aussehen
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
TimoN11 Quadratwurzel Genauigkeit Java Basics - Anfänger-Themen 6
J double (un-)genauigkeit Java Basics - Anfänger-Themen 20
S Datentypen Genauigkeit Double Java Basics - Anfänger-Themen 8
K Mal wieder: double-Genauigkeit Java Basics - Anfänger-Themen 14
H Genauigkeit beim Multiplizieren zweier Zahlen Java Basics - Anfänger-Themen 2
H Verständnisfrage Genauigkeit Java Basics - Anfänger-Themen 31
W Double or Float zusammenrechnen Java Basics - Anfänger-Themen 15
T float soll durch schleife die größte mögliche Zahl herausfinden, Ausgabe ist aber "Infinity" Java Basics - Anfänger-Themen 1
H Cast von Float nach String klappt nicht Java Basics - Anfänger-Themen 12
ms_cikar Bin to Float convertieren funktioniert nicht Java Basics - Anfänger-Themen 24
S Fragen zu Ausgabe double und float Java Basics - Anfänger-Themen 3
B String to Float Java Basics - Anfänger-Themen 27
A Negative float Werte? Java Basics - Anfänger-Themen 10
J Float Frage Java Basics - Anfänger-Themen 1
K Überprüfen ob Eingabe ein Float ist Java Basics - Anfänger-Themen 4
M Datentypen Byte, Float und Boolean Java Basics - Anfänger-Themen 13
MiMa String nach float Konvertieren Java Basics - Anfänger-Themen 23
S Math.ceil für float Java Basics - Anfänger-Themen 1
T Kann erbende Klasse Attribute der vererbenden Klasse anpassen (int -> float)? Java Basics - Anfänger-Themen 9
J Array zu float Java Basics - Anfänger-Themen 6
I Datentypen float-Grenzen (?) Java Basics - Anfänger-Themen 21
X Einfache Frage; wie soll ich die spezielle float var speichern? Java Basics - Anfänger-Themen 2
C Erste Schritte Eingabe mit Float Java Basics - Anfänger-Themen 1
K Erste Schritte switch - Warum sind long/float/double/... nicht erlaubt? Java Basics - Anfänger-Themen 5
M Datentypen Integer und Float Konflikt Java Basics - Anfänger-Themen 3
N Mehrdimensionales float Array aus .txt-Datei einlesen? Java Basics - Anfänger-Themen 17
V Datentypen Position mit Int und Float berechen und ausgeben Java Basics - Anfänger-Themen 5
G double in float umwandeln Java Basics - Anfänger-Themen 2
B Datentypen Test float und double speichern Zahlen nur ungefähr Java Basics - Anfänger-Themen 4
P Variablen 2D float unterteilen Java Basics - Anfänger-Themen 3
W Variablen float rundet beim Bruch rechnen Java Basics - Anfänger-Themen 3
M Erste Schritte float-Array auslesen Java Basics - Anfänger-Themen 4
S byte to float Java Basics - Anfänger-Themen 4
K Datentypen Wertebereich float/double - Warum nicht hoch -1 Java Basics - Anfänger-Themen 6
J Falsche Darstellung von Float Java Basics - Anfänger-Themen 2
1 float Array deklarieren Java Basics - Anfänger-Themen 10
T Operatoren Float in byte umwandeln Java Basics - Anfänger-Themen 3
N Methoden String to Float Java Basics - Anfänger-Themen 3
G Queue mit int oder float Java Basics - Anfänger-Themen 3
Luk10 Unpräzise float-Werte Java Basics - Anfänger-Themen 10
U Nachbarzahl einer Float Java Basics - Anfänger-Themen 4
R Float Wertebereich Java Basics - Anfänger-Themen 3
V Double schneller als Float? Java Basics - Anfänger-Themen 13
T float[] in float Fehler Java Basics - Anfänger-Themen 6
P Einem Double-Objekt einen float-Wert zuweisen Java Basics - Anfänger-Themen 2
B Datentypen Float ohne .0 ausgeben, sonstige Nachkommastellen aber erhalten Java Basics - Anfänger-Themen 4
K aus String mach Float funktioniert nicht warum? Java Basics - Anfänger-Themen 7
C Probleme mit float und int Java Basics - Anfänger-Themen 3
O 64bit- OS byte, short, int oder long bzw. float oder double? Java Basics - Anfänger-Themen 13
M String Datei in Float-Matrix umwandeln Java Basics - Anfänger-Themen 8
M float/double Anzahl Nachkommastellen ermitteln Java Basics - Anfänger-Themen 18
K float to String Java Basics - Anfänger-Themen 11
T Fehler beim Konvertieren (String --> Float) Java Basics - Anfänger-Themen 5
C Falsches Ergebnis float-Addition Java Basics - Anfänger-Themen 10
N Datentypen Warum Compilerfehler bei float f = 4.0; Java Basics - Anfänger-Themen 2
X Float ausgeben Java Basics - Anfänger-Themen 3
B Datentypen char, int, float in String Variable speichern Java Basics - Anfänger-Themen 4
M Float und double Java Basics - Anfänger-Themen 11
S Datentypen float statt void Java Basics - Anfänger-Themen 3
J String => Float Problem Java Basics - Anfänger-Themen 10
C Datentypen Float und Double Java Basics - Anfänger-Themen 2
M Float auf bestimmte Nachkommazahl runden Java Basics - Anfänger-Themen 3
D Datentypen Parse float[] to int[] Java Basics - Anfänger-Themen 4
S Long und Float Frage Java Basics - Anfänger-Themen 2
lenniii float[] Java Basics - Anfänger-Themen 2
S casten array in int von float Java Basics - Anfänger-Themen 5
P float Eingabe wird nicht akzeptiert, obwohl Variable als float deklariert Java Basics - Anfänger-Themen 2
M Vergleich Float-, Doublewert Java Basics - Anfänger-Themen 10
F Array in double/float Java Basics - Anfänger-Themen 4
A text mit float ausgeben Java Basics - Anfänger-Themen 14
G float - Frage Java Basics - Anfänger-Themen 2
G Float schneidet nach dem Rechnen auf eine Stelle ab Java Basics - Anfänger-Themen 9
G String zu float oder int Java Basics - Anfänger-Themen 3
P Float wisenschaftliche Ausgabe/Exponenten Java Basics - Anfänger-Themen 2
G Float Nachkommazahlen vergleichen Java Basics - Anfänger-Themen 7
G PRoblem mit rekursiver float additions methode Java Basics - Anfänger-Themen 9
O Object in Float konvertieren Java Basics - Anfänger-Themen 2
F bei einem Float nur x Stellen nach dem Komma anzeigen ? Java Basics - Anfänger-Themen 7
D Formatierung: ganzzahlige Float Werte nach Int Java Basics - Anfänger-Themen 2
V Exponentieren mit Exponenten vom Typ float Java Basics - Anfänger-Themen 2
J einlesen von datei, float und array und und und. Java Basics - Anfänger-Themen 7
B Vector nach float[] casten Java Basics - Anfänger-Themen 6
S float in int umwandeln? Java Basics - Anfänger-Themen 4
N String -> float Java Basics - Anfänger-Themen 3
M Float-Zahl auf x Stellen beschränken Java Basics - Anfänger-Themen 6
M Problem mit float und nullzuweisung Java Basics - Anfänger-Themen 15
M Float in String umwandeln Java Basics - Anfänger-Themen 9
G float in int wandeln Java Basics - Anfänger-Themen 2
H float Java Basics - Anfänger-Themen 3
K Eingabe von float werten Java Basics - Anfänger-Themen 4
sambalmueslie Float.parseFloat Java Basics - Anfänger-Themen 5
G Frage zur Objekt-Wrapper Float ? Java Basics - Anfänger-Themen 6
R float Variable aus String Java Basics - Anfänger-Themen 8
D HILFE bei float to String Java Basics - Anfänger-Themen 6
& String to Float Java Basics - Anfänger-Themen 7
G Frage zur Eingabe von Float ? Java Basics - Anfänger-Themen 4
G float-Array _ohne_ Arrays.sort sortieren Java Basics - Anfänger-Themen 5
W String into Float Java Basics - Anfänger-Themen 7
D Zahlen von Typ float aus einer Textdatei lesen Java Basics - Anfänger-Themen 2
R switch erlaubt keine float/double-Rechnung Java Basics - Anfänger-Themen 5

Ähnliche Java Themen

Neue Themen


Oben