您的位置:首页 > 其它

定位错误:glibc detected :double free or corruption (!prev): 0x08a03b88

2011-11-22 15:58 811 查看

参考自:

http://topic.csdn.net/u/20090812/15/43cae1c5-938d-4dac-a5f2-192f262d30f5.html

定位free/malloc的位置和参数,可以在对应的.cpp/.h文件中添加:

C代码







#include <stdio.h>

#include <stdlib.h>

void *

debug_malloc(size_t size, const char *file, int line, const char *func)

{

void *p;

p = malloc(size);

printf("%s:%d:%s:malloc(%ld): p=0x%lx\n",

file, line, func, size, (unsigned long)p);

return p;

}

#define malloc(s) debug_malloc(s, __FILE__, __LINE__, __func__)

#define free(p) do { \

printf("%s:%d:%s:free(0x%lx)\n", __FILE__, __LINE__, \

__func__, (unsigned long)p); \

free(p); \

} while (0)

int

main(int argc, char *argv[])

{

char *p;

p = malloc(1024);

free(p);

return 0;

}

#include <stdio.h>
#include <stdlib.h>

void *
debug_malloc(size_t size, const char *file, int line, const char *func)
{
void *p;

p = malloc(size);
printf("%s:%d:%s:malloc(%ld): p=0x%lx\n",
file, line, func, size, (unsigned long)p);
return p;
}

#define malloc(s) debug_malloc(s, __FILE__, __LINE__, __func__)
#define free(p)  do {                                                   \
printf("%s:%d:%s:free(0x%lx)\n", __FILE__, __LINE__,            \
__func__, (unsigned long)p);                                \
free(p);                                                        \
} while (0)

int
main(int argc, char *argv[])
{
char *p;
p = malloc(1024);
free(p);
return 0;
}


延伸一下,如果想在不改动原来代码的情况下跳过这个错误,则可以将上述代码再重新改写一下:

#define malloc(s) debug_malloc(s, __FILE__, __LINE__, __func__)
#define free(p) do { \
printf("%s:%d:%s:free(0x%lx)\n", __FILE__, __LINE__, \
__func__, (unsigned long)p); \

if (p) { \
free(p); \

p = NULL; \

} \
} while (0)

转自:http://socol.iteye.com/blog/695872
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: