![]() |
Delphi-Version: XE5
Merkwürdiges Verhalten intrinsischer Routinen
Hallo DP-Community,
ich hab mal eine Frage. Diese ist zwar nicht überlebensnotwendug, ich glaube gedoch, dass es sich hierbei um einen kleinen "Bug" im Compiler handelt. Und zwar geht es um die intrinischen Routinen. In den ganz alten Pascalversionen musste man ja den Rückgabewert eine Methode zuweisen oder weiter verarbeiten. Dieses wurde aber kurzerhand wieder verworfen, und so konnte man dann, wie es auch in C-Sprachen üblich war, Funktionen aufrufen, ohne deren Rückgabewert weiterhin zu nutzen. Allerdings ist dies bei den "instrinischen Routinen" in Delphi bisher immer noch nicht möglich. Das ist zwar in den meisten Fällen nicht relevant, allerdings macht es meines Erachtens nach bei Methoden wie "Pi" keinen Sinn. Denn wenn man ein weiteres verarbeiten von beispielsweise Pi erzwingen wollte, hätte man ja auch einfach Pi zu einer Konstanten machen können, hat man aber nicht. Außerdem ergibt dieses Verhalten des DCC für mich keinen Sinn, da es ja sonst auch keine Rolle spielt, ob das Ergebnis weiterhin verarbeitet wird. Hier mal ein Beispiel:
Delphi-Quellcode:
Hinzu kommt noch, dass der Fehler ja auch nicht irgendwie heißt "Wert muss zugewiesen werden" oder so, sondern "Anweisung erforderlich, aber Ausdruck vom Typ 'Extended' gefunden". Hier wird also suggeriert, dass System.Pi gar keine Methode, aber ein "Ausdruck" (Konstante oder Variable) sei. Und das widerspricht ja letztenendes dem Oben gezeigten.
function GetPi: Double;
begin Result := 3.141592{...}; end; var F: Double; begin 3.141592; //Funktioniert nicht (logischerweise) F := 3.141592; //Funktioniert (logischerweise) GetPi; //Funktioniert (logischerweise) F := GetPi //Funktioniert (logischerweise) Pi; //Funktioniert nicht (?) F := Pi; //Funktioniert F := Pi(); //Funktioniert, beweist noch mal, dass System.Pi auch wirklich eine Methode und keine Konstante ist end; Liege ich komplett falsch, oder stimmt da etwas nicht so ganz? |
AW: Merkwürdiges Verhalten intrinsischer Routinen
Stimmt, Pi ist eine Function, wird aber vom Compiler offenbar wie eine Konstante behandelt.
Edit: Bei genauem hinsehen wird der Funktionsaufruf einfach in die Zuweisung einer Konstanten umgewandelt. Das ist halt Compiler-Magic. |
AW: Merkwürdiges Verhalten intrinsischer Routinen
Dann geht das hier vermutlich auch.
Delphi-Quellcode:
Mittlerweile finde ich es gut (von C#), das parameterlose Methoden als 'Foo()' aufgerufen werden müssen, und nicht als 'Foo'. Da kommt dann noch nicht mal der Compiler durcheinander.
Pi();
// PS: Ich dachte immer, Pi wäre eine Konstante. |
AW: Merkwürdiges Verhalten intrinsischer Routinen
Zitat:
Zitat:
|
AW: Merkwürdiges Verhalten intrinsischer Routinen
Ich auch nicht. Ich war mir sicher, dass das früher mal eine Konstante war.
|
AW: Merkwürdiges Verhalten intrinsischer Routinen
Zitat:
|
AW: Merkwürdiges Verhalten intrinsischer Routinen
In D2007 sagt die Hilfe, Pi sei die function Pi: Extended; in der system.pas. Pi ist dort aber nicht zu finden. :)
|
AW: Merkwürdiges Verhalten intrinsischer Routinen
Ich kann mir vorstellen, dass man die Idee hatte die Konstante aus dem Prozessor zu übernehmen, falls dieser das unterstützt. Intel-CPUs kennen den Befehl "FLDPI".
|
AW: Merkwürdiges Verhalten intrinsischer Routinen
WIMRE war Pi schon zu Turbo-Pascal-Zeiten eine Funktion. Ich könnte mir vorstellen, dass das was damit zu tun hat, dass früher die Gleitkommaunterstützung in der Hardware etwas "diffiziler" war als heutzutage (Coprozessor und so).
|
AW: Merkwürdiges Verhalten intrinsischer Routinen
Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 05:37 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