Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   Multiplikation von Integerwerten gibt Überlauf (https://www.delphipraxis.net/126668-multiplikation-von-integerwerten-gibt-ueberlauf.html)

Xplosion 30. Dez 2008 15:40


Multiplikation von Integerwerten gibt Überlauf
 
Hi

bei folgendem Source spuckt der Compiler folgende Fehlermeldung aus:
'E2099 Überlauf bei Konvertierung oder arithmetischer Operation'

Delphi-Quellcode:
var
  nSize : Int64;
  nPotenz : Integer
  //nPotenz : Int64; <<< Funktioniert

nPotenz := 1024;

if nSize > (nPotenz) then
  AFormat := 'fsKilobyte';
if nSize > (nPotenz * nPotenz) then
  AFormat := 'fsMegabyte';
if nSize > (nPotenz * nPotenz * nPotenz) then
  AFormat := 'fsGigabyte';
if nSize > (nPotenz * nPotenz * nPotenz * nPotenz) then <<< Fehler weil > 32Bit
  AFormat := 'fsTerabyte';
if nSize > (nPotenz * nPotenz * nPotenz * nPotenz * nPotenz) then <<< Fehler weil > 32Bit
  AFormat := 'fsPetabyte';
Warum ist da so? :gruebel:

Das Geheimnis liegt in der Variablendeklaration von 'nPotenz'. Integer funktioniert nicht, Int64 schon, obwohl ich der Variable 'nPotenz' ja gar nix größers als Integer zuweisen will.

Hätte mal gern gewusst, warum kann das Ergebnis einer Multiplikation nicht größer sein als der Bereich der Variable, die für die Multiplikation benutzt wird? Ist das nur beim Delphi Compiler so?

Torpedo 30. Dez 2008 15:46

Re: Multiplikation von Integerwerten gibt Überlauf
 
Zitat:

Zitat von Xplosion
warum kann das Ergebnis einer Multiplikation nicht größer sein als der Bereich der Variable, die für die Multiplikation benutzt wird?

Na irgendwo muss das Ergebnis ja zwischengespeichert werden ;) Und da wird der selbe Variablentyp benutzt.
Zitat:

Zitat von Xplosion
Ist das nur beim Delphi Compiler so?

Nein

Dax 30. Dez 2008 15:46

Re: Multiplikation von Integerwerten gibt Überlauf
 
Das ist überall so. Schreib zwei Blätter mit jeweils einer Zahl voll, das Ergebnis passt nicht auf eines (in der Regel) ;) Integer geht bis 2^31 - 1, also bis (bei dir) knapp unter 2 Gigabyte.

Reinhard Kern 30. Dez 2008 15:50

Re: Multiplikation von Integerwerten gibt Überlauf
 
Zitat:

Zitat von Xplosion
Hätte mal gern gewusst, warum kann das Ergebnis einer Multiplikation nicht größer sein als der Bereich der Variable, die für die Multiplikation benutzt wird? Ist das nur beim Delphi Compiler so?

Hallo,

so ist es ja nicht, aber das Ergebnis kann nicht grösser sein als die Variable, in der das Ergebnis gespeichert werden soll - logisch, man kann ja auch nicht 100 l Wasser in einer Sprudelflasche unterbringen. Das sind Grundlagen der Datenverarbeitung überhaupt: im Computer gibt es keine unendlich grossen Zahlen, daher gibt es bei JEDEM Datentyp Zahlen, die nicht mehr hineinpassen.

Gruss Reinhard

Hawkeye219 30. Dez 2008 17:07

Re: Multiplikation von Integerwerten gibt Überlauf
 
Hallo,

den "Fehler" kannst du auch umgehen, indem du den Compiler zwingst, Code für eine Berechnung auf Int64-Basis zu erzeugen:

Delphi-Quellcode:
var
  nPotenz : Integer;
begin
  :
  if nSize > (Int64(nPotenz) * nPotenz * nPotenz * nPotenz) then
    AFormat := 'fsTerabyte';
  if nSize > (Int64(nPotenz) * nPotenz * nPotenz * nPotenz * nPotenz) then
    AFormat := 'fsPetabyte';
end;
Gruß Hawkeye

Xplosion 30. Dez 2008 17:47

Re: Multiplikation von Integerwerten gibt Überlauf
 
