Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Library: Object-Pascal / Delphi-Language (https://www.delphipraxis.net/35-library-object-pascal-delphi-language/)
-   -   Delphi Mehrere Strings effizient verketten (https://www.delphipraxis.net/113412-mehrere-strings-effizient-verketten.html)

shmia 7. Mai 2008 15:24


Mehrere Strings effizient verketten
 
Man kann ja Ansi-Strings einfach mit dem + Operator zusammenhängen.
Wenn die Strings aber länger sind, kann dies allerdings ziemlich ineffizient werden,
da für jedes Zwischenergebnis eine Speicherreservierung und ein Verschieben von Daten eforderlich wird.

Dies kann auch zu einem ständig zunehmenden Speicherverbrauch führen, da jedes Zwischenergebnis länger als
sein Vorgänger ist. Also werden dann immer neue Blocke von Windows angefordert.

Folgende Funktion vermeidet die Zwischenergebnisse (es sollten aber mindestens 3 Strings übergeben werden, sonst lohnt sich das nicht):
Delphi-Quellcode:
function StrArrayConcat(const a : array of string):string;
var
  i, j,total_len : Integer;
  s : string;
begin
  total_len := 0;
  for i := Low(a) to High(a) do
    Inc(total_len, Length(a[i]));
  SetLength(Result, total_len);

  j := 1;
  for i := Low(a) to High(a) do
  begin
    s := a[i];
    if s <> '' then
    begin
      Move(s[1], Result[j], Length(s));
      Inc(j, Length(s));
    end;
  end;
end;
Beispiel für die Verwendung:
Delphi-Quellcode:
var
  a,b,c,d,s: string;
begin
  a := ...
  b := ...
  c := ...
  d := ...

// s := a + b + '***********' + c + d
  s := StrArrayConcat([a,b,'***********',c,d]);

Dax 4. Jul 2008 03:02

Re: Mehrere Strings effizient verketten
 
himitsu schlägt folgende Optimierung vor:
Delphi-Quellcode:
function StrArrayConcat(const a : array of string):string;
var
  i, j, k : Integer;
begin
  j := 0;
  for i := Low(a) to High(a) do
    Inc(j, Length(a[i]));
  SetLength(Result, j);

  j := 0;
  for i := Low(a) to High(a) do
    if a[i] <> '' then
    begin
      k := Length(a[i]);
      MoveMemory(PChar(Pointer(Result)) + j, Pointer(a[i]), k);
      Inc(j, k);
    end;
end;
Sein Kommentar:
Zitat:

Zitat von himitsu
var s: string; entfernt ... unnötige bearbeiung des Referenzzählers
UniqueString entfernt (kein PChar(s), s[x]+Varparameter oder @s[x])
und ein [i]Length(a) entfernt



Alle Zeitangaben in WEZ +1. Es ist jetzt 11:46 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