![]() |
Delphi-Version: 10.3 Rio
Optionale (= vorbelegte) FunktionsParameter vom Type Record - Wie geht das?
Hallo Community,
ich möchte gerne Optionale (= vorbelegte) FunktionsParameter vom Type Record nach folgendem Muster verwenden:
Delphi-Quellcode:
So funktioniert es natürlich einwandfrei.
Function p_ex(V, T, n: Extended; z: Extended = 1.25): Extended;
Begin . . . End; Nun möchte ich einen vorbelegten Record als Parameter z übergeben:
Delphi-Quellcode:
was der Compiler freilich ablehnt.
Type
TDRecord = Record X: Double; Y: Double; End; Function p_Rec(V, T, n: Extended; z: TDRecord = (1.25, 2.5): Extended; Begin . . . End; Hat jemand eine Idee wie ich den Parameter z mit Default-Werten vorbelegen könnte? Geht das überhaupt? Danke im Voraus! Gruß, Andreas |
AW: Optionale (= vorbelegte) FunktionsParameter vom Type Record - Wie geht das?
Als Defaultparameter geht das nicht, aber mit overload:
Delphi-Quellcode:
function p_Rec(V, T, n: Extended; const z: TDRecord): Extended; overload;
begin . . . end; function p_Rec(V, T, n: Extended): Extended; overload; const z: TDRecord = (X: 1.25; Y: 2.5); begin Result := p_Rec(V, T, n, z); end; |
AW: Optionale (= vorbelegte) FunktionsParameter vom Type Record - Wie geht das?
Danke Uli für Deinen Vorschlag! Der einzige Schönheitsfehler ist nur, daß sich dadurch der Code verdoppelt und Redundanzen mit den bekannten Nachteilen entstehen.
Vielleicht kennt jemand einen noch besseren Weg? Gruß, Andreas |
AW: Optionale (= vorbelegte) FunktionsParameter vom Type Record - Wie geht das?
Das Record wie eine Klasse aufbauen, also per "strict private" variablen und einer "Init" methode vielleicht?
|
AW: Optionale (= vorbelegte) FunktionsParameter vom Type Record - Wie geht das?
Zitat:
|
AW: Optionale (= vorbelegte) FunktionsParameter vom Type Record - Wie geht das?
@KodeZwerg:
Die einfache herkömmliche Alternative wäre, in der rufenden Routine den Record z vorzubelegen
Delphi-Quellcode:
und z so als Parameter zu übergeben.
z.X:= 1.25; z.Y:= 2.5;
Daraus Klassen zu machen mit "strict private" Variablen und einer "Init" - Methode wäre eine Kanone auf ein Spätzchen, zumal ich etliche solche Funktionen mit Vorbelegung habe. Dadurch wäre sowohl der Code, als auch die Benutzung wesentlich komplizierter. @Uligerhardt: In manchen Fällen wäre es in der Tat nur ein dünner Wrapper, wenn die Werte in z linear in die Routine
Delphi-Quellcode:
eingehen, also wenn z.B. gilt:
p_Rec(V, T, n: Extended; const z: TDRecord): Extended;
Delphi-Quellcode:
Aber oft sind die Werte z.X und z.Y auf eine wesentlich kompliziertere, nichtlineare Art und Weise in der Funktion enthalten.
p_Rec(V, T, n, z) := z.X*p_Rec(V, T, n) + z.Y;
Man kann sich das etwa so vorstellen: Die StandardFunktion verwendet für die Berechnung einer komplexen Formel z.B.
Delphi-Quellcode:
. Es gibt aber noch Funktion_1, Funktion_2, Funktion_3 etc., welche mit der gleichen Formel aber mit verschiedenen z-Werten arbeiten können. In solchen Fällen wäre es kein dünner Wrapper mehr, sondern eine Duplizierung des Codes der Berechnungsroutine.
z.X:= 1.25; z.Y:= 2.5;
Aber für die linearen Fälle ist Dein Vorschlag mit
Delphi-Quellcode:
eine gute Lösung.
overload;
Danke & Gruß, Andreas |
AW: Optionale (= vorbelegte) FunktionsParameter vom Type Record - Wie geht das?
Zitat:
|
AW: Optionale (= vorbelegte) FunktionsParameter vom Type Record - Wie geht das?
Delphi-Quellcode:
Habe es gerade mal ausprobiert und es compiliert ohne einen Fehler zu werfen.
type
MyRec = packed record public procedure DoJob(const AValue: Integer = -1; const BValue: DOUBLE = 1.23); end; var Form15: TForm15; implementation {$R *.dfm} procedure MyRec.DoJob(const AValue: Integer = -1; const BValue: Double = 1.23); begin // end; |
AW: Optionale (= vorbelegte) FunktionsParameter vom Type Record - Wie geht das?
@Uligerhardt:
Zitat:
Hallo KodeZwerg, ja, aber damit hast Du den Record in optional vorbelegte Teile zerpflückt. Das würde bei mir etwa entsprechen:
Delphi-Quellcode:
Das habe schon lange so, was ohne Probleme funktioniert. Aber die Liste meiner optionalen Parameter kann auch mal deutlich länger sein bis zu 20 Elementen und mehr, daher dachte ich ein einen vorbelegten Record, weil dies übersichtlicher wäre.
Function p_Rec(V, T, n: Extended; X: Double = 1.25; X: Double = 2.5): Extended;
Begin . . . End; Hinzu kommt andererseits der eigentliche Auslöser, der mich über die Parameterübergabe als vorbelegten optionalen Record bewogen hat: Das ist die Verwendung der mathematischen Bibliothek Neslib.MultiPrecision. Das sind die Beweggründe & Vorläufer dafür, damit Ihr das Ganze besser verstehen könnt: 1): High-Precision Floating-Point Types for Delphi ![]() 2): High-Precision Floating-Point Types for Delphi - Hilfe beim Linken von C object files ![]() 3): Hilfe beim Linken von C object files in in Delphi XE5? ![]() 4): und meine Beiträge zu: ![]() Ich versuche momentan meine früheren Berechnungen testweise von
Delphi-Quellcode:
auf die höhere Genauigkeit DoubleDouble (32 Ziffern) und QuadDouble (64 Ziffern) umzustellen.
Extended
Beide neuen Datentypen sind im wesentlichen Records:
Delphi-Quellcode:
Und diese Records kann man nicht zerpflücken, denn die Teile des Record-Arrays enthalten die weiteren Nachkommastellen, die nicht vom Benutzer, sondern von der Bibliothek intern nach aufwendigen iterativen Berechnungen bestimmt werden.
Type
DoubleDouble = record public X: array [0..1] of Double; . . . End; . . . QuadDouble = record public X: array [0..3] of Double; . . . End; Damit ich meine zahlreichen "alten" Berechnungen, die viele vorbelegte optionale Parameter des Typs
Delphi-Quellcode:
enthalten auf
Extended
Delphi-Quellcode:
oder
DoubleDouble
Delphi-Quellcode:
umstellen kann, müßte ich vorbelegte Records übergeben können, oder auf die Annehmlichkeit der vorbelegten optionalen Parameter verzichten...
QuadDouble
Gruß, Andreas |
AW: Optionale (= vorbelegte) FunktionsParameter vom Type Record - Wie geht das?
Nun, der Compiler lässt aber nun mal Default-Werte bei Record-Parametern nicht zu. Dann bleibt halt nur der von Uli beschriebene Ansatz mit overload.
Für den anfangs beschriebenen Anwendungsfall sehe ich da auch keinen wesentlichen Nachteil.
Delphi-Quellcode:
Es lassen sich so Aufrufe mit und ohne z-Parameter schreiben, die auch korrekt ausgeführt werden. Wenn das nicht für deinen Anwendungsfall passt, dann zeig den doch mal. Es hilft ja nicht, wenn wir hier Lösungen für ein Problem suchen, was gar nicht existiert. Ich persönlich kann im Moment noch nicht sehen, wo es bei dir genau hakt.
function p_Rec(V, T, n: Extended; const z: TDRecord): Extended; overload;
begin . . . end; function p_Rec(V, T, n: Extended): Extended; overload; const z: TDRecord = (X: 1.25; Y: 2.5); begin Result := p_Rec(V, T, n, z); end; |
Alle Zeitangaben in WEZ +1. Es ist jetzt 21:45 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 by Thomas Breitkreuz