AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Delphi StringList oder dynamisches Array.
Thema durchsuchen
Ansicht
Themen-Optionen

StringList oder dynamisches Array.

Ein Thema von MiKaEr · begonnen am 8. Feb 2012 · letzter Beitrag vom 10. Feb 2012
Antwort Antwort
Seite 2 von 2     12   
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#11

AW: StringList oder dynamisches Array.

  Alt 9. Feb 2012, 14:22
Da wäre jetzt dein Code interessant wie du befüllst und wie du die Zeit misst.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Iwo Asnet

Registriert seit: 11. Jun 2011
313 Beiträge
 
#12

AW: StringList oder dynamisches Array.

  Alt 9. Feb 2012, 17:07
Delphi-Quellcode:
program TestStringLists;

{$APPTYPE CONSOLE}

uses
  Windows, Classes, SysUtils;
Const
  R = 1000;

Var
  A : Array [0..10000] Of String;
  S : TStringList;
  
  Procedure ArrayProc;
  Var
    T : Cardinal;
    i : Integer;
    Procedure AppendProc;
    Var i : Integer;
    Begin
      for I := 0 to High(a) do A[i] := '123123123123';
    End;

    Procedure FetchProc;
    Var i : Integer; s: String;
    Begin
      for I := 0 to High(a) do s := A[i];
      if S='123then A[0] := '';
    End;

    Procedure InsertProc;
    Var i : Integer;
    Begin
      for I := 0 to High(A) do
        Move(A[0], A[1], High(A)*SizeOf(A[0]));
    End;

    Procedure DeleteProc;
    Var i : Integer;
    Begin
      for I := 0 to High(A) do
        Move(A[1], A[0], High(A)*SizeOf(A[0]));
    End;
  Begin
    T := GetTickCount;
    For i:=1 to R do AppendProc;
    Writeln('Array - Add : ',GetTickcount-t);
    T := GetTickCount;
    For i:=1 to R do FetchProc;
    Writeln('Array - Fetch : ',GetTickcount-t);
    T := GetTickCount;
    For i:=1 to R div 100 do Begin InsertProc; DeleteProc; End;
    Writeln('Array - Ins/Del : ',GetTickcount-t);
  End;
  Procedure StringListProc;
  Var
    T : Cardinal;
    i : Integer;
    Procedure AppendProc;
    Var i : Integer;
    Begin
      for I := 0 to High(a) do S.Add('123123123123');
    End;

    Procedure FetchProc;
    Var i : Integer; x: String;
    Begin
      for I := 0 to High(a) do x := S[i];
      if x='123then S[0] := '';
    End;

    Procedure InsertProc;
    Var i : Integer;
    Begin
      for i := 0 to High(A) do begin
        S.Insert(0,'1^23123123');
        s.Delete(0);
      end;
    End;

    Procedure DeleteProc;
    Var i : Integer;
    Begin
      for i := 0 to High(A) do
        S.Delete(0);
    End;
  Begin
    s:= TStringlist.Create;
    T := GetTickCount;
    For i:=1 to R do AppendProc;
    Writeln('StrLst - Add : ',GetTickcount-t);

    T := GetTickCount;
    For i:=1 to R do FetchProc;
    Writeln('StrLst - Fetch : ',GetTickcount-t);
    s.clear;
    AppendProc; // damit die Stringlist auch 10000 elemente zum Testen hat
    T := GetTickCount;
    For i:=1 to R div 100 do InsertProc;
    Writeln('StrLst - In/Del : ',GetTickcount-t);
   s.free;
 End;
begin
  ArrayProc;
  StringListProc;
  ReadLn;
end.

Geändert von Iwo Asnet ( 9. Feb 2012 um 17:13 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#13

AW: StringList oder dynamisches Array.

  Alt 9. Feb 2012, 17:14
Also GetTickCount ist dazu schon mal ungeeignet. Wenn dann sollte man mit GetThreadTimes, um genauere Werte zu erhalten.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke
Online

Registriert seit: 10. Jun 2003
Ort: Berlin
9.592 Beiträge
 
Delphi 11 Alexandria
 
#14

AW: StringList oder dynamisches Array.

  Alt 9. Feb 2012, 17:20
Und davon ganz abgesehen ist das hier kein dynamisches Array. Ein festes Array zu nehmen um festzustellen wie sich ein dynamisches Array zu einer TStringList verhält, ist schon reichlich seltsam...
Denn die Operationen, die dabei eigentlich interessieren, kann man so ja gar nicht testen...
Sebastian Jänicke
Alle eigenen Projekte sind eingestellt, ebenso meine Homepage, Downloadlinks usw. im Forum bleiben aktiv!
  Mit Zitat antworten Zitat
Iwo Asnet

Registriert seit: 11. Jun 2011
313 Beiträge
 
#15

AW: StringList oder dynamisches Array.

  Alt 9. Feb 2012, 17:43
@Luckie: Ob nun GetTickCount oder etwas anderes ist bei 500-700ms egal, oder etwa nicht?
@Jaenicke: Ob nun Array oder dynamisches Array ist eigentlich auch egal, auch wenn ich deine Ansicht im Prinzip teile. Ein dynamisches Array wird bei Zugriff über eine Dereferenzierung vermutlich etwas langsamer werden.

Aber wer mag, kann ja ein dynamisches Array einbauen und einen ultragenauen Zeitmesser obendrauf. Ob das Ergebnis -speziell durch eine Atomuhr- nun anders ausfällt, wage ich zwar zu bezweifeln, aber ich lasse mich gern eines besseren belehren. Hier wird der CPU-Cache eine viel größere Rolle spielen.

Interessant für mich ist der Overhead bei den Insert/Delete-Operationen, die man vielleicht optimieren kann. Wenn man will.

Geändert von Iwo Asnet ( 9. Feb 2012 um 17:46 Uhr)
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.858 Beiträge
 
Delphi 11 Alexandria
 
#16

AW: StringList oder dynamisches Array.

  Alt 10. Feb 2012, 07:51
Zitat:
@Jaenicke: Ob nun Array oder dynamisches Array ist eigentlich auch egal, auch wenn ich deine Ansicht im Prinzip teile. Ein dynamisches Array wird bei Zugriff über eine Dereferenzierung vermutlich etwas langsamer werden.
Aber nur wenn man den dynamischen Array anfänglich auzch auf einen sehr großen Wert dimensioniert. Im Normalfall macht man das ja nicht ( sonst bräucht man keinen dynamischen Array, dessen Vorteil es ja ist, dass die Größe änderbar ist.)
Markus Kinzler
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


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 20:06 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