Einzelnen Beitrag anzeigen

Benutzerbild von jfheins
jfheins

Registriert seit: 10. Jun 2004
Ort: Garching (TUM)
4.579 Beiträge
 
#11

AW: Datentypen und Genauigkeitsverluste?

  Alt 20. Jul 2012, 15:38
@Jfheinz
warum wird dann an vielen Stellen darauf hingewiesen, das man wenn man mit einem Fließkommawert multiplizieren will man z.b. 2.0 anstatt 2 schreiben soll.
Der Compiler kann doch nicht richen was gemeint ist? Ich bin da unter Java schonmal böse auf die Nase gefallen.
Zeig mal bitte so eine Stelle. Beim Multiplizieren ist es egal, beim Dividieren nicht.
Grund:
Auf der Menge der ganzen Zahlen int kann man Addition, Subtraktion und Multiplikation durchführen, ohne die Menge zu verlassen.
Damit das mit der Division auch klappt, muss man das ganze aber auf den Körper der rationalen Zahlen erweitern.
(Ganze Zahlen = int, rationale Zahlen = Float)
Wenn man also zwei Integer multipliziert, kommt stets eine ganze Zahl raus.
Sobald an einer Rechnung in Java ein Float beteiligt ist, wird das Ergebnis der Rechnung ebenfalls ein Float sein. (Und nicht vorher!)

Bei deinem Beispiel:
Zitat:
Double:= Double * Double; -> zb. X:= 1,15478 * 2 vs. X:= 1,15478 * 2.0
(2 und 2.0 sind in dem Fall konstanten)
Macht das also keinen Unterschied. Da bereits der erste Operand ein Float ist, wird die gesamte Rechnung mit Floats gemacht. Die 2 wird dann einfach konvertiert. Im Rahmen der Maschinengenauigkeit liefern beide Rechnungen das gleiche Ergebnis.

Falls du tatsächlich mal auf die Nase gefallen bist, lag es vielleicht gerade an der Maschinengenauigkeit - das hat dann aber nur bedingt etwas mit der Multiplikation zu tun

Geändert von jfheins (20. Jul 2012 um 15:42 Uhr)
  Mit Zitat antworten Zitat