AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

EIntOverflow bei LongWord, nicht aber bei Word

Ein Thema von Der schöne Günther · begonnen am 28. Mai 2018 · letzter Beitrag vom 29. Mai 2018
Antwort Antwort
Benutzerbild von Zacherl
Zacherl

Registriert seit: 3. Sep 2004
4.629 Beiträge
 
Delphi 10.2 Tokyo Starter
 
#1

AW: EIntOverflow bei LongWord, nicht aber bei Word

  Alt 29. Mai 2018, 15:04
Ich glaube Günther geht es darum, dass seine Word + Word Expression nicht vor der Addition erweitert wurde (da ja schon erkennbar ist, dass der temporäre Wert direkt einem Double zugewiesen werden soll). Unter C printed folgender Code:
Code:
Word a = 1000;
Word b = 10000;
printf("%f", (double)(a - b))
übrigens "-9000.000000".
Projekte:
- GitHub (Profil, zyantific)
- zYan Disassembler Engine ( Zydis Online, Zydis GitHub)

Geändert von Zacherl (29. Mai 2018 um 15:19 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.012 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#2

AW: EIntOverflow bei LongWord, nicht aber bei Word

  Alt 29. Mai 2018, 15:16
Ich glaube Günther geht es darum, dass seine Word + Word Expression nicht vor der Addition erweitert wurde
Nope, es geht darum, dass je nach Größe des Ordinaltypes trotz {$OVERFLOWCHECKS ON} on keiner kommt.


Unter C printed folgender Code:
Code:
Word a = 1000;
Word b = 10000;
printf("%f", (double)(a - b))
übrigens "-9000.000000".
C schert sich auch nicht um Overflows.
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight

Geändert von Stevie (29. Mai 2018 um 15:19 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Zacherl
Zacherl

Registriert seit: 3. Sep 2004
4.629 Beiträge
 
Delphi 10.2 Tokyo Starter
 
#3

AW: EIntOverflow bei LongWord, nicht aber bei Word

  Alt 29. Mai 2018, 15:27
Ich glaube Günther geht es darum, dass seine Word + Word Expression nicht vor der Addition erweitert wurde
Nope, es geht darum, dass je nach Größe des Ordinaltypes trotz {$OVERFLOWCHECKS ON} on keiner kommt.
Sorry, das "nicht" war mir reingerutscht. Genau, das ist klar. Ohne eine Erweiterung auf 32-Bit würde es aber ja funktionieren. Oder halt wie oben irgendwo angemerkt über das Carry-Flag statt des Overflow-Flags.

Unter C printed folgender Code:
Code:
Word a = 1000;
Word b = 10000;
printf("%f", (double)(a - b))
übrigens "-9000.000000".
C schert sich auch nicht um Overflows.
Macht Delphi im Grunde ja auch nicht. Der C-Code schiebt die Werte auch erst in ein 32-Bit Register, verrechnet sie und verwendet dann SSE/AVX für die Konvertierung nach Double. Caste ich statt nach Double in Word, wird einfach Truncated, was dann einem Überlauf gleichkommt. Wollte hiermit nur andeuten, dass die eigentliche Berechnung in Delphi schon soweit konform zu sein scheint. Lediglich der eigentliche Overflow-Check ist halt an der Stelle verbuggt.
Projekte:
- GitHub (Profil, zyantific)
- zYan Disassembler Engine ( Zydis Online, Zydis GitHub)
  Mit Zitat antworten Zitat
Der schöne Günther

Registriert seit: 6. Mär 2013
6.114 Beiträge
 
Delphi 10 Seattle Enterprise
 
#4

AW: EIntOverflow bei LongWord, nicht aber bei Word

  Alt 29. Mai 2018, 17:00
Eine ganz peinliche Frage, ich mache ja noch nicht lange Delphi

Ich sehe in Delphi keine Äquivalent zu C's (double)(a - b) außer vielleicht a*1.0 - b . Gibt es etwas besseres außer vielleicht einer zusätzlichen Variable der man dann a zuweist?
  Mit Zitat antworten Zitat
gammatester

Registriert seit: 6. Dez 2005
999 Beiträge
 
#5

AW: EIntOverflow bei LongWord, nicht aber bei Word

  Alt 29. Mai 2018, 17:12
Ich sehe in Delphi keine Äquivalent zu C's (double)(a - b) außer vielleicht a*1.0 - b . Gibt es etwas besseres außer vielleicht einer zusätzlichen Variable der man dann a zuweist?
int(a) - int(b) oder int(a-b) sollte auch funktionieren.

Geändert von gammatester (29. Mai 2018 um 17:23 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
43.249 Beiträge
 
Delphi 12 Athens
 
#6

AW: EIntOverflow bei LongWord, nicht aber bei Word

  Alt 29. Mai 2018, 17:15
Delphi-Quellcode:
CCast = PascalCast

(double)(a - b) = Double(a - b)

(double)a - b = Double(a) - b

(double)a - (double)b = Double(a) - Double(b)

(double)((integer)a - (integer)b) = Double(Integer(a) - Integer(b))
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests

Geändert von himitsu (29. Mai 2018 um 17:17 Uhr)
  Mit Zitat antworten Zitat
Der schöne Günther

Registriert seit: 6. Mär 2013
6.114 Beiträge
 
Delphi 10 Seattle Enterprise
 
#7

AW: EIntOverflow bei LongWord, nicht aber bei Word

  Alt 29. Mai 2018, 17:45
Dann ist mein Delphi wohl kaputt, denn das kompiliert alles nicht.

Delphi-Quellcode:
procedure p();
var
   a:   LongWord;
   b:   LongWord;
   asFloat: Double;
begin
   a := 0;
   b := 1;
   asFloat := Double(a-b); // E2089 "Ungültige Typumwandlung"
end;
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
43.249 Beiträge
 
Delphi 12 Athens
 
#8

AW: EIntOverflow bei LongWord, nicht aber bei Word

  Alt 29. Mai 2018, 18:00
Sehr eigenartig, der implizite Cast asFloat := a-b; funktioniert, aber der Explizite nicht.

Ich mache sowas selten/nie, drum bin ich jetzt auch überrascht, dass nichtmal ein asFloat := Double(a); geht.
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests

Geändert von himitsu (29. Mai 2018 um 18:02 Uhr)
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 21:08 Uhr.
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