AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Programmablauf in VM korrekt, ohne VM nicht
Thema durchsuchen
Ansicht
Themen-Optionen

Programmablauf in VM korrekt, ohne VM nicht

Ein Thema von dGeek · begonnen am 28. Mär 2015 · letzter Beitrag vom 28. Mär 2015
Antwort Antwort
dGeek
(Gast)

n/a Beiträge
 
#1

Programmablauf in VM korrekt, ohne VM nicht

  Alt 28. Mär 2015, 14:38
Ich habe mal wieder ein seltsames Problem.

Mein Programm lädt eine Textdatei, welche einige MB groß ist. Die aufbereiteten Daten werden in einer VirtualStringTree-Komponente gespeichert.

Innerhalb der VM (VMWare, Windows 7 Home Premium 64 Bit) erzeugt funktioniert alles ohne Probleme. Außerhalb der VM (Windows 7 Home Premium 64 Bit) bleibt das Programm beim Laden
der Daten (genauer gesagt, nach etwa 4 MB geladenen Daten) einfach hängen.

Mittlerweile konnte ich auch herausfinden, welche Zeile(n) vermutlich das Problem darstelle(n):
Delphi-Quellcode:
procedure AddVSTStructure(aVST: TVirtualStringTree; aRecord: TTreeData);
var
  Data: PTreeData;
  Node: PVirtualNode;
begin
  Node := aVST.AddChild(nil);
  Data := aVST.GetNodeData(Node);

  aVST.ValidateNode(Node, False);

  Data^ := aRecord;
end;

AddVSTStructure(aNewVST, TreeData);

Nur zur Information: die Daten werden innerhalb eines Threads aufbereitet und der VST-Struktur hinzugefügt.
Ob das daran liegen kann, dass das Windows in der VM nicht geupdated wurde und das außerhalb schon?

Ich habe gerade auch herausgefunden, dass es ohne "ValidateNode" wahrscheinlich funktioniert. Aber was ist an ValidateNode innerhalb eines Threads falsch?
Ok, das war es doch nicht

Geändert von dGeek (28. Mär 2015 um 14:44 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Zacherl
Zacherl

Registriert seit: 3. Sep 2004
4.629 Beiträge
 
Delphi 10.2 Tokyo Starter
 
#2

AW: Programmablauf in VM korrekt, ohne VM nicht

  Alt 28. Mär 2015, 14:45
Machst du denn auch TThread.Synchronize oder TThread.Queue um die Nodes hinzuzufügen? VCL Zugriffe aus einem zweiten Thread heraus musst du immer synchronisieren, sonst passieren unter anderem solche Freezes.
Projekte:
- GitHub (Profil, zyantific)
- zYan Disassembler Engine ( Zydis Online, Zydis GitHub)
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

AW: Programmablauf in VM korrekt, ohne VM nicht

  Alt 28. Mär 2015, 14:47
Möglicherweise stellt die VM Software nur eine CPU bereit, so dass Du in der VM Glück hast, dass es funktioniert.
Markus Kinzler
  Mit Zitat antworten Zitat
dGeek
(Gast)

n/a Beiträge
 
#4

AW: Programmablauf in VM korrekt, ohne VM nicht

  Alt 28. Mär 2015, 14:51
Das Hinzufügen der Nodes ist synchronisiert, richtig.

Und mit der CPU das stimmt auch, die VM hat nur eine CPU bzw einen Kern zur Verfügung.
  Mit Zitat antworten Zitat
Benutzerbild von Zacherl
Zacherl

Registriert seit: 3. Sep 2004
4.629 Beiträge
 
Delphi 10.2 Tokyo Starter
 
#5

AW: Programmablauf in VM korrekt, ohne VM nicht

  Alt 28. Mär 2015, 14:54
Wenn das Hinzufügen synchronisiert ist, hast du wohl an irgendeiner anderen Stelle eine Race Condition, die bei einer CPU nicht auffällt. Immer schwer sowas zu finden. Würde erstmal alles nach unsynchronisierten VCL Zugriffen absuchen und danach schauen, ob du vom Main Thread und vom zweiten Thread aus auf gemeinsame Variablen/Speicherbereiche zugreifst, die eventuell eine Critical Section benötigen.
Projekte:
- GitHub (Profil, zyantific)
- zYan Disassembler Engine ( Zydis Online, Zydis GitHub)
  Mit Zitat antworten Zitat
dGeek
(Gast)

n/a Beiträge
 
#6

AW: Programmablauf in VM korrekt, ohne VM nicht

  Alt 28. Mär 2015, 15:46
Ich glaube den Fehler nun gefunden zu haben.
Die Race Conditions haben mich zum Nachdenken gebracht was 3rd-Party-Code angeht.

Ich hatte hier noch den SJMmfFileReader (http://www.delphipraxis.net/151898-s...ei-reader.html) in Verwendung, welcher für diesen Zweck aber nicht geeignet war.

Ich habe alles testweise auf eine normale Stringlist umgestellt und von einer While- auf eine For-Schleife gewechselt > weniger Probleme.
Danach habe ich den kompletten Code in der For-Schleife mit Synchronize umschlossen > noch weniger Probleme. Aber dennoch ab und zu (1 Mal in 3 Versuchen).

Sehr seltsam.

Edit:
ich habe nun allen Code vom zweiten Thread in den Mainthread verpackt.
Sehr komisch manchmal, dass es nicht funktioniert obwohl man alles richtig macht.

Geändert von dGeek (28. Mär 2015 um 16:20 Uhr)
  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 02:47 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