单线程下使用系统自带mtrace
即可.使用方法如下所示.
在代码中添加如下代码.
#include <mcheck.h>
void mtrace(void);
void muntrace(void);
#include <stdlib.h>
#include <stdio.h>
#include <mcheck.h>
int main(int argc, char **argv)
{
setenv("MALLOC_TRACE", "output", 1);
mtrace();
char * p = malloc(100);
free(p);
p = malloc(1000);
muntrace();
return 0;
}
编译产生可执行文件.
编译时请加入-g
参数.
cmake添加方式如下所示
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -g")
gcc添加方式如下所示.
gcc main.c -g
之后运行可执行文件后,同级文件夹下产生一个名为output
的文件.
执行下列命令
mtrace app_main output
输出如下所示.
wq@wq-Virtual-Machine:~/work/test_zlog/build$ ./app_main
wq@wq-Virtual-Machine:~/work/test_zlog/build$ mtrace app_main output
Memory not freed:
-----------------
Address Size Callerpossibly lost0x0000000001374860 0x3e8 at /home/wq/work/test_zlog/main.c:19
wq@wq-Virtual-Machine:~/work/test_zlog/build$