AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi offenes Array beliebigen Typs als Parameter, so dass es von SetLength akzeptiert wird
Thema durchsuchen
Ansicht
Themen-Optionen

offenes Array beliebigen Typs als Parameter, so dass es von SetLength akzeptiert wird

Ein Thema von RSE · begonnen am 10. Aug 2012 · letzter Beitrag vom 10. Aug 2012
Antwort Antwort
RSE

Registriert seit: 26. Mär 2010
254 Beiträge
 
Delphi XE Enterprise
 
#1

offenes Array beliebigen Typs als Parameter, so dass es von SetLength akzeptiert wird

  Alt 10. Aug 2012, 13:40
Delphi-Version: XE
Hallo,

wie kann ich ein offenes Array beliebigen Typs als Parameter übergeben, so dass es von SetLength akzeptiert wird?

Ich habe bereits folgendes probiert:
Delphi-Quellcode:
class procedure TArrays.Remove<T>(var Arr: array of T; Index: Integer);
begin
  if Index < High(Arr) then
    Move(Arr[Index + 1], Arr[Index], SizeOf(Arr[Index]) * (High(Arr) - Index));
  SetLength(Arr, Length(Arr) - 1); // Compiler-Fehlermeldung: "E2008 Inkompatible Typen"
end;
Mit Generics scheint es da also offenbar Probleme zu geben. Wieso es da Probleme gibt, ist mir allerdings unklar.
"Seit er seinen neuen Computer hat, löst er alle seine Probleme, die er vorher nicht hatte."
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.171 Beiträge
 
Delphi 10.4 Sydney
 
#2

AW: offenes Array beliebigen Typs als Parameter, so dass es von SetLength akzeptiert

  Alt 10. Aug 2012, 13:44
Geht mit festen Typ?
Ich glaube mich zu erinnern das es da auch nicht geht.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Benutzerbild von s.h.a.r.k
s.h.a.r.k

Registriert seit: 26. Mai 2004
3.159 Beiträge
 
#3

AW: offenes Array beliebigen Typs als Parameter, so dass es von SetLength akzeptiert

  Alt 10. Aug 2012, 13:45
Mit Generics scheint es da also offenbar Probleme zu geben. Wieso es da Probleme gibt, ist mir allerdings unklar.
Was genau meinst du damit?

Schon mal folgendes probiert?
Delphi-Quellcode:
class procedure TArrays.Remove<T>(var Arr: TArray<T>; Index: Integer);
begin
  if Index < High(Arr) then
    Move(Arr[Index + 1], Arr[Index], SizeOf(Arr[Index]) * (High(Arr) - Index));
  SetLength(Arr, Length(Arr) - 1);end;
Du versuchst aber nicht zufälligerweise das gleiche wie zu machen? Habe hier auch mal einen Record gepostet, über den ich ziemlich viele Array-Methoden abgebildet habe. Mein Record implementiert dabei sehr viele PHP-Methode.
»Remember, the future maintainer is the person you should be writing code for, not the compiler.« (Nick Hodges)
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu
Online

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

AW: offenes Array beliebigen Typs als Parameter, so dass es von SetLength akzeptiert

  Alt 10. Aug 2012, 13:49
Offene Array-Parameter können niemals als VAR deklariert werden.

Denn zum Verändern des übergebenen Arrays muß die Übergabe typgenau sein, das hier nicht gegeben ist.


Du kannst aber xxx<T>(var arr: TArray<T>) verwenden
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
RSE

Registriert seit: 26. Mär 2010
254 Beiträge
 
Delphi XE Enterprise
 
#5

AW: offenes Array beliebigen Typs als Parameter, so dass es von SetLength akzeptiert

  Alt 10. Aug 2012, 13:53
var Arr: TArray<T> funktioniert, vielen Dank! Wieder etwas gelernt...

Edit: Ich kann kein a: array of Integer übergeben, sondern nur ein a: TArray<Integer> , aber das ist vertretbar, denn TArray ist definiert als: TArray<T> = array of T .

Edit2: Klappt super, außer mit TArray<Pointer> oder TArray<TMyRecordType> ... Also etwas genauer:
Delphi-Quellcode:
type
  TProcArray = TArray<Pointer>;
...
procedure UnRegisterEvt(var Evts: TProcArray; Handler: Pointer);
var
  i: Integer;
begin
  i := HandlerIndex(Evts, Handler);
  if i > -1 then
    TArrays.Remove(Evts, i); // Compilerfehler: E2033 Die Typen der tatsächlichen und formalen Var-Parameter müssen übereinstimmen
end;
Delphi ist hier also nicht clever genug, um mitzukriegen, dass als generischer Typ Pointer eingesetzt werden muss. Ich will an dieser Stelle auch nicht Pointer hardcoden, denn dann könnte ich mir die Typdefinition von TProcArray sparen. Bei Klassen gibt es die Methode ClassType von TObject, die den Klassentyp einer Instanz zurückgibt. Kann man irgendwie auch für "normale Variablen" den Typ bestimmen? So etwas wie TArrays.Remove<TypeOf(Evts[0])>(Evts, i); würde mir sehr gefallen.

Edit3: Sorry, dass die Edits hier so ausufern...
TArrays.Remove<TypeOf(Evts[0])>(Evts, i); ist natürlich nicht möglich, da Generics ja zur Compiletime "übersetzt" werden. Ich habe also folgende Änderung gemacht:
Delphi-Quellcode:
type
  TProcFunc = Pointer; // TProc gibt es schon in SysUtils
  TProcFuncArray = TArray<TProcFunc>;
...
    TArrays.Remove<TProcFunc>(Evts, i); // kein Compilerfehler mehr, die Annahme, dass TProcFuncArray ein Array aus TProcFuncs ist, ist denke ich annehmbar.
"Seit er seinen neuen Computer hat, löst er alle seine Probleme, die er vorher nicht hatte."

Geändert von RSE (10. Aug 2012 um 14:44 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 13:23 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