Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   XML (https://www.delphipraxis.net/46-xml/)
-   -   Delphi IXMLdocument Memoryleak (https://www.delphipraxis.net/190764-ixmldocument-memoryleak.html)

Sequitar 4. Nov 2016 14:24

IXMLdocument Memoryleak
 
Hallo, ich versuche gerade, Daten über das XML-format auszutauschen (der Inhalt sei hier unberücksichtigt). Habe bei der erstellung eines XML documents über das IXML interface jedoch ein memoryleak. Wie kann ich das umgehen / eheben?
Ich ging davon aus dass die Nutzung des IXMLDocument interface automatisch reference counted ist und somit keine manuelle freigabe des dahinterliegenden TXMLDocuments nötig ist?

Delphi-Quellcode:

Procedure ClearXMLnode(Var Node: Ixmlnode);
Var
  Temp: Ixmlnode;
  I, Count: Integer;
Begin
  Count := Node.ChildNodes.Count;
  I := 0;
  While I < Count Do
  Begin
    Temp := Node.ChildNodes[I];
    ClearXMLnode(Temp);
    // temp:=nil;
    Inc(I);
  End;
  Node := Nil;
End;

Procedure Run_test(Sender: TObject);
Var
  Xml: Ixmldocument;
  Root, Node: Ixmlnode;
Begin
  // With Ttester.Create Do
  Begin
    // Test_leakProc( // custom memory leak tester
    // Procedure
    Begin
      Xml := Newxmldocument;
      Assert(Xml.Active);
      Root := Xml.AddChild('XML');
      Node := Root.AddChild('firstentry');
      Root.ChildNodes[0].AddChild('aaa');
      Root.ChildNodes[0].AddChild('bb');
      // clear document
      ClearXMLnode(Root);
      Node := Nil;
      Xml.Active := False;
      Xml := Nil;
    End
    // , 0);
    // Writereport(Memo1); // custom output of memoryleaks if detected
    // Free;
  End;
End;
Auch wenn bei //do something kein weiterer code ausgeführt wird stelle ich ein memoryleak fest... relativ klein (28 b), aber bei mehrfacher verwendung / langlaufender application (service) würde ich das gerne vermeiden.

Bambini 4. Nov 2016 15:02

AW: IXMLdocument Memoryleak
 
Zitat:

Zitat von Sequitar (Beitrag 1352652)
Auch wenn bei //do something kein weiterer code ausgeführt wird stelle ich ein memoryleak fest... relativ klein (28 b), aber bei mehrfacher verwendung / langlaufender application (service) würde ich das gerne vermeiden.

Wie stellt du diesen Leak fest? Ein ReportMemoryLeaksOnShutdown := True; stellt nix fest.

Sequitar 4. Nov 2016 15:45

AW: IXMLdocument Memoryleak
 
Liste der Anhänge anzeigen (Anzahl: 1)
hallo, die leaks teste ich wie angegeben 8auskommentiert)mit nem eigenen tester. Dieser beutzt
Delphi-Quellcode:
Function Ttester.MemoryUsed: Cardinal;
Var
  St: TMemoryManagerState;
  Sb: TSmallBlockTypeState;
Begin
  GetMemoryManagerState(St);
  Result := St.TotalAllocatedMediumBlockSize + St.TotalAllocatedLargeBlockSize;
  For Sb In St.SmallBlockTypeStates Do
  Begin
    Result := Result + Sb.UseableBlockSize * Sb.AllocatedBlockCount;
  End;
End;
zur bestimmung des Verbrauchs

Unit dazu im Anhang

Bambini 4. Nov 2016 15:55

AW: IXMLdocument Memoryleak
 
Da du den MSXML Parser verwendest, liegt der scheinbare Mem-Zuwachs außerhalb von Delphi.
Das muss kein Leak sein, vielleicht hält MS Speicherblöcke als Puffer vorrätig.
Wenn du da kein Vertrauen hast, verwende eine native Delphi XML Lib.

Blup 4. Nov 2016 15:58

AW: IXMLdocument Memoryleak
 
Eventuell wird für den Zugriff auf "ChildNodes[0]" eine versteckte Variable mit einer Interfacereferenz erzeugt, die erst beim Verlassen der Prozedur freigegeben wird.

Sequitar 4. Nov 2016 16:13

AW: IXMLdocument Memoryleak
 
Danke schon mal für die Hinweise.
Das leak bleibt auch bestehen, falls keine nodes hinzugefügt werden.
Also nur
Delphi-Quellcode:
begin
 xml:=newxmldocument;
 xml:=nil;
end;
Daher vermute ich dass ich das XML dcoument vlt falsch erstellt habe (newxmldocument erstellt ja eine interface reference auf ein TXMLdocumment), oder das dann nicht korrekt freigegeben wird (reference count);

Welche Delphi alternativen gibts denn zu msxml, falls das denn der Grund sein sollte?

Nachtrag.

Die eigentliche idee war über ein xmldcoument das mainmenu einer form dynamisch zu erstellen (div. GUI Sprachen, nachträgliche erweiterungen, ohne dass ich das ganze menu in der *PAS erstelle, sondern z.b als Resource zur Verfügung stelle / extern lade), und bei Bedarf durch neue funktionen zu erweitern.
Macht das üerhaupt Sinn? Alternativen?

Bambini 4. Nov 2016 17:26

AW: IXMLdocument Memoryleak
 
Zitat:

Zitat von Sequitar (Beitrag 1352664)
Daher vermute ich dass ich das XML dcoument vlt falsch erstellt habe (newxmldocument erstellt ja eine interface reference auf ein TXMLdocumment), oder das dann nicht korrekt freigegeben wird (reference count);

Nö, sieht ganz gut aus. Aber ob deine Memoryabfrage wirklich nur dein Programm wiederspiegelt :gruebel:?
Zitat:

Zitat von Sequitar (Beitrag 1352664)
Welche Delphi alternativen gibts denn zu msxml, falls das denn der Grund sein sollte?

Die Unit Xml.adomxmldom ist glaube ich ab Delphi 2010 dabei

Zitat:

Zitat von Sequitar (Beitrag 1352664)
Die eigentliche idee war über ein xmldcoument das mainmenu einer form dynamisch zu erstellen (div. GUI Sprachen, nachträgliche erweiterungen, ohne dass ich das ganze menu in der *PAS erstelle, sondern z.b als Resource zur Verfügung stelle / extern lade), und bei Bedarf durch neue funktionen zu erweitern.
Macht das üerhaupt Sinn? Alternativen?

Das Menu erweitern, klingt schon gut, aber welche Funktion wird dann ausgeführt? wenn es die Funktion eh schon gibt, solch ein Customizing von Menus bieten schon viele Toolbars an.
Nur die Delphi eigene nicht ;-) Schau mal nach Toolbar2000 o.ä.


Alle Zeitangaben in WEZ +1. Es ist jetzt 01:34 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