【內存泄漏】方法二:利用linux的mtrace命令定位內存泄露(Memory Leak)


借鑒於:https://blog.csdn.net/stpeace/article/details/46642507

linux小命令:mtrace(memory trace), 它可以用來協助定位內存泄露。 搞開發的, 應該或多或少地聽說過mtrace.

        下面, 我們來看看程序:

#include <stdio.h>

 

int main()

{

        setenv("MALLOC_TRACE", "test.log", "1");

        mtrace();

 

        int *p = (int *)malloc(2 * sizeof(int));

 

        return 0;

}

編譯:gcc -g -DDEBUG test.c   (千萬要注意, -g不可漏掉, 否則, 雖然最后能定位到內存泄露, 但卻找不到在代碼的第幾行。由於我代碼中沒有Debug宏控制, 所以編譯時, -DDEBUG是可以省略的, 因此, 直接寫成gcc -g mtrace.c -o mtrace即可)

        運行:./mtrace

        定位:mtrace mtrace  test.log

        結果:

 

 可以看到, 有內存泄露,且正確定位到了代碼的行數。

 mtrace函數/命令的原理,記錄每一對malloc/free的調用情況, 從這個意義上來講, mtrace替代了部分我們的眼睛, 緊緊地盯着malloc/free, 所以能看到泄露還是不泄露。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM