AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Array zusammenhängen

Ein Thema von TomDooley · begonnen am 24. Nov 2006 · letzter Beitrag vom 24. Nov 2006
Antwort Antwort
TomDooley

Registriert seit: 26. Jan 2004
124 Beiträge
 
#1

Array zusammenhängen

  Alt 24. Nov 2006, 15:19
Hallo

Ich verwende folgende Funktion um ein bestendes Array zu erweitern:

Delphi-Quellcode:
procedure TTest.FillArray(var aArray: tBestehendesArray; aValues: array of integer);
var
  TmpLen : integer;
  lp : byte;
begin
  TmpLen := Length(aArray);
  SetLength(aArray,TmpLen+Length(aValues));
  for lp:=0 to high(aValues) do
    aArray[TmpLen+lp] := aValues[lp];
end;
Gibt es dafür noch eine elegantere Möglichkeit?
  Mit Zitat antworten Zitat
Der_Unwissende

Registriert seit: 13. Dez 2003
Ort: Berlin
1.756 Beiträge
 
#2

Re: Array zusammenhängen

  Alt 24. Nov 2006, 15:41
Hi,
es gibt auf jeden Fall eine deutlich schnellere:

Delphi-Quellcode:
procedure TTest.FillArray(var aArray: tBestehendesArray; aValues: array of integer);
var
  TmpLen : integer;
  lp : byte;
begin
  TmpLen := Length(aArray);
  SetLength(aArray,TmpLen+Length(aValues));
  copyMemory(@aArray[TmpLen], @aValues[0], sizeOf(aValues[0]) * length(aValues));
end;
CopyMemory ist dabei aus der Unit Windows.

Gruß Der Unwissende
  Mit Zitat antworten Zitat
Benutzerbild von Dani
Dani

Registriert seit: 19. Jan 2003
732 Beiträge
 
Turbo Delphi für Win32
 
#3

Re: Array zusammenhängen

  Alt 24. Nov 2006, 15:42
Hi, ich denke nicht, dass eine effizientere Implementierung sehr sinnvoll wäre, da du dir für das Aneinanderhängen von Daten sowieso eine schlecht geeignete Datenstruktur ausgesucht hast. Wenn du weißt, dass in diesem Array niemals mehr als ~100 Einträge liegen, brauchst du dir auch nicht weiter Gedanken darüber zu machen. Sind es (viel) mehr Einträge, nimm eine Datenstruktur, die zu deiner Aufgabe passt (Suchen? Sortieren? Aneinanderhängen? etc)

Gruß, Dani
Dani H.
At Least I Can Say I Tried
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#4

Re: Array zusammenhängen

  Alt 24. Nov 2006, 15:42
Du könntest die Daten effektiver (=schneller) mit der Move Prozedure bewegen.
Aber Achtung: wäre das Array von Typ: array of string; wäre dies verboten.
Deine Prozedure könnte so aussehen (ungetestet!!!):
Delphi-Quellcode:
procedure AppendArray(var aArray: TIntegerArray; aValues: TIntegerArray);
var
  TmpLen : integer;
  lp : byte;
begin
  TmpLen := Length(aArray);
  SetLength(aArray,TmpLen+Length(aValues));
  Move(aValues[0], aArray[TmpLen], Length(aValues)*sizeof(Integer));
end;
Bei Verwendung von Move muss man höchste Vorsicht walten lassen, damit kein Speicher "zerschossen" wird.
PS: ich habe den Namen der Procedure geändert; ist so deutlich sprechender
Andreas
  Mit Zitat antworten Zitat
Ferber

Registriert seit: 9. Mär 2005
Ort: Wien Umgebung
155 Beiträge
 
Delphi 2006 Architect
 
#5

Re: Array zusammenhängen

  Alt 24. Nov 2006, 15:45
Hi !

Kleine Änderung spart Berechnung innerhalb der Schleife !

Delphi-Quellcode:
procedure TTest.FillArray(var aArray: tBestehendesArray; aValues: array of integer);
var
  TmpLen : integer;
  lp : byte;
begin
  TmpLen := Length(aArray);
  SetLength(aArray,TmpLen+Length(aValues));
  for lp:=TmpLen to TmpLen+high(aValues) do
    aArray[lp] := aValues[lp];
end;
Otto
  Mit Zitat antworten Zitat
Benutzerbild von SirThornberry
SirThornberry
(Moderator)

Registriert seit: 23. Sep 2003
Ort: Bockwen
12.235 Beiträge
 
Delphi 2006 Professional
 
#6

Re: Array zusammenhängen

  Alt 24. Nov 2006, 15:55
Zitat von shmia:
Du könntest die Daten effektiver (=schneller) mit der Move Prozedure bewegen.
Aber Achtung: wäre das Array von Typ: array of string; wäre dies verboten.
Deine Prozedure könnte so aussehen (ungetestet!!!):
Delphi-Quellcode:
procedure AppendArray(var aArray: TIntegerArray; aValues: TIntegerArray);
var
  TmpLen : integer;
  lp : byte;
begin
  TmpLen := Length(aArray);
  SetLength(aArray,TmpLen+Length(aValues));
  Move(aValues[0], aArray[TmpLen], Length(aValues)*sizeof(Integer));
end;
Bei Verwendung von Move muss man höchste Vorsicht walten lassen, damit kein Speicher "zerschossen" wird.
PS: ich habe den Namen der Procedure geändert; ist so deutlich sprechender
CopyMemory ruft doch auch nur Move auf. Damit hat man nur das zusätzliche Stack schaufeln wenn man anstelle von Move Copy Memory verwendet.
Jens
Mit Source ist es wie mit Kunst - Hauptsache der Künstler versteht's
  Mit Zitat antworten Zitat
TomDooley

Registriert seit: 26. Jan 2004
124 Beiträge
 
#7

Re: Array zusammenhängen

  Alt 24. Nov 2006, 15:58
Danke an alle! Ich werde in dem Fall Move verwenden.
  Mit Zitat antworten Zitat
Der_Unwissende

Registriert seit: 13. Dez 2003
Ort: Berlin
1.756 Beiträge
 
#8

Re: Array zusammenhängen

  Alt 24. Nov 2006, 15:59
Zitat von Ferber:
Kleine Änderung spart Berechnung innerhalb der Schleife !
Die Schleife an sich ist aber schon das Problem. Einerseits müssen hier wirklich mehrere Aufrufe stattfinden und andererseits wird hier jedes Datum einzeln kopiert. Das kopieren eines Datums kostet aber (unabhängig von dessen Größe) fast immer die gleiche Zeit. Kopiert man also ein Array, so werden die Kosten für das Kopieren der Elemente auf alle Elemente im Array umgelegt, der Overhead ist << als der für das Kopieren in einer Schleife.

Was die Move Prozedur angeht, so greift CopyMemory auch nur auf Move zurück, also ist Move hier noch etwas flinker.

[ADD]
Sorry, kein roter Kasten, komisch
[/ADD]
  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 09:59 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