天天看點

用mtrace檢查記憶體洩漏

文章出處:http://lagignition.blog.163.com/blog/static/128730023201072421016361/

記憶體洩漏檢查方法(for Linux)

如果你更想讀原始文檔, 請參考glibc info的"Allocation Debugging" 一章 (執行info libc);

glibc提供了一個檢查記憶體洩漏的方法, 前提是你的程式使用glibc的标準函數 配置設定記憶體(如malloc, alloc...):

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提供外還可以試試一些專用的程式;如:

ccmalloc(http://www.inf.ethz.ch/personal/biere/projects/ccmalloc/ccmalloc-english.html)

mpatrol(http://www.cbmamiga.demon.co.uk/mpatrol/)

這倆個工具的功能相當不錯,能對程式進行相當全面的檢查

很奇怪,redhat 9 居然不帶mtrace perl腳本,隻好下載下傳gcc源碼編譯了

wget --passive-ftp ftp://rpmfind.net/linux/redhat/9/en/os/i386/SRPMS/glibc-2.3.2-11.9.src.rpm

rpm -ivh glibc*.src.rpm

cd /usr/src/redhat/SPECS/

rpmbuild -ba glibc-9.spec

cd /var/tmp/glibc-2.3.2-root/usr/bin/

cp mtrace /usr/bin/

調試方法如下:

vi a.c

1 #include <mcheck.h>
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

可以看到,會顯示未釋放動态空間的代碼具體位置.