Как настроить 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.