AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Array korrekt freigeben

Ein Thema von woodie · begonnen am 23. Sep 2025 · letzter Beitrag vom 26. Sep 2025
Antwort Antwort
Seite 1 von 2  1 2      
woodie

Registriert seit: 30. Sep 2020
8 Beiträge
 
#1

Array korrekt freigeben

  Alt 23. Sep 2025, 14:39
Delphi-Version: 5
Hallo zusammen ich habe folgenden Code:

Code:
var AString := 'Test;1';
var AArray := AString.Split([';']);

//...

Setlength(AArray,0);
Finalize(AArray);
AArray:=nil;
Warum wird mir bei FastMM5 trotzdem ein Leak angezeigt? Was muss mit dem Array passieren, um den Leak zu unterbinden? oder ist die Split Funktion fehlerhaft?


Code:
A memory block has been leaked. The size is: 78

This block was allocated on 2025-09-23 15:28:03.379 by thread 10096, and the stack trace (return addresses) at the time was:
0096A473 [FastMM5.pas][FastMM5][FastMM_DebugGetMem_GetDebugBlock$qqrio][8039]
0096A53B [FastMM5.pas][FastMM5][FastMM_DebugGetMem$qqri][8075]
009478BA [System.pas][System][GetMem][4965]
0094CF9F [System.pas][System][NewUnicodeString][26083]
0094D1E0 [System.pas][System][UStrFromPWCharLen][26697]
0094E597 [System.pas][System][UStrCopy][32009]
009BADFF [System.SysUtils.pas][System.SysUtils][Sysutils.TStringHelper.InternalSplit][31746]
009BB040 [System.SysUtils.pas][System.SysUtils][Sysutils.TStringHelper.Split][31814]
009BAA52 [System.SysUtils.pas][System.SysUtils][Sysutils.TStringHelper.Split][31580]
01EE8B9C [Test.pas][Test][TTestItem.TestF1][1926]
  Mit Zitat antworten Zitat
Thaddy

Registriert seit: 23. Jan 2012
2 Beiträge
 
#2

AW: Array korrekt freigeben

  Alt 23. Sep 2025, 15:43
Setlength(AArray,0);
Finalize(AArray); // <---

Dass ist doppel: double free. Beide machen dasselbe.

Geändert von Thaddy (23. Sep 2025 um 15:46 Uhr)
  Mit Zitat antworten Zitat
Der schöne Günther

Registriert seit: 6. Mär 2013
6.226 Beiträge
 
Delphi 10 Seattle Enterprise
 
#3

AW: Array korrekt freigeben

  Alt 23. Sep 2025, 16:48
Vielleicht im Debugger noch einen der Strings in Visualizer gehabt? Da kann sowas passieren.

Sowas elementares wie String.Split(..) wird ja kaum kaputt sein.
  Mit Zitat antworten Zitat
TiGü

Registriert seit: 6. Apr 2011
Ort: Berlin
3.082 Beiträge
 
Delphi 10.4 Sydney
 
#4

AW: Array korrekt freigeben

  Alt Gestern, 11:03
Vielleicht im Debugger noch einen der Strings in Visualizer gehabt? Da kann sowas passieren.
Hand hoch, wer auch schon mal einen halben Tag auf der Suche nach derartigen Speicherlecks verbracht hatte und sich immer wunderte, warum der FastMM beim Kollegen (ohne derartiges Untersuchungsobjekt in der Watch List) das Problem nicht anzeigte!
  Mit Zitat antworten Zitat
Blup

Registriert seit: 7. Aug 2008
Ort: Brandenburg
1.498 Beiträge
 
Delphi 12 Athens
 
#5

AW: Array korrekt freigeben

  Alt Heute, 07:50
Mit Finalize muss man sehr vorsichtig sein, sonst erzeugt man an anderer Stelle eine Zugriffsverletzung.
Delphi-Quellcode:
type
  TMyRecord = record
    A: Integer;
    B: String;
    C: IInterface;
    procedure Clear;
  end;

implementation

procedure TMyRecord.Clear;
begin
  Finalize(Self); // für Strings, Interfaces, Array usw.
  FillChar(Self, SizeOf(Self), 0);
end;
Finalize prüft ob B und C auf Nil verweisen.
Ist das nicht der Fall, wird der Referenzzähler des Strings oder Objects verringert.
Fällt der Referenzzähler auf 0 wird der String oder das Object freigegeben, der Inhalt der Variablen aber nicht verändert.
Durch FillChar verweisen B und C danach auf Nil.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Array korrekt freigeben

  Alt Heute, 09:10
Delphi-Quellcode:
procedure TMyRecord.Clear;
begin
  Self := Default(TMyRecord);
end;
und eventuell noch bissl Custom-Managed-Records mit drauf.

https://docwiki.embarcadero.com/RADS...anaged_Records
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.058 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#7

AW: Array korrekt freigeben

  Alt Heute, 09:35
Mit Finalize muss man sehr vorsichtig sein, sonst erzeugt man an anderer Stelle eine Zugriffsverletzung.
Delphi-Quellcode:
type
  TMyRecord = record
    A: Integer;
    B: String;
    C: IInterface;
    procedure Clear;
  end;

implementation

procedure TMyRecord.Clear;
begin
  Finalize(Self); // für Strings, Interfaces, Array usw.
  FillChar(Self, SizeOf(Self), 0);
end;
Finalize prüft ob B und C auf Nil verweisen.
Ist das nicht der Fall, wird der Referenzzähler des Strings oder Objects verringert.
Fällt der Referenzzähler auf 0 wird der String oder das Object freigegeben, der Inhalt der Variablen aber nicht verändert.
Durch FillChar verweisen B und C danach auf Nil.
Falsch, auch Finalize setzt die Felder von managed Types auf ihren "leer/nil" Status - denn genau dadurch wird der entsprechende Mechanismus hinter diesen Typen getriggert.
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight

Geändert von Stevie (Heute um 09:38 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.058 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#8

AW: Array korrekt freigeben

  Alt Heute, 09:31
Vielleicht im Debugger noch einen der Strings in Visualizer gehabt? Da kann sowas passieren.
Hand hoch, wer auch schon mal einen halben Tag auf der Suche nach derartigen Speicherlecks verbracht hatte und sich immer wunderte, warum der FastMM beim Kollegen (ohne derartiges Untersuchungsobjekt in der Watch List) das Problem nicht anzeigte!
Auf Leak Reports während einer Debugging Session geb ich grundsätzlich gar nix.
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight
  Mit Zitat antworten Zitat
Benutzerbild von bernau
bernau

Registriert seit: 1. Dez 2004
Ort: Köln
1.321 Beiträge
 
Delphi 12 Athens
 
#9

AW: Array korrekt freigeben

  Alt 23. Sep 2025, 18:33
Setlength(AArray,0);
Finalize(AArray); // <---

Dass ist doppel: double free. Beide machen dasselbe.

Warum überhaupt freigeben (beide versionen)? Am Ende der Procedure ist es doch sowiso weg.

Auch würde ich nie auf die Idee kommen "AArray:=nil;" zu verwenden
Gerd
Kölner Delphi Usergroup: http://wiki.delphitreff.de
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Array korrekt freigeben

  Alt 23. Sep 2025, 22:02
Auch würde ich nie auf die Idee kommen "AArray:=nil;" zu verwenden
Große Arrays, wenn sie nicht mehr gebraucht werden, mitten in der Methode freigeben, um Speicher für was Anderes freizumachen.
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 16:07 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz