AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Delphi Zugriff auf Strings / Listen langsam?
Thema durchsuchen
Ansicht
Themen-Optionen

Zugriff auf Strings / Listen langsam?

Ein Thema von OlliWW · begonnen am 1. Okt 2014 · letzter Beitrag vom 16. Okt 2014
Antwort Antwort
Seite 1 von 3  1 23      
OlliWW

Registriert seit: 31. Aug 2011
159 Beiträge
 
#1

Zugriff auf Strings / Listen langsam?

  Alt 1. Okt 2014, 17:25
Hallo,

Ich habe einen Fehler in meiner Software, aber ich komme nicht auf die richtige Lösung.

Die Software läuft auf verschiedenen Windows Systemen performant und ohne Probleme. Bei einigen Windows Server 2012 Systemen habe ich jedoch die Problematik, dass die gesamte Software langsamer reagiert. An der Hardware des Rechners kann es nicht liegen.

Ich konnte zwei "Ursachen" bereits eingrenzen:
1.) Man ist per RDP auf den Rechner verbunden = langsam. Ist man hingegen direkt auf der "Console", also sitzt vor dem PC verhält sich das System normal schnell
2.) Eine Methode die besonders auffällig ist ist "Combobox.Items.AddStrings(TStringList)"

Dieses Addstrings dauert bis zu 6 Sekunden, um eine Liste von ca. 50 Einträgen hinzuzufügen. Diese Methode ist natürlich abgesichert mit "BeginUpdate" und "EndUpdate".

Ich habe zwei Vermutungen:
Entweder werden Strings falsch behandelt / interpretiert oder es hat irgendwas mit den Visuellen Komponenten ansich zu tun. Hoffentlich habt ihr ein paar Tipps.
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer
Online

Registriert seit: 13. Aug 2002
17.202 Beiträge
 
Delphi 10.4 Sydney
 
#2

AW: Zugriff auf Strings / Listen langsam?

  Alt 1. Okt 2014, 17:27
VCL oder FMX?
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
OlliWW

Registriert seit: 31. Aug 2011
159 Beiträge
 
#3

AW: Zugriff auf Strings / Listen langsam?

  Alt 1. Okt 2014, 17:28
Vcl
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Zugriff auf Strings / Listen langsam?

  Alt 1. Okt 2014, 17:30
Der RDP hookt sich in die Grafikausgaben rein
und für die Dauer der Übertragung wird das Zeichnen somit ausgebremst.

Bei vielen Änderungen/großen Datenmängen bremst das natürlich enorm aus,
wobei hier nicht nur die Performance des Servers zählt, sondern auch die des Klienten und er Netzwerkverbindung.


Wenn ihr (viele) Daten in den Listen ändert, schaltet ihr dann auch die Ausgaben solange ab? (z.B. BeginUpdate)
Hängt vielleicht noch was am OnChange dran, was eventuell auch Ausgaben generiert?



Ich würde mir ja wünschen, wenn man im RDP sich die eintreffenden Daten anzeigen lassen könnte.
z.B. kürzlich geänderte Bereiche farblich markieren und natürlich Traffikstatistiken (Anzahl der Datenpackete und Datenmenge/Datenrate)
$2B or not $2B

Geändert von himitsu ( 1. Okt 2014 um 17:33 Uhr)
  Mit Zitat antworten Zitat
OlliWW

Registriert seit: 31. Aug 2011
159 Beiträge
 
#5

AW: Zugriff auf Strings / Listen langsam?

  Alt 1. Okt 2014, 17:35
Hallo,

Ja wie oben bereits geschrieben machen wir ein Begin / EndeUpdate. Wie gesagt es ist ingesamt träge, allerdings besonders signifikant ist diese Stelle:
Delphi-Quellcode:
  with FontBox do
  begin
    Items.BeginUpdate;
    if meineForm <> nil then
    begin
      Items.AddStrings(meineForm.lstTTFonts);
    end;
    Items.EndUpdate;
  end; //with
Aufgrund der RDP Sache hatte ich auch zunächst auf das Zeichnen der Komponenten getippt, allerdings wird hier an dieser Stelle ja nicht wirklich gezeichnet und laut Profiler dauert das mit 50 Einträgen 6 Sekunden. Ich habe irgendwie im Bauchgefühl dass es irgendwas mit Strings (Unicode, Ansi...) zu tun haben könnte, bin mir aber nicht sicher.
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#6

