![]() |
AW: Datentypen und Genauigkeitsverluste?
Zitat:
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:
Falls du tatsächlich mal auf die Nase gefallen bist, lag es vielleicht gerade an der ![]() |
AW: Datentypen und Genauigkeitsverluste?
@jfheinz
vielleicht ist er ja auch über den Unterschied zwischen Currency und Double gestolpert. Da wird zwar immer wieder darauf hingewiesen, aber oft genug wird Currency als "so 'n neumodisches Zeug" angesehen. Gruß K-H |
AW: Datentypen und Genauigkeitsverluste?
Zitat:
Zitat:
Genau genommen ist es so, dass die Double Werte mit FLD xx und der Integerwert mit FILD xx in die FPU geladen werden und dort mit der Genauigkeit der FPU (80 Bit, davon 64 Mantisse, 15 Exponent, 1 Vorzeichen) verarbeitet werden. |
AW: Datentypen und Genauigkeitsverluste?
Double hat 15–16 signifikante Stellen, demnach kann man, unabhängig vom möglichen Wertebereich (5.0 * 10^-324 bis 1.7 * 10^+308) auf jeden Fall 15 aufeinanderfolgende Dezimalstellen definitiv/sicher verwenden.
Bei 8 Nachkommastellen also noch 7 Vorkommastellen (15-8=7) ... -9999999.99999999 bis +9999999.99999999 |
AW: Datentypen und Genauigkeitsverluste?
Wie es bei Java ist, weiß ich nicht, aber bei SQL werden zumindest explizite Datentypen nicht konvertiert.
SQL-Code:
Bei den ersten beiden Varianten muss eine explizite Typkonvertierung vorgenommen werden, um zum gewünschten Ergebnis zu kommen.
select cast (1 as int)/2
--versus select myIntField/2 from myTable -- versus select 1/2 Sicherheitshalber sollten Konstanten stehts als Gleitkomma geschrieben werden, also:
SQL-Code:
Vielleicht meint er das.
select cast (1 as int)/2.0
--versus select myIntField/2.0 from myTable -- versus select 1.0/2.0 -- Hier eigentlich nicht nötig Wie schon erwähnt: In Delphi ist-das-nicht-n-ö-t-i-g :stupid: |
Alle Zeitangaben in WEZ +1. Es ist jetzt 06:55 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz