AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Memory Leak bei Verwendung von TIBDataSet
Thema durchsuchen
Ansicht
Themen-Optionen

Memory Leak bei Verwendung von TIBDataSet

Ein Thema von the_dude82 · begonnen am 23. Aug 2007 · letzter Beitrag vom 24. Aug 2007
Antwort Antwort
the_dude82

Registriert seit: 23. Aug 2007
2 Beiträge
 
#1

Memory Leak bei Verwendung von TIBDataSet

  Alt 23. Aug 2007, 17:34
Datenbank: Firebird • Zugriff über: ADO
Guten Tag

Ich habe ein Problem beim Freigeben von Speicher einer IBDataSet. Und zwar wird der Speicher trotz Free, FreeAndNil, Release einfach nicht frei.
Kann nicht verstehen was der Grund dafür ist.

Das DataSet ist in einer Klasse die mehrmals erzeugt und auch wieder zerstört wird, was mit der Zeit zu einem deutlichen Memoryleak führt.


Hier die Klasse (nur Konstruktor und Destruktor):

Delphi-Quellcode:
unit UnitLayoutAssignmentManager;

interface

uses
  SysUtils, Variants, Classes, DB, IBDatabase, IBCustomDataSet;

type
  TLayoutAssignmentManager = class(TObject)
    
  private
    { Private-Deklarationen }
    myIBTransaction: TIBTransaction;
    myIBDataSet: TIBDataSet;

    procedure LoadLayoutPath;
    procedure LoadLayoutAssignments;
  public
    { Public-Deklarationen }
    constructor CreateWithDB(db: TIBDatabase);
    destructor Destroy; override;
    function GetLayoutForMatnr(matnr: string): string;
    procedure AddAssignment(matnr, layout: string);
  published
    property DataSet: TIBDataSet read myIBDataSet;
  end;

var
  LayoutAssignmentManager: TLayoutAssignmentManager;
  LayoutPath: String;

implementation

// Datenbank ist bereits vorher erzeugt worden und wird im Konstruktor übergeben
constructor TLayoutAssignmentManager.CreateWithDB(db: TIBDatabase);
begin
  inherited Create;

  myIBDataset := TIBDataSet.Create(nil);
  myIBTransaction := TIBTransaction.Create(nil);
  
  // DataSet und Transaction mit DB verbinden
  with myIBTransaction do begin
    DefaultDatabase := db;
  end;

  with myIBDataSet do begin
    Database := db;
    Transaction := myIBTransaction;
  end;

  ...

end;

destructor TLayoutAssignmentManager.Destroy;
begin

  // Hier ist die Stelle, an der der Speicher nicht freigegeben wird
  myIBTransaction.Free;
  myIBDataSet.Free;

  inherited Destroy;

end;

end.

Und hier die Stelle an der die Klasse eingesetzt wird:

Delphi-Quellcode:
  ...

  layoutAssignmentManager := TLayoutAssignmentManager.CreateWithDB(IBDB1);
  layout := layoutAssignmentManager.GetLayoutForMatnr(matnr);

  if Length(layout) = 0 then
  begin
  // Es wurde keine oder keine gültige Zuweisung gefunden
  // -> neue Zuweisung erstellen

  OpenDialog1.Title := 'Layout für Materialnummer "' + matnr + '" auswählen';
  if OpenDialog1.Execute then begin
    layout := ChangeFileExt(ExtractFileName(OpenDialog1.FileName),'');
    layoutAssignmentManager.AddAssignment(matnr, layout);
    end;
  end;

  // Speicher freigeben
  layoutAssignmentManager.Free;

  ...
Ich hoffe ihr könnt mir helfen.
Danke schon im Voraus.

Gruss
Stefan
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

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

Re: Memory Leak bei Verwendung von TIBDataSet

  Alt 23. Aug 2007, 18:20
Ich würde sie Klasse als Owner übergeben, dann kümmert die sich automatisch um die Entsorgung des DataSets.
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.201 Beiträge
 
Delphi 10.4 Sydney
 
#3

Re: Memory Leak bei Verwendung von TIBDataSet

  Alt 23. Aug 2007, 18:37
Häng dir doch FastMM4 rein und schalte die TD32-Debug-Infos an. Dann bekommst du doch raus obs an dir oder an TIBDataset liegt.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Benutzerbild von RavenIV
RavenIV

Registriert seit: 12. Jan 2005
Ort: Waldshut-Tiengen
2.875 Beiträge
 
Delphi 2007 Enterprise
 
#4

Re: Memory Leak bei Verwendung von TIBDataSet

  Alt 24. Aug 2007, 09:19
ein Objekt mit
XYZ.create (nil); zu erzeugen ist immer schlecht.
Wer soll da wissen, wer für das neue Objekt zuständig ist.
Es hat schon seinen Sinn, dass man da einen Owner übergeben soll.
In der Regel ist der Self ein guter Kandidat für den Owner...
Klaus E.
Linux - das längste Text-Adventure aller Zeiten...
Wer nie Linux mit dem vi konfiguriert hat, der hat am Leben vorbei geklickt.
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.276 Beiträge
 
Delphi 10.4 Sydney
 
#5

Re: Memory Leak bei Verwendung von TIBDataSet

  Alt 24. Aug 2007, 09:53
Hallo,

zu jedem Create gehört ein try finally.

Was ich an deinem Bsp z.B. nicht sehe ist ein layout.Free.

Nimm fastmm4 oder memcheck (das bevorzuge ich).


Heiko
Heiko
  Mit Zitat antworten Zitat
the_dude82

Registriert seit: 23. Aug 2007
2 Beiträge
 
#6

Re: Memory Leak bei Verwendung von TIBDataSet

  Alt 24. Aug 2007, 11:15
Ich hab die Klasse nun von TComponent abgeleitet und IBDataSet self als Owner übergeben.
Scheint ganz gut zu klappen.

@ hoika: layout ist ein String.
Bin noch recht neu bei Delphi, aber so wie ich das verstanden habe, muss man Strings weder erzeugen noch zerstören.

Danke nochmal für die Hilfe und Gruss
Stefan
  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 04:00 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