Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Object-Pascal / Delphi-Language (https://www.delphipraxis.net/32-object-pascal-delphi-language/)
-   -   Delphi Kann so ein Speicherleck entstehen? (https://www.delphipraxis.net/73754-kann-so-ein-speicherleck-entstehen.html)

AirJordan 23. Jul 2006 16:43


Kann so ein Speicherleck entstehen?
 
Hallo,

ich habe mal eine kleine Frage ob mit meinem Beispielcode ein Speicherleck entstehen kann,
weil eine TStringList nicht korrekt aus dem Speicher geräumt wird.

Folgende Funktion wurde definiert:

Delphi-Quellcode:
function TbvshOfficeHauptformular.GetVereineEmail: TStringList;
var iVereinsStr, iVereinsFuktionaer: String;
begin
  Result := TStringList.Create;
  try
   [..]
   SQL Abfrage auf die Datenbank
   [..]
   while not dmBVSH.sqlBVSHVereine.Eof do
   begin
     with [..] SQL Abfrage [..] do
     begin
       iVereinsStr := [..] String wird erstellt [..]
       Result.Add(iVereinsStr);
       Next;
     end;
   end;
end;
und die Funktion wird nun in der Procedure die ausgelöst wird, wenn der
Schalter im Programm gedrückt wird.

Delphi-Quellcode:
procedure TbvshOfficeHauptformular.dxBVSHNavBarGruppeUpdateVereineExportThunderbirdClick(Sender: TObject);
var slVereinsDaten: TStringList;

  procedure CreateVereineExportThunderbird;
  begin
    slVereinsDaten := GetVereineEmail;

    try
      slVereinsDaten.SaveToFile('.\Export\BVSHEmails.CSV'); //Datei speichern
    finally
      slVereinsDaten.Free; //Objekt wieder freigeben
    end;
    MessageDlg('>HinweisText<', mtInformation, [mbOK], 0);
  end;

begin
  if bvshSicherheit then
  begin
    if MessageDlg('>HinweisText<', mtConfirmation,[mbNo, mbYes], 0) = mrYes then CreateVereineExportThunderbird;
  end else CreateVereineExportThunderbird;
end;
Wird die StringList, die in der Procedure über die Funktion erstellt wird, auch korrekt freigegeben?
Danke für eure Hinweise.

marabu 23. Jul 2006 16:50

Re: Kann so ein Speicherleck entstehen?
 
Hallo Holger,

es hängt alles von der genauen Implementierung von GetVereineEmail ab. Wenn nach der Speicheranforderung im Konstruktor eine Exception geworfen wird, die in der Funktion nicht abschließend bearbeitet wird, dann erhält der aufrufende event handler nie die Kontrolle und die dortige Freigabe wird nie durchlaufen.

Grüße vom marabu

AirJordan 23. Jul 2006 16:59

Re: Kann so ein Speicherleck entstehen?
 
Hallo marabu,

ok habe ich verstanden. Wenn die SQL Abfrage aus irgendwelchen Gründe in´s Leere laufen würde,
dann würde die Free Routine nichts zum Freigeben haben und das Programm würde hängen oder
Ähnliches.

3_of_8 23. Jul 2006 17:09

Re: Kann so ein Speicherleck entstehen?
 
Free überprüft vor dem Aufruf von Destroy, ob was drin ist oder nicht. Das gibt keine Exception.

Es kann allerdings tatsächlich passieren, dass die Ausnahmebehandlungsroutine einfach so weit rausspringt, dass die StringList nie gefreet wird.

Christian Seehase 23. Jul 2006 17:15

Re: Kann so ein Speicherleck entstehen?
 
Moin Holger,

Zitat:

Zitat von AirJordan
Wenn die SQL Abfrage aus irgendwelchen Gründe in´s Leere laufen würde,dann würde die Free Routine nichts zum Freigeben

marabu meinte, wenn in GetVereineEmail nach dem Erzeugen der StringListe eine Exception auftritt, könnte es passieren, dass nicht mehr zu CreateVereineExportThunderbird zurückgesprungen wird, womit das slVereinsDaten.Free nie aufgerufen würde.

Erzeuge doch einfach die StringListe in CreateVereineExportThunderbird und übergebe sie dann als Parameter.

AirJordan 24. Jul 2006 19:51

Re: Kann so ein Speicherleck entstehen?
 
Hallo

und vielen Dank für die ausführlichen Antworten. Ich werde die Routine dann nochmal überarbeiten.


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