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 ftp://rpmfind.net/linux/redhat/9 ... -
rpm -ivh glibc*.src.rpm
cd /usr/src/redhat/SPECS/
rpmbuild -ba glibc-9.spec
cd /var/tmp/glibc-
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=a.log
$./a.out
$unset MALLOC_TRACE #記得執行完後unset變數,否則可能執行其他命令可能覆蓋log
$mtrace a.out a.log
Memory not freed:
-----------------
Address Size Caller
0x09b08378 0xa at /XXX/a.c:6
0x09b08388 0x10 at /XXX/a.c:7
可以看到,會顯示未釋放動態空間的代碼具體位置。


