嵌入式linux內存
『壹』 嵌入式linux怎麼檢內存泄漏雨
檢測內存泄露主要有以下5種方法:
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怎麼檢內存泄漏雨
1. 在需要內存泄漏檢查的代碼的開始調用void mtrace(void) (在mcheck.h中? 有聲明). mtrace為malloc等函數安裝hook, 用於記錄內存分配罩春信息.在需要內存泄漏檢查的代碼的結束調用void muntrace(void).x0dx0a 注意: 一般情況下不要調用muntrace, 而讓程序自然結束. 因為可能有些釋放內存代碼要到muntrace之後才運行.x0dx0ax0dx0a 2. 用debug模式編譯被檢查代碼(-g或-ggdb)x0dx0ax0dx0a 3. 設置環境變數MALLOC_TRACE為一文件名, 這一文件將存有內存分配信息.x0dx0ax0dx0a 4. 運行被檢查程序, 直至結束或muntrace被調用.x0dx0ax0dx0a 5. 用mtrace命令解析內存分配姿悶衫Log文件($MALLOC_TRACE)x0dx0a (mtrace foo $MALLOC_TRACE, where foo is the executible name)x0dx0a 如果有內存泄漏, mtrace會輸出分配泄漏x0dx0a 內存的代碼位置,以及分配數量.x0dx0ax0dx0a 附加說明x0dx0a 1. 可以將mtrace, muntrace放入信號處理函數(USR1, USR2), 以動態地進行內存泄漏檢查控制.x0dx0a 2. mtrace是個perl代碼, 如果你對符號地址與代碼文本的轉換感興趣, 可以讀一下.x0dx0a 3. again, 盡量不要用muntrace()x0dx0a For C++ Leak:x0dx0a 檢查內存泄漏的方法除glibc提供外;還可以試試一些專用的程序。x0dx0a 很奇怪,redhat 9 居然不帶mtrace perl腳本,只好下載gcc源碼編譯了x0dx0a wget --passive-ftp ftp://rpmfind.net/linux/redhat/9 ... -2.3.2-11.9.src.rpmx0dx0a rpm -ivh glibc*.src.rpmx0dx0a cd /usr/src/redhat/SPECS/x0dx0a rpmbuild -ba glibc-9.specx0dx0a cd /var/tmp/glibc-2.3.2-root/usr/bin/x0dx0a cp mtrace /usr/bin/x0dx0a 調試方法如下:x0dx0a vi a.cx0dx0a 1 #includex0dx0a 2x0dx0a 3 int main()x0dx0a 4 {x0dx0a 5 mtrace();x0dx0a 6 malloc(10);x0dx0a 7 malloc(16);x0dx0a 8 return 0;x0dx0a 9 }x0dx0a $gcc -g a.c #記得編譯帶-g調試選項x0dx0a $export MALLOC_TRACE=a.logx0dx0a $./a.outx0dx0a $unset MALLOC_TRACE #記得執行完後unset變數,否則可能運行其他命令可能跡腔覆蓋logx0dx0a $mtrace a.out a.logx0dx0a Memory not freed:x0dx0a -----------------x0dx0a Address Size Callerx0dx0a 0x09b08378 0xa at /XXX/a.c:6x0dx0a 0x09b08388 0x10 at /XXX/a.c:7x0dx0a 可以看到,會顯示未釋放動態空間的代碼具體位置。