3

FastMMを使用してプログラムをデバッグしていますが、報告されているメモリリークの多くは、実際のメモリリークではなく、正当なメモリ割り当てのようです。

例えば、

A memory block has been leaked. The size is: 20

This block was allocated by thread 0xD44, and the stack trace (return addresses) at the time was:
404902 [System.pas][System][@GetMem][3693]
406597 [System.pas][System][TObject.NewInstance][11044]
406B2A [System.pas][System][@ClassCreate][12121]
60A1D2 [CtrlObjs.pas][Ctrlobjs][TConnObj.Create][430]
61703B [Control.pas][Control][TControlMgr.FindLinks][854]
60ACB2 [CtrlObjs.pas][Ctrlobjs][TControlObject.FindLink][746]
60E2A3 [CtrlObjs.pas][Ctrlobjs][TDelayControl.EvalPulse][2105]
60E4C0 [CtrlObjs.pas][Ctrlobjs][TDelayControl.Evaluate][2193]
6102D4 [CtrlObjs.pas][Ctrlobjs][TLineControl.Evaluate][3155]
60ABF1 [CtrlObjs.pas][Ctrlobjs][TControlObject.ActiveCount][711]
6105D8 [CtrlObjs.pas][Ctrlobjs][TLineControl.ActiveCount][3261]

The block is currently used for an object of class: TConnObj

TConnObjは、オブジェクトを作成するために頻繁に使用されるクラスであり、プログラムがオブジェクトを必要としなくなったときに破棄されます。ただし、FastMMは、実際のメモリリークであると報告しています。では、FastMMメモリリークログファイルを見ると、どれがどれであるかをどのように判断できますか?

4

1 に答える 1

8

FastMMがそれをリークとして報告している場合、それは実際にはリークです。

オブジェクトを作成しましたが、プログラムが終了する前にオブジェクトを破棄できませんでした。通常、これはコードの単純なエラーが原因です。おそらく、オブジェクトの生命を保護するために、try/finallyを省略しました。

破棄されていないグローバルスコープオブジェクトの場合は、プログラムの終了時に破棄するだけで済みます。または、RegisterExpectedMemoryLeakを呼び出して、そのオブジェクトを破棄するつもりがないことを示すことができます。ただし、意図的にオブジェクトをリークする場合にのみ実行してください。意図的ではないリークを紙に書くために使用しないでください。

しかし、肝心なのは、FastMMは嘘をつかないということです。漏れていると表示されている場合は、それを信頼してください。

于 2012-04-17T21:09:44.923 に答える