AGB  ·  Datenschutz  ·  Impressum  







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

Desaströse Performance von TRichedit

Ein Thema von Maekkelrajter · begonnen am 11. Sep 2024 · letzter Beitrag vom 12. Sep 2024
Antwort Antwort
Benutzerbild von Uwe Raabe
Uwe Raabe
Online

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.690 Beiträge
 
Delphi 12 Athens
 
#1

AW: Desaströse Performance von TRichedit

  Alt 12. Sep 2024, 11:20
Ich habe das mal hier mit Delphi 12.1 und einem VCL-Form, einem RichEdit, einem Button und einem Label drauf ausprobiert:
Delphi-Quellcode:
procedure TForm866.Button1Click(Sender: TObject);
begin
// var FN:= 'c:\Users\Uwe\Downloads\TestDateien\Windows_ITunesContent.txt';
  var FN:= 'c:\Users\Uwe\Downloads\TestDateien\MacOS_ItunesContent.txt';
  var sw := TStopwatch.StartNew;
  richedit1.lines.LoadFromFile(fn);
  label1.Caption := sw.ElapsedMilliseconds.ToString;
end;
Ohne Debugger dauert das bei der Windows-Datei gut 1 Sekunde und bei der MacOS-Datei knapp 4 Sekunden.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Maekkelrajter

Registriert seit: 8. Mär 2017
Ort: Köln
158 Beiträge
 
Delphi 12 Athens
 
#2

AW: Desaströse Performance von TRichedit

  Alt 12. Sep 2024, 12:16
Ich habe das mal hier mit Delphi 12.1 und einem VCL-Form, einem RichEdit, einem Button und einem Label drauf ausprobiert:
Ohne Debugger dauert das bei der Windows-Datei gut 1 Sekunde und bei der MacOS-Datei knapp 4 Sekunden.
Das Verhältnis der Zeiten entspricht ja fast genau den von mir ermittelten Zeiten. Die enorme absolute Dauer ist wohl u.a. meinem in die Jahre gekommenen Rechner geschuldet. Aber auch mit meinem IT-Methusalem ging es ja mit der früheren Version (Delphi bzw.Trichedit) bedeutend schneller, ebenso wie aktuell mit TMemo.
Und 4 Sekunden sind heutzutage für eine Datei von gerade mal 6 MB auch ganz schön happig;
Festzustehen scheint, dass die aktuelle Implementierung von TRichedit gewissermaßen suboptimal ist.
Ich bin schon dabei, bei meinem Hauptprojekt überall dort, wo Performance eine Rolle spielt und Richedit-Features nicht unbedingt benötigt werden, das TRichedit durch ein TMemo zu ersetzen. So kommt wenigstens keine Langeweile auf

Gruß LP
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe
Online

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.690 Beiträge
 
Delphi 12 Athens
 
#3

AW: Desaströse Performance von TRichedit

  Alt 12. Sep 2024, 13:24
Festzustehen scheint, dass die aktuelle Implementierung von TRichedit gewissermaßen suboptimal ist.
Ich habe das mal auf einen simplen WinApi-Aufruf reduziert und komme auf ziemlich dieselben Werte. Es hängt also wohl nicht an der Delphi-Implementierung.
Delphi-Quellcode:
  var FN:= 'c:\Users\Uwe\Downloads\TestDateien\Windows_ITunesContent.txt';
// var FN:= 'c:\Users\Uwe\Downloads\TestDateien\MacOS_ItunesContent.txt';
  var S := TFile.ReadAllText(FN, TEncoding.Unicode);
  var sw := TStopwatch.StartNew;
  RichEdit1.SetSelText(S);
  label1.Caption := sw.ElapsedMilliseconds.ToString;
Warum die doppelt so große Windows-Datei aber nur 1/4 der Zeit braucht erschließt sich mir noch nicht so ganz.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Desaströse Performance von TRichedit

  Alt 12. Sep 2024, 13:35
TextDateien ohne Formatierung ... warum überhaupt in ein RichEdit anstatt in ein Memo?
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe
Online

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.690 Beiträge
 
Delphi 12 Athens
 
#5

AW: Desaströse Performance von TRichedit

  Alt 12. Sep 2024, 14:01
TextDateien ohne Formatierung ... warum überhaupt in ein RichEdit anstatt in ein Memo?
Na ja, weil:
Aber einige optische Gimmicks wie mehrfarbiger Text sind eben mit einem TMemo nicht zu realisieren.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Desaströse Performance von TRichedit

  Alt 12. Sep 2024, 15:08
TextDateien ohne Formatierung ... warum überhaupt in ein RichEdit anstatt in ein Memo?
Na ja, weil:
Aber einige optische Gimmicks wie mehrfarbiger Text sind eben mit einem TMemo nicht zu realisieren.
ups.

SynEdit/SynMemo oder dergleichen?
oder das neue Direct2D-RichEdit ... müsste man doch bestimmt gut im FireMokey einbinden können.
(der Start von dem Geraffel dauert zwar ewig, aber danach scheint es schnell zu sein)
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
Kas Ob.

Registriert seit: 3. Sep 2023
436 Beiträge
 
#7

AW: Desaströse Performance von TRichedit

  Alt 12. Sep 2024, 15:16
What about this
Delphi-Quellcode:
var
  Stream: TMemoryStream;
begin
  Stream := TMemoryStream.Create;
  try
    Stream.LoadFromFile(FILE_NAME);
    SendMessage(RichEdit1.Handle, WM_SETTEXT, LPARAM(0), WPARAM(Stream.Memory)); // better to add to the stream another byte with 0 or double bytes with 0, but for testing now
    //Stream.Position := 0;
    //RichEdit1.Lines.LoadFromStream(Stream);
  finally
    Stream.Free;
  end;
end;
Kas
  Mit Zitat antworten Zitat
Kas Ob.

Registriert seit: 3. Sep 2023
436 Beiträge
 
#8

AW: Desaströse Performance von TRichedit

  Alt 12. Sep 2024, 14:52
Well, if someone reading my writing somewhere, then try this

Delphi-Quellcode:
var
  Stream:TMemoryStream;
begin
  Stream := TMemoryStream.Create;
  try
    Stream.LoadFromFile(FILE_NAMEXX);
    Stream.Position := 0;
    RichEdit1.Lines.LoadFromStream(Stream);
  finally
    Stream.Free;
  end;
end;
The problem is known, which is the ****** stream handling in RTL, and also in VCL, it does many small read at 2kb (like it was bronze age) instead of 64kb, anyway TMemoryStream will load this stuff in full in memory and feed it, this should be faster, (Well in theory and in my slow brain)
Kas
  Mit Zitat antworten Zitat
Benutzerbild von Uwe Raabe
Uwe Raabe
Online

Registriert seit: 20. Jan 2006
Ort: Lübbecke
11.690 Beiträge
 
Delphi 12 Athens
 
#9

AW: Desaströse Performance von TRichedit

  Alt 12. Sep 2024, 15:05
Well, if someone reading my writing somewhere, then try this
Sorry, no difference. The problem is most likely inside Windows.
Uwe Raabe
Certified Delphi Master Developer
Embarcadero MVP
Blog: The Art of Delphi Programming
  Mit Zitat antworten Zitat
Maekkelrajter

Registriert seit: 8. Mär 2017
Ort: Köln
158 Beiträge
 
Delphi 12 Athens
 
#10

AW: Desaströse Performance von TRichedit

  Alt 12. Sep 2024, 15:33
Warum die doppelt so große Windows-Datei aber nur 1/4 der Zeit braucht erschließt sich mir noch nicht so ganz.
Ich vermute, es liegt an der Codierung unter MacOS. Zum Beispiel werden Umlaute im normalen Text anders codiert als solche im Dateipfad
Beispiel Track 4344
Titel: Morgendämmerung und Siegfried's Rheinfahrt aus "Götterdämmerung". Der Code für 'ä' = $E4 00
Im Dateipfad "Macintosh HD/Users/.../05 Morgendämmerung und Siegfried's Rheinfahrt aus _Götterdämmerung_.m4a" ist der Code für 'ä'= $61 00 08 03 (a + ¨).
Wenn ich mit Trichedit.FindText nach 'dämmerung' suche, wird nur das Vorkommen im Text, nicht aber das im Dateipfad gefunden
Ich habe allerdings keine Ahnung, warum sich das so gravierend auf die Ausführungszeit auswirkt.

Gruß LP
  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 15:31 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz