AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Code-Bibliothek Library: Object-Pascal / Delphi-Language Delphi Mehrere Strings effizient verketten
Thema durchsuchen
Ansicht
Themen-Optionen

Mehrere Strings effizient verketten

Ein Thema von shmia · begonnen am 7. Mai 2008 · letzter Beitrag vom 4. Jul 2008
Antwort Antwort
shmia

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

Mehrere Strings effizient verketten

  Alt 7. Mai 2008, 16:24
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]);
Andreas
  Mit Zitat antworten Zitat
Dax
(Gast)

n/a Beiträge
 
#2

Re: Mehrere Strings effizient verketten

  Alt 4. Jul 2008, 04:02
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 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
  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 12:38 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