Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Float-Literale sind unumstößlich Extended? (https://www.delphipraxis.net/203181-float-literale-sind-unumstoesslich-extended.html)

Der schöne Günther 20. Jan 2020 19:27

Delphi-Version: 10.2 Tokyo

Float-Literale sind unumstößlich Extended?
 
Delphi-Quellcode:
const someConstant = 3.14
ist kein Single, kein Double, sondern Extended. Da kann ich nichts dran machen, richtig? Keine Compilerschalter, nichts?

http://docwiki.embarcadero.com/RADSt...True_Constants
Zitat:

if constantExpression is a real, its type is Extended.

Rollo62 20. Jan 2020 19:47

AW: Float-Literale sind unumstößlich Extended?
 
Probier mal so

Delphi-Quellcode:
Const
    kFeetToMeter: Double = 3.2808;

Der schöne Günther 20. Jan 2020 19:55

AW: Float-Literale sind unumstößlich Extended?
 
Ja, ich weiß dass ich Konstanten typisieren kann, aber ich meinte wirklich wenn im Quelltext einfach
Delphi-Quellcode:
3.14
steht. Ich weiß dass ich auch
Delphi-Quellcode:
Single(3.14)
schreiben könnte, aber es wäre natürlich schön wenn ich da herum käme...

Uwe Raabe 20. Jan 2020 20:20

AW: Float-Literale sind unumstößlich Extended?
 
Woher soll der Compiler denn wissen, welche Genauigkeit du haben willst, wenn du es ihm nicht sagst?

Stevie 20. Jan 2020 22:01

AW: Float-Literale sind unumstößlich Extended?
 
Irgendwie schon komisch, dass das ansonsten so typenvernarrte Pascal bei Konstanten son untypisierten Blödsinn zulässt :gruebel:

Uwe Raabe 20. Jan 2020 22:35

AW: Float-Literale sind unumstößlich Extended?
 
Zitat:

if constantExpression is a real, its type is Extended.
Diese Aussage ist falsch! Ich vermute, eine Float-Konstante ist ein Double, wenn sich die textuelle Darstellung exakt als Double darstellen lässt. Andernfalls ist es ein Extended. Außer bei 64-Bit, dann ist es immer ein Double.

Die Zahl 3.14 lässt sich zufälligerweise exakt als Double darstellen. Prüf mal
Delphi-Quellcode:
Sizeof(someConstant)
.

Uwe Raabe 20. Jan 2020 22:37

AW: Float-Literale sind unumstößlich Extended?
 
Zitat:

Zitat von Stevie (Beitrag 1455650)
Irgendwie schon komisch, dass das ansonsten so typenvernarrte Pascal bei Konstanten son untypisierten Blödsinn zulässt :gruebel:

Als Wirth Pascal 1974 erfand, konnte ein Zielsystem allenfalls eine Float-Darstellung - da hatte man keine Wahl. Die IEEE 754 ist von 1985.

himitsu 21. Jan 2020 08:02

AW: Float-Literale sind unumstößlich Extended?
 
Per se ist das erstmal garkein bestimmter Typ, denn dieser "Wert" wird an den Stellen eingesetzt (ähnlich einem Makro), wo er verwendet wird, und dort entscheidet sich dann jeweils der Typ, anhand dessen wo er zugewiesen wird.
Im Zweifelsfall ist es aber natürlich der größere Typ.

Die typisierten Konstanten sind "schreibgeschützte" Variablen, wo am Verwendungsort ein Zeiger darauf eingesetzt wird.
Delphi-Quellcode:
const
  kFeetToMeter = 3.2808;         // echte Konstante
  kFeetToMeter = Double(3.2808); // echte Konstante mit Vorgabe, kann am Verwendungsort sich aber noch ändern
  kFeetToMeter: Double = 3.2808; // typisierte Konstante

Der schöne Günther 21. Jan 2020 09:40

AW: Float-Literale sind unumstößlich Extended?
 
Liste der Anhänge anzeigen (Anzahl: 1)
Sorry, aber ich stimme euch nicht zu.

Erstens:

Delphi-Quellcode:
program Project1;

{$APPTYPE CONSOLE}

procedure acceptFloat(const input: Single) overload; deprecated 'Single';
begin
   //
end;

procedure acceptFloat(const input: Double) overload; deprecated 'Double';
begin

end;

procedure acceptFloat(const input: Extended) overload; deprecated 'Extended';
begin

end;

begin
   acceptFloat(3.14);
end.
Hier wird definitiv die Extended-Version aufgerufen.


Und zweitens: Wenn ich den Mauszeiger auf eine untypisierte Float-Konstante halte bekomme ich einen Tooltip der glasklar "Extended" sagt: Anhang 52023


Edit: Aber
Delphi-Quellcode:
SizeOf(myConst)
sagt tatsächlich 8, obwohl definitiv die Extended-Überladung aufgerufen wird. Jetzt bin ich noch verwirrter als vorher.

TiGü 21. Jan 2020 09:48

AW: Float-Literale sind unumstößlich Extended?
 
Zitat:

Zitat von Der schöne Günther (Beitrag 1455684)
Edit: Aber
Delphi-Quellcode:
SizeOf(myConst)
sagt tatsächlich 8, obwohl definitiv die Extended-Überladung aufgerufen wird. Jetzt bin ich noch verwirrter als vorher.

32- oder 64-Bit?


Alle Zeitangaben in WEZ +1. Es ist jetzt 23:11 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