Как настроить FastMM для обнаружения утечки памяти в dll
Я не могу понять, как обнаружить утечки памяти в статически или даже динамически связанной dll. Я просто хочу обнаружить утечки в dll, и я не хочу делиться менеджером памяти между dll и приложением. Кроме того, dll является связан с пакетами времени выполнения
мой пример dll выглядит так:
library dll;
uses
fastmm4,
System.SysUtils,
System.Classes;
{$R *.res}
procedure MyInit; stdcall;
Begin
TObject.Create;
End;
exports MyInit;
begin
end.
применение dpr:
program app;
uses
//fastmm4,
Vcl.Forms,
main in 'main.pas' {Form1};
{$R *.res}
begin
Application.Initialize;
Application.MainFormOnTaskbar := True;
Application.CreateForm(TForm1, Form1);
Application.Run;
end.
Примечание: Если я раскомментирую fastmm4, чем я могу обнаружить memleak, вызванный приложением (TStringList.Create), но не утечка в dll.
и в главном блоке Приложения:
unit main;
interface
uses
Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls;
type
TForm1 = class(TForm)
procedure FormCreate(Sender: TObject);
private
LDLLHandle: HModule;
LShowProc: TProcedure;
end;
var
Form1: TForm1;
{$ifdef static}
procedure MyInit; stdcall; external 'dll.dll';
{$endif}
implementation
{$R *.dfm}
procedure TForm1.FormCreate(Sender: TObject);
begin
TStringList.Create;
{$ifdef static}
MyInit;
{$else}
LDLLHandle := LoadLibrary('dll.dll');
if LDLLHandle <> 0 then
begin
try
LShowProc := GetProcAddress(LDLLHandle, 'MyInit');
if Assigned(LShowProc) then
LShowProc;
finally
FreeLibrary(LDLLHandle);
end;
end;
{$endif}
end;
end.
Я ожидаю от FastMM генерировать отчет при вызове FreeLibrary или при выходе из программы, если dll статически загружена, но ничего не происходит.
на FastMM4Options.inc
кроме того, я просто поставил FullDebugMode и ClearLogFileOnStartup и FastMM_FullDebugMode.dll файлы в выходной справочник.
Я создал репозиторий на github. Что я упускаю?
2 ответов
причина, по которой ваша DLL не сообщает об утечках, проистекает из этого кода при выключении FastMM:
CheckBlocksOnShutdown(
{$ifdef EnableMemoryLeakReporting}
True
{$ifdef RequireIDEPresenceForLeakReporting}
and DelphiIsRunning
{$endif}
{$ifdef RequireDebuggerPresenceForLeakReporting}
and ((DebugHook <> 0)
{$ifdef PatchBCBTerminate}
or (Assigned(pCppDebugHook) and (pCppDebugHook^ <> 0))
{$endif PatchBCBTerminate}
)
{$endif}
{$ifdef ManualLeakReportingControl}
and ReportMemoryLeaksOnShutdown
{$endif}
{$else}
False
{$endif}
);
в параметрах, RequireDebuggerPresenceForLeakReporting
определяется. Более того, в DLL, DebugHook
равна 0
, предположительно, потому, что вы отлаживаете приложение, а не DLL. Это означает, что вы называете CheckBlocksOnShutdown
передает False
. И это False
отключить отчеты об утечках.
вы можете решить эту проблему, не определив RequireDebuggerPresenceForLeakReporting
.
Я просто тестирую его с версией Fast Memory Manager 4.97 на Delphi2010-win7
- FastMM4 является первой единицей в предложении "uses".dpr (проект и dll)
- опция "ShareMM" включена 'AttemptToUseSharedMM' включена 'EnableMemoryLeakReporting' включена
Добавить FastMM_FullDebugMode.dll в папке exe
существует также динамически загружаемая тестовая демонстрация ДЛЛ' Это демо без ShareMem. Я должен установить опцию "ShareMM" и "AttemptToUseSharedMM" и добавить FastMM_FullDebugMode.dll, чтобы иметь отчет об утечке FastMM.