AW: Zugriff auf Strings / Listen langsam?

  Alt 1. Okt 2014, 17:41
AFAIK wird bei RDP der Inhalt der Controls (sofern Standard) übertragen und eben nicht die reine Anzeige.

Bei einem Edit wird eben der Typ (ein Edit) und die Eigenschaften übertragen, dadurch kann dieses Control dann am Ziel selber gezeichnet werden, was dann schneller ist, als dort ein Bild zu übertragen.

Nun, bei einem Listen-Control kann das natürlich dann wieder bremsen
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
OlliWW

Registriert seit: 31. Aug 2011
159 Beiträge
 
#7

AW: Zugriff auf Strings / Listen langsam?

  Alt 1. Okt 2014, 17:46
AFAIK wird bei RDP der Inhalt der Controls (sofern Standard) übertragen und eben nicht die reine Anzeige.
Das würde erklären, warum eine Teamviewer Verbindung auf diesem Rechner "schnell" ist. Die Frage ist:
Wie stelle ich das um?

Vielleicht noch eine interessante Sache:
Ich habe das Problem versucht lokal nach zustellen, indem ich auch einen Windows Server 2012 installiert habe. => Kein Erfolg, selbe Daten, selbe Version, es ist immer schnell. Installiert man bei dem Kunden Windows Server 2008R2 oder ähnliches ist es ebenfalls schnell. Nur 2012 mag nicht.
  Mit Zitat antworten Zitat
OlliWW

Registriert seit: 31. Aug 2011
159 Beiträge
 
#8

AW: Zugriff auf Strings / Listen langsam?

  Alt 1. Okt 2014, 21:44
Ich habe eine andere "langsame" Stelle mit dem Profiler gemessen und am Ende war es auch hier:
Der Refresh einer Combobox.

Es scheint also ein Problem mit dem Zeichnen von Comoboboxen zu existieren. Irgendwelche Ideen? Ich habe eben ein "Tsaware" Flag gefunden, das man setzen kann, das hilft aber auch nicht.
  Mit Zitat antworten Zitat
mjustin

Registriert seit: 14. Apr 2008
3.006 Beiträge
 
Delphi 2009 Professional
 
#9

AW: Zugriff auf Strings / Listen langsam?

  Alt 2. Okt 2014, 08:01
AFAIK wird bei RDP der Inhalt der Controls (sofern Standard) übertragen und eben nicht die reine Anzeige.
Das würde erklären, warum eine Teamviewer Verbindung auf diesem Rechner "schnell" ist. Die Frage ist:
Wie stelle ich das um?

Vielleicht noch eine interessante Sache:
Ich habe das Problem versucht lokal nach zustellen, indem ich auch einen Windows Server 2012 installiert habe. => Kein Erfolg, selbe Daten, selbe Version, es ist immer schnell. Installiert man bei dem Kunden Windows Server 2008R2 oder ähnliches ist es ebenfalls schnell. Nur 2012 mag nicht.
Was hat sich zwischen Windows Server 2008 R2 und 2012 denn geändert?

Ich habe eher zufällig gelesen dass der DWM - Desktop Windows Manager) ab 2012 immer aktiviert ist und nicht abgeschaltet werden kann. Ist auf dem 2008 System der DWM in den Prozessen aufgeführt (in der RDP Sitzung)?

Wenn es am Betriebssystem liegt, muss das Problem überall auf 2012er RDP Umgebungen reproduzierbar sein. Ist es möglich eine kompilierte Testanwendung bereitzustellen?

Viele Grüße
Michael Justin
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer
Online

Registriert seit: 13. Aug 2002
17.202 Beiträge
 
Delphi 10.4 Sydney
 
#10

AW: Zugriff auf Strings / Listen langsam?

  Alt 2. Okt 2014, 08:07
Sind das eigentlich normale W2012-Server oder sind diese Citrix-Verseucht?
Habe schon öfter Problem gehabt die an Citrix lagen und durch Updates von Citrix behoben wurden.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23      

 

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 17:28 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