![]() |
MD5-Hash wirft Integer-Überlauf Exception (EIntOverflow)
Liste der Anhänge anzeigen (Anzahl: 1)
Guten Morgen erst mal,
ich sitze zurzeit an einem sehr komischen Problem: Und zwar handelt es sich darum, dass ich über die Unit, welche ich in den Anhang gesteckt habe, einen MD5-Hash ausgeben lassen will. Bisher, d.h. so circa 2 Monate lang ging es auch ohne Problem, nur seit gestern macht die Unit zicken und wirft mit jedes Mal, wenn ich die Anwendung ausführe eine EIntOverflow-Exception. Ich weiß nicht mehr weiter... Vor allem, weil es bisher wunderbar funktioniert hat. In Zeile 111 erscheint dann der folgende Fehler: Zitat:
Delphi-Quellcode:
Noch ein paar Informationen:
{Z:109} procedure FF(var a: DWORD; b, c, d, x: DWORD; s: BYTE; ac: DWORD);
{Z:110} begin {Z:111} inc(a, F(b, c, d) + x + ac); // <<< hier tritt der Fehler auf... {Z:112} rot(a, s); {Z:113} inc(a, b); {Z:114} end; // Die Werte: // a = 1732584193 // b = 4023233417 // c = 2562383102 // d = 271733878 // x = 128 // s = 7 // ac = 3614090360 - wir sind eine Gruppe von Programmieren, d.h. ich kann nicht genau sagen wer, was, wann, wie geändert hat! - das Projekt umfasst doch mehrere tausend Zeilen - wir arbeiten mit der BDS 2006 (ohne Updates, soweit ich weiß) - ich habe die Unit aus dem Internet geladen und daran nicht geändert! - Ich habe auch schon andere Units getestet, mit dem selben Fehler! Ich hoffe Ihr könnt mir hierbei weiterhelfen. Ich bin echt am verzweifeln :wall: Mit freundlichen Grüßen der Hai [edit] Schreibfehler gefunden und für schlecht empfunden ;) [/edit] |
Re: MD5-Hash wirft Integer-Überlauf Exception (EIntOverflow)
Hey,
ich könnt echt die Wand hochlaufen... Hab den Fehler selbst gefunden :wall: schon toll, dass jemand an den Projekteinstellungen rumgedreht hat. Man kann dort unter den Compiler-Einstellungen (nicht Compiler-Meldungen) die Laufzeitfehler einstellen. Dort war ein Haken bei der Überlaufprüfung gesetzt, welcher dort nicht stehen sollte. >>> Haken rausgenommen, keinerlei Fehler mehr, Programmierer glücklich ;) Mit freundlichen Grüßen der Hai |
Re: MD5-Hash wirft Integer-Überlauf Exception (EIntOverflow)
Zitat:
Zitat:
Ansonsten wenn der Überlauf gewollt ist, dann sollte man die Überlaufprüfung nur für den Bereich abschalten und für das Projekt als solches aber einschalten. Gleiches gilt für die Bereichsprüfung! |
Re: MD5-Hash wirft Integer-Überlauf Exception (EIntOverflow)
Man sollte dann eher {$R-} verwenden. Es kann ja sein, dass jemand anderes den globalen Schalter gesetzt hat, weil er will dass in den von ihm programmierten Modulen Exceptions auftreten und entsprechen abgefangen werden. In den von ihm erstellten Sourcen sollte dann explizit {R+} eingefügt werden.
|
Re: MD5-Hash wirft Integer-Überlauf Exception (EIntOverflow)
Zitat:
Der Sinn und Zweck dieser Compilerschalter ist doch Codestellen zu finden, welche nicht ordentlich funktionieren bzw. sich ungewollt verhalten. Wenn du explizit Codebereiche fest markierst, welche überprüft werden sollen, dann blendest du haufenweise anderen Code aus, welcher genau solche Problemfälle beinhaltet. Wenn ich schon weiß wo der Fehler liegt, ist das ok, aber die Optionen sollen doch helfen Code zu finden, wo man keinen Fehler vermutet, dieser aber trotzdem welche enthält. $R ist die Bereichsprüfung und nicht die Überlaufprüfung! |
Re: MD5-Hash wirft Integer-Überlauf Exception (EIntOverflow)
Zitat:
Zitat:
|
Re: MD5-Hash wirft Integer-Überlauf Exception (EIntOverflow)
Du könntest auch folgendes mal probieren...
Delphi-Quellcode:
Damit lässt sich meine MD5 zumindest compilen,auch mit den genannten Prüfroutinen..
procedure FF(var a: DWORD; b, c, d, x: DWORD; s: BYTE; ac: DWORD);
begin a:=a+F(b, c, d) + x + ac; rot(a, s); a:=a+b; end; |
Re: MD5-Hash wirft Integer-Überlauf Exception (EIntOverflow)
Compilieren lies es sich immer! Nur während der Laufzeit hab ich dann die Exception bekommen. Hätte ich wohl noch dazu erwähnen können :oops:
|
Re: MD5-Hash wirft Integer-Überlauf Exception (EIntOverflow)
Bei MD5 (und den meisten anderen Hashalgorithmen) MUSS {$Q-} gesetzt sein, weil dort Integerarithmetik mod 2^32 benutzt wird, und mit 32Bit-Arithmetik Überlaufe praktisch immer vorkommen. Die Alternative wäre 64-Bit-Arithmetik und nach jeder Operatiion ein and $FFFFFFFF dazu programmieren.
Damit ist aber die Performance ziemlich runter und übersichtlicher ist es auch nicht. Man muss halt wissen was man macht, und hier ist {$Q-} definitiv angebracht. Man kann allerdings die entsprechenden Proceduren mit {$Q-}...{$Q+] klammern und immer den Standardwert wieder herstellen. Gruß Gammatester |
Re: MD5-Hash wirft Integer-Überlauf Exception (EIntOverflow)
Zitat:
alternativ könnte ich noch negaH's DEC empfehlen, dort wird per ASM gearbeitet und die Fehlerprüfung somit umgangen. eine Implementation ist ebenfalls in ASM, also auch keine Probleme und zu guter Letzt könnte man sich auch direkt an Windows wenden, dessen Implementation (seit Win2000 immer dabei) hat auch nicht soclhe Problemchen, |
Re: MD5-Hash wirft Integer-Überlauf Exception (EIntOverflow)
Zitat:
Delphi-Quellcode:
Man muß also selektiv erstmal abfragen ob $R+ aktiviert wurde und nur dann $R+ auch wieder einschalten, ansonsten würde man ja $R+ einschalten obwohl es vorher in den globalen Compilerswitches nicht aktiviert war.
{$ifopt R+}
{ $define RangeCheckOn} {$endif} {$R-} procedure OhneRangeCheck; begin end; {$ifdef RangCheckOn $R+ $endif} Alternaiv kann man einen Switch lokal innerhalb der Procedure aktivieren, ich habe aber die Erfahrung gemacht das das je nach Compilerversion nicht richtig funktioniert bzw. Seiteneffekte provoziert. Gruß hagen |
Re: MD5-Hash wirft Integer-Überlauf Exception (EIntOverflow)
Hallo,
in den Turbo-Pascal-Zeiten gab es für die Compilerschalter neben den Optionen "+" und "-" noch die Option "=", die den vorigen Zustand des Schalters wiederherstellte. Delphi bietet diese Möglichkeit leider nicht mehr, man kann sich aber relativ leicht behelfen, indem man für den betreffenden Schalter Include-Dateien im Bibliothekspfad bereitstellt und diese einbindet:
Delphi-Quellcode:
Bei Verwendung dieser Include-Dateien sieht Hagens Beispiel so aus:// Datei "R+.pas" {$ifopt R-} {$undef RangeCheckIsOn} {$R+} {$else} {$define RangeCheckIsOn} {$endif} // Datei "R-.pas" {$ifopt R+} {$define RangeCheckIsOn} {$R-} {$else} {$undef RangeCheckIsOn} {$endif} // Datei "R=.pas" {$ifdef RangeCheckIsOn} {$R+} {$else} {$R-} {$endif}
Delphi-Quellcode:
Gruß Hawkeye
{$I R-}
procedure OhneRangeCheck; begin end; {$I R=} |
Re: MD5-Hash wirft Integer-Überlauf Exception (EIntOverflow)
Normalerweise müsste es auch so gehen
Delphi-Quellcode:
weil diese Switches dann nur lokale Gültigkeit haben sollten (per Definition). Leider hat das Nachteile da verschiedene Delphiversionen sich nicht daran halten oder zb. ausgehend von den übergebenen Parametern denoch ihren Rangcheck aktivieren. Zumal die Range/Overflowcheks mit jeder neueren Delphiversion immer unzuverlässiger werden, mal schlagen sie zu wenn es nicht richtig ist mal schlagen sie nicht zu wenn es richtig wäre.
procedure OhneRangeCheck(params);
{$R-} begin end; PS: eine Include sollte die Extension .inc haben und nicht .pas ;) Gruß Hagen |
Re: MD5-Hash wirft Integer-Überlauf Exception (EIntOverflow)
Hallo Hagen,
Zitat:
Zitat:
Zitat:
Zitat:
Gruß Hawkeye |
Re: MD5-Hash wirft Integer-Überlauf Exception (EIntOverflow)
Zitat:
1. Wir reden hier von Overflowcheck, also $Q+ oder $Q- 2. Dein {$ifdef RangCheckOn $R+ $endif} ist nicht sehr sinnvoll. Richtig wäre
Delphi-Quellcode:
Also richtig
{$ifdef RangCheckOn} {$R+} {$endif}
Delphi-Quellcode:
Gruß Gammatester
{$ifopt Q+}
{$define TurnonQ} {$Q-} {$else} {$undef TurnonQ} {$endif} procedure OhneOverflowCheck; begin end; {$ifdef TurnonQ} {$Q+} {$endif} |
Re: MD5-Hash wirft Integer-Überlauf Exception (EIntOverflow)
hatte es mal aus Interesse einfach getestet und...
Delphi-Quellcode:
tja, mit Lokal ala
Program Project1;
{$APPTYPE CONSOLE} Uses SysUtils; // wegen Compileroptimierung und Nutzungswarnung: // If i = 0 Then ; {$OVERFLOWCHECKS ON} Procedure P1; Var i: Integer; Begin i := MaxInt; If i = 0 Then ; Try Inc(i); If i = 0 Then ; WriteLn('P1 - OverflowChecks OFF (global ON)'); Except WriteLn('P1 - OverflowChecks ON (global ON)'); End; End; {$OVERFLOWCHECKS OFF} Procedure P2; Var i: Integer; Begin i := MaxInt; If i = 0 Then ; Try Inc(i); If i = 0 Then ; WriteLn('P2 - OverflowChecks OFF (global OFF)'); Except WriteLn('P2 - OverflowChecks ON (global OFF)'); End; End; Procedure P3; {$OVERFLOWCHECKS ON} Var i: Integer; Begin i := MaxInt; If i = 0 Then ; Try Inc(i); If i = 0 Then ; WriteLn('P3 - OverflowChecks OFF (global OFF, local ON)'); Except WriteLn('P3 - OverflowChecks ON (global OFF, local ON)'); End; End; Procedure P4; Var i: Integer; Begin i := MaxInt; If i = 0 Then ; Try Inc(i); If i = 0 Then ; WriteLn('P4 - OverflowChecks OFF (global OFF)'); Except WriteLn('P4 - OverflowChecks ON (global OFF)'); End; End; {$OVERFLOWCHECKS OFF} Procedure P5; Var i: Integer; Begin i := MaxInt; If i = 0 Then ; Try {$OVERFLOWCHECKS ON} Inc(i); If i = 0 Then ; {$OVERFLOWCHECKS OFF} WriteLn('P5 - OverflowChecks OFF (global OFF, local ON)'); Except WriteLn('P5 - OverflowChecks ON (global OFF, local ON)'); End; End; Procedure P6; Var i: Integer; Begin i := MaxInt; If i = 0 Then ; Try Inc(i); If i = 0 Then ; WriteLn('P6 - OverflowChecks OFF (global OFF)'); Except WriteLn('P6 - OverflowChecks ON (global OFF)'); End; End; Begin P1; P2; P3; P4; P5; P6; ReadLn; End.
Delphi-Quellcode:
ist wohl nix :angel:
procedure OhneRangeCheck(params);
{$R-} begin
Code:
1: hier hat wohl noch die P3 'ne Nachwirkung
P1 - OverflowChecks ON (global ON)
P2 - OverflowChecks OFF (global OFF) P3 - OverflowChecks ON (global OFF, local ON) [color=#ff0000]P4 - OverflowChecks ON (global OFF)[/color] [color=gray]<< 1[/color] P5 - OverflowChecks OFF (global OFF, local ON) [color=gray]<< 2[/color] P6 - OverflowChecks OFF (global OFF) 2: hmmm ... irgendwie sollte hier doch auch ON stehn :shock: |
Alle Zeitangaben in WEZ +1. Es ist jetzt 00:47 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-2025 by Thomas Breitkreuz