mtrace檢查內存泄漏

內存泄漏檢查方法(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會輸出分配泄漏 
內存的代碼位置,以及分配數。linux

For C++ Leak: 
檢查內存泄漏的方法除glibc提供外; 
還能夠試試一些專用的程序;如: 
ccmalloc
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:7ui

能夠看到,會顯示未釋放動態空間的代碼具體位置.spa

轉自:http://lagignition.blog.163.com/blog/static/128730023201072421016361/.net

相關文章
相關標籤/搜索