1. 在需要記憶體洩漏檢查的程式碼的開始呼叫void mtrace(void) (在mcheck.h中? 有宣告). mtrace為malloc等函式安裝hook, 用於記錄記憶體分配資訊.在需要記憶體洩漏檢查的程式碼的`結束呼叫void muntrace(void).
注意: 一般情況下不要呼叫muntrace, 而讓程式自然結束. 因為可能有些釋放記憶體程式碼要到muntrace之後才執行.
2. 用debug模式編譯被檢查程式碼(-g或-ggdb)
3. 設定環境變數MALLOC_TRACE為一檔名, 這一檔案將存有記憶體分配資訊.
4. 執行被檢查程式, 直至結束或muntrace被呼叫.
5. 用mtrace命令解析記憶體分配Log檔案($MALLOC_TRACE)
(mtrace foo $MALLOC_TRACE, where foo is the executible name)
如果有記憶體洩漏, mtrace會輸出分配洩漏
記憶體的程式碼位置,以及分配數量.
附加說明
1. 可以將mtrace, muntrace放入訊號處理函式(USR1, USR2), 以動態地進行記憶體洩漏檢查控制.
2. mtrace是個perl程式碼, 如果你對符號地址與程式碼文字的轉換感興趣, 可以讀一下.
3. again, 儘量不要用muntrace()
For C++ Leak:
檢查記憶體洩漏的方法除glibc提供外;還可以試試一些專用的程式。
很奇怪,redhat 9 居然不帶mtrace perl指令碼,只好下載gcc原始碼編譯了
wget --passive-ftp ...
rpm -ivh glibc*
cd /usr/src/redhat/SPECS/
rpmbuild -ba
cd /var/tmp/glibc-2.3.2-root/usr/bin/
cp mtrace /usr/bin/
除錯方法如下:
vi a.c
1 #include
2
3 int main()
4 {
5 mtrace();
6 malloc(10);
7 malloc(16);
8 return 0;
9 }
$gcc -g a.c #記得編譯帶-g除錯選項
$export MALLOC_TRACE=
$./
$unset MALLOC_TRACE #記得執行完後unset變數,否則可能執行其他命令可能覆蓋log
$mtrace
Memory not freed:
-----------------
Address Size Caller
0x09b08378 0xa at /XXX/a.c:6
0x09b08388 0x10 at /XXX/a.c:7
可以看到,會顯示未釋放動態空間的程式碼具體位置。