![]() |
Delphi-Version: 2005
Überladene Funktionen - Delphi erkennt keine Eindeutigkeit?
Hallo!
Ich arbeite mit Delphi 5 (nicht 2005). Dort habe ich folgende überladene Funktionen deklariert:
Delphi-Quellcode:
Beim Aufruf von
function BestellGrpSendExist(Typ: Integer = 0): Boolean; overload;
function BestellGrpSendExist(aTyp: array of Integer): Boolean; overload; function BestellGrpSendExist(ProdNames: array of string; Typ: Integer = 0): Boolean; overload; function BestellGrpSendExist(ProdNames: array of string; aTyp: array of Integer): Boolean; overload;
Delphi-Quellcode:
meldet Delphi:
BestellGrpSendExist(['bla','je'],[21,22])
Code:
Ich kann mir das nicht erklären. In meinen Augen ist der Aufruf eindeutig. Vielleicht weiß ja einer von Euch woran das liegt?
[Fehler] CCCHemopharm1003Ergebnis.pas(1145): Doppeldeutiger überladener Aufruf von 'BestellGrpSendExist'
|
AW: Überladene Funktionen - Delphi erkennt keine Eindeutigkeit?
Was passiert, wenn du mal die Defaultwerte (=0) in den Deklarationen wegläßt?
|
AW: Überladene Funktionen - Delphi erkennt keine Eindeutigkeit?
Hmmm, ist in D2007 immer noch so. Das kann ich mir auch nicht erklären. Wenn ich die BestellGrpSendExist(aTyp: array of Integer)-Überladung auskommentiere, geht's.
Vielleicht kannst du die Überladungen ohne ProdNames entfernen und in ihren Aufrufen [] als ersten Parameter übergeben? |
AW: Überladene Funktionen - Delphi erkennt keine Eindeutigkeit?
Also die Funktionen sind historisch gewachsen und rufen sich auch gegenseitig auf, ich werd also probieren müssen, was ich "umstrukturieren" kann.
Danke! |
AW: Überladene Funktionen - Delphi erkennt keine Eindeutigkeit?
Tja, wenn man mal genau hinsieht, wo der Cursor steht, nach/nei dieser Fehlermeldung, dann wird es klar.
Es wird direkt nach dem [ geprüft ob es "irgendwelche" Arrays gibt und da es mehrere Arrays gibt, kann sich der Kompiler nicht entscheiden, da er den Inhalt des Arrays wohl erst später auswertet und so noch nicht weiß was es für ein Array wird ... nun findet er aber mehrere Array-Deklarationen und muß aufgeben. Ein Umweg wäre ['bla','je'] nicht als direkte Konstante, sondern über eine externe Array-Konstante/Variable zu übergeben- |
AW: Überladene Funktionen - Delphi erkennt keine Eindeutigkeit?
Zitat:
Delphi-Quellcode:
und z.B.
procedure P(const AStrings: array of string); overload;
procedure P(const ANumbers: array of Byte); overload;
Delphi-Quellcode:
führen zum gleichen Fehler. Scheinbar wirft Delphi bei der Auflösung von Überladungen alle (offenen?) Array-Typen in einen Topf.
P(['bla', 'je']);
Edit: ![]() |
AW: Überladene Funktionen - Delphi erkennt keine Eindeutigkeit?
Das Problem hab ich auch ständig mit überladenen Stringparametern.
AnsiString, UnicodeString/WideString und UTF8String ... gibt man nun direkt einen String 'xyz' an, dann kann sich Delphi nicht entscheiden. Warum weiß ich nicht, denn es wäre doch sooo einfach: Ist kein zu nutzender Typ vorgegeben (z.B. über eine Zielvariable oder einen eindeutigen Parameter), dann wird String genommen und schon wäre klar, welcher Aufruf genommen werden müßte und/oder mam schaut, was an Möglichleiten zur Verfügung steht und versucht dann den angegebenen Typ irgendwo zuzuordnen und so auf ein eindeutiges Ergebnis zu kommen. :wall: Hier ist es halt so, daß der Compiler das [ findet, nun schaut er nach welchen Typ das Array haben kann/muß, anhand von den Parametern (hier findet er leider mehrere und kann sich nicht entscheigen, da er zu doof ist jetzt mal in die Werte zu schauen und zu erkennen, daß dort Strings oder Integer enthalten sind und demnach dann nur noch eine Deklaration passen würde) baut er nun das Array auf. Dann nimmt er sich erst den Inhalt vor und versucht die "Strings" in das Zielarray einzubauen. (wenn jetzt als einziges das Zielformat ein Integer(LongInt)-Array erkannt worden wäre und man übergibt Strings, dann hätte er beim String gemeckert, weil es kein Integer ist). Es wünschen sich ja schon lange welche einen mehrphasigen oder zumindestens (wenn nötig) vorausschauenden Compiler, welcher dann solche Probleme nicht hätte. |
AW: Überladene Funktionen - Delphi erkennt keine Eindeutigkeit?
Öhm...bin noch nicht ganz wach, aber bei dem Aufruf übergibst du doch ein SET, kein Array (bzw. der Compiler nimmt da ein Set an):
Delphi-Quellcode:
BestellGrpSendExist(['bla','je'],[21,22])
|
AW: Überladene Funktionen - Delphi erkennt keine Eindeutigkeit?
Zitat:
Zitat:
![]() |
AW: Überladene Funktionen - Delphi erkennt keine Eindeutigkeit?
Delphi-Quellcode:
kann nur ein "offenes Array" sein, denn es gibt keine SETs mit Strings.
['bla','je']
Delphi-Quellcode:
könnte ein SET sein oder ein "offenes Array".
[21,22]
Darum schaut sich der Kompiler vorher das Ziel an, entscheidet dann was es nun werden soll und versucht danach die Werte dort einzufügen. |
AW: Überladene Funktionen - Delphi erkennt keine Eindeutigkeit?
Ok, man lernt nie aus :D
So habe ich das noch nie benutzt, ich übergebe sowas normalerweise dann immer als Variable... Komischerweise funktionieren die offenen Var-Parameter nicht mehr, sobald man das array als einen Typ kapselt:
Delphi-Quellcode:
type
TSArray = array of string ; ... function ATest(aParam: TSArray): boolean ; ... ATest(['bla','möp']) ; => Fehler "ordinaltyp erforderlich" ; |
AW: Überladene Funktionen - Delphi erkennt keine Eindeutigkeit?
Offene Array-Parameter dürfen nicht als Typ vorliegen.
Delphi-Quellcode:
"normaler" Array-Parameter
function ATest(aParam: TSArray): boolean;
Delphi-Quellcode:
offener Array-Parameter
function ATest(aParam: array of String): boolean;
Und nur beim Letzen kann man [...] direkt übergeben. Beim Ersten muß eine Variable/Konstante mit genau diesem Typen übergeben werden. aParam: TSArray übergibt nur einen Pointer auf die Variable/Konstante. Beim offenen Arrayparameter wird etwas mehr intern gemacht (die Werte werden einzeln in ein temporäres Array kopiert, mit der Länge versehn und erst dann an die Funktion übergeben). |
AW: Überladene Funktionen - Delphi erkennt keine Eindeutigkeit?
Joa, find'sch zwar doof, ist aber halt so. Naja,ich brauch das eh so nie :D
|
AW: Überladene Funktionen - Delphi erkennt keine Eindeutigkeit?
Zitat:
![]() |
AW: Überladene Funktionen - Delphi erkennt keine Eindeutigkeit?
Hab's schon gerafft! (ist zwar selten, aber das jetzt schon :D)
|
AW: Überladene Funktionen - Delphi erkennt keine Eindeutigkeit?
Zitat:
![]() |
AW: Überladene Funktionen - Delphi erkennt keine Eindeutigkeit?
Selten, aber ja, jetzt, wo du's sagst....:oops:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 03:28 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