Hallo
der Vergleich mit zwei Blatt Papier oder 100 L Wasser ist ja sehr anschaulich, aber meiner Meinung nach nicht mal richtig.
Was die Lösung ist, hab ich ja selbst gepostet.

Zitat:

so ist es ja nicht, aber das Ergebnis kann nicht grösser sein als die Variable, in der das Ergebnis gespeichert werden soll - logisch, man kann ja auch nicht 100 l Wasser in einer Sprudelflasche unterbringen. Das sind Grundlagen der Datenverarbeitung überhaupt: im Computer gibt es keine unendlich grossen Zahlen, daher gibt es bei JEDEM Datentyp Zahlen, die nicht mehr hineinpassen.
Ja in welcher Variable wird das Ergebniss gespeichert? In der Integer Variable 'nPotenz'? Kann nicht sein, denn wenn ich 'nPotenz : Integer' als 'nPotenz : Word' deklariere, müsste nach eurer Meinung bei 65535 Schluss sein, bzw. ein Überlauffehler kommen. Ist aber nicht so.

Delphi-Quellcode:
var
  nSize : Int64;
  nPotenz : Word;

nPotenz := 1024;

if nSize > (nPotenz) then
  AFormat := 'fsKilobyte';
if nSize > (nPotenz * nPotenz) then <<< funktioniert obwohl größer als 65535
  AFormat := 'fsMegabyte';
if nSize > (nPotenz * nPotenz * nPotenz) then <<< funktioniert obwohl größer als 65535
  AFormat := 'fsGigabyte';
if nSize > (nPotenz * nPotenz * nPotenz * nPotenz) then <<< hier knallt es wieder weil, > 32Bit
  AFormat := 'fsTerabyte';
if nSize > (nPotenz * nPotenz * nPotenz * nPotenz * nPotenz) then
  AFormat := 'fsPetabyte';
Der Delphi Compiler verwendet also anscheinend für Multiplikationen (intern !!!) einen Integer als Speicheradresse. Liegt warscheinlich daran, dass das aktuelle RAD 2007 noch kein 64Bit Compiler ist.

Hawkeye219 30. Dez 2008 17:53

Re: Multiplikation von Integerwerten gibt Überlauf
 
Bei arithmetischen Operationen wird laut Dokumentation immer der größte Datentyp aller beteiligten Operanden verwendet, "kleine" Typen (Byte, Word,...) werden dabei zunächst auf Integer erweitert. Dies erklärt, warum in deinem letzten Beispiel die Operationen fehlerfrei durchgeführt werden können.

Gruß Hawkeye

alzaimar 30. Dez 2008 18:55

Re: Multiplikation von Integerwerten gibt Überlauf
 
Zitat:

Zitat von Xplosion
der Vergleich mit zwei Blatt Papier oder 100 L Wasser ist ja sehr anschaulich, aber meiner Meinung nach nicht mal richtig...
Ja in welcher Variable wird das Ergebniss gespeichert?

Bisserl nassforsch, wie? Vergleiche hinken, das liegt in der Natur der Sache. Man könnte auch bemängeln, das 100 L Wasser gar nichts mit Integer-Zahlen zu tun hat... :roll:

Oreaden 30. Dez 2008 19:05

Re: Multiplikation von Integerwerten gibt Überlauf
 
Zitat:

Zitat von Xplosion
wenn ich 'nPotenz : Integer' als 'nPotenz : Word' deklariere, müsste nach eurer Meinung bei 65535 Schluss sein, bzw. ein Überlauffehler kommen.

Dieser kommt auch auf einen 16Bit oder 8Bit System. Aktuell dürftest Du eine 32Bit Architektur haben, und da passen halt 16Bit hinein. Das ist der Grund, ansonsten kannst Du gerne die Überlaufprüfung ausschalten, dann meckert niemand mehr.

Wünsche einen schönen Abend
OREADEN

3_of_8 30. Dez 2008 19:09

Re: Multiplikation von Integerwerten gibt Überlauf
 
...wobei dann aber wiederum Folgefehler auftreten können bzw. sogar wahrscheinlich auftreten.


Alle Zeitangaben in WEZ +1. Es ist jetzt 21:03 Uhr.
Seite 1 von 2  1 2      

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz