在最近的工作中,遇到了一个内存泄漏的问题,查了很多遍代码,都没发现出错点。所以,想借助一些工具来查出错误所在。由于嵌入式系统不像PC那样便利,所以选择了memwatch这个工具来调试,一方面它简单易用,另一方面它恰恰又是内存泄漏检测的好工具。
我遇到的问题如下:内存会按照固定的数值泄漏(比如说是4k,那么系统运行的时候,内存就会按照这个数字递减),但并不是每次使用了的内存都不会释放,怀疑是在某些特殊的条件下没有释放掉内存。所以,写下以下代码来了解学习memwatch这个工具,希望能够帮我查出问题的所在。
- #include <stdio.h>
-
#include <signal.h>
-
#include "memwatch.h"
-
-
int main(int argc,char **argv)
-
{
-
int i = 0;
-
char *p;
-
-
mwInit(); //执行memwatch的初始化工作。虽然memwatch有在第一次使用时能够自动装载,但作者还是建议我们使用该函数。
-
-
p = malloc(100);
-
p = malloc(200);
-
free(p);
-
-
for(i=0;i<5;i++)
-
{
-
p = malloc(50);
-
if(p == NULL)
-
{
-
printf("can't malloc memory for test,num:%d\n",i);
-
continue;
-
}
-
-
if((i%2) == 0)
-
{
-
free(p);
-
p = NULL;
-
}
-
}
-
-
mwTerm(); //执行memwatch的清除工作。当我们使用了mwInit()时,就必须使用该函数来终止memwatch的工作。
-
-
return;
-
}
-
-
-
============= MEMWATCH 2.71 Copyright (C) 1992-1999 Johan Lindh =============
-
-
Started at Sun Feb 26 00:50:08 2012
-
-
Modes: __STDC__ 64-bit mwDWORD==(unsigned long)
-
mwROUNDALLOC==8 sizeof(mwData)==32 mwDataSize==32
-
-
-
Stopped at Sun Feb 26 00:50:08 2012
-
-
unfreed: <9> main.c(18), 50 bytes at 0x96653b0 {FE FE FE FE FE FE FE FE FE FE FE FE FE FE FE FE ................}
-
unfreed: <6> main.c(18), 50 bytes at 0x9665278 {FE FE FE FE FE FE FE FE FE FE FE FE FE FE FE FE ................}
-
unfreed: <1> main.c(12), 100 bytes at 0x96651e0 {FE FE FE FE FE FE FE FE FE FE FE FE FE FE FE FE ................}
-
-
Memory usage statistics (global):
-
N)umber of allocations made: 7
-
L)argest memory usage : 300
-
T)otal of all alloc() calls: 550
-
U)nfreed bytes totals : 200
在memwatch的日志文件中,准确的提出了哪些内存分配没有被释放掉。
备注:在编译源码的时候一定要加上选项-DMEMWATCH及-DMW_STDIO。
阅读(7996) | 评论(0) | 转发(3) |