MEMWATCH 调试动态库2

原创 2016年08月31日 12:05:34

下面是一个memwatch使用的例子:

1.

root@ubuntu:~/wanghuan/memwatch# cat test.c

#include
#include
#include "memwatch.h"
int main(void)
{
  char *ptr1;
  char *ptr2;
  ptr1 = malloc(512);
  ptr2 = malloc(512);
  ptr2 = ptr1;
  free(ptr2);
  free(ptr1);
}
2.

root@ubuntu:~/wanghuan/memwatch# cat Makefile
test:
 gcc -DMEMWATCH -DMEMWATCH_STDIO test.c memwatch.c -o test

3.

make 之后执行 ./test

root@ubuntu:~/wanghuan/memwatch# ./test
MEMWATCH detected 2 anomalies

查看 log内容:

4.

root@ubuntu:~/wanghuan/memwatch# cat memwatch.log

============= MEMWATCH 2.71 Copyright (C) 1992-1999 Johan Lindh =============

Started at Thu Feb 24 10:13:41 2011

Modes: __STDC__ 64-bit mwDWORD==(unsigned long)
mwROUNDALLOC==8 sizeof(mwData)==32 mwDataSize==32

double-free: <4> test.c(23), 0x8e444c8 was freed from test.c(22)

Stopped at Thu Feb 24 10:13:41 2011

unfreed: <2> test.c(20), 512 bytes at 0x8e44700   {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: 2
 L)argest memory usage      : 1024
 T)otal of all alloc() calls: 1024
 U)nfreed bytes totals      : 512

可以看出:

double-free: <4> test.c(23), 0x8e444c8 was freed from test.c(22):test.c的第23行内存双重释放。该内存在22行已被释放过。

unfreed: <2> test.c(20), 512 bytes at 0x8e44700  : test.c的第20行分配的内存没被释放。

最后是一个统计结果:

动态分配了两次内存。一共分配了1024,未释放512.

<script>window._bd_share_config={"common":{"bdSnsKey":{},"bdText":"","bdMini":"2","bdMiniList":false,"bdPic":"","bdStyle":"0","bdSize":"16"},"share":{}};with(document)0[(getElementsByTagName('head')[0]||body).appendChild(createElement('script')).src='http://bdimg.share.baidu.com/static/api/js/share.js?v=89860593.js?cdnversion='+~(-new Date()/36e5)];</script>
阅读(248) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~
评论热议
版权声明:本文为博主原创文章,转载请注明出处。

MEMWATCH 调试动态库1

MEMWATCH 由 Johan Lindh 编写,是一个开放源代码 C 语言内存错误检测工具,您可以自己下载它(请参阅本文后面部分的参考资料)。只要在代码中添加一个头文件并在 gcc 语句中定义了 ...
  • chituhuan
  • chituhuan
  • 2016年08月31日 12:05
  • 301

MEMWATCH 调试动态库3

MEMWATCH 调试动态库3 (2011-02-24 10:33:08)[编辑][删除]标签: 调试 内存错误 memwatch 调试动态库 it分类: linux    下边是一个调试动态库的例子...
  • chituhuan
  • chituhuan
  • 2016年08月31日 12:05
  • 237

dmalloc的使用

dmalloc到/usr/local/bin/目录下。  (6) 设置环境变量: 对于 Bash, ksh, and zsh (http://www.zsh.org/), 在 `.bashrc',...
  • bamboolsu
  • bamboolsu
  • 2015年01月22日 12:26
  • 1031

vs调试动态库的方法(图解)

首先 ,dll 是以MFC的方式生成的,并且为了在调试dll时方便,我把dll和测试程序(一个控制台类型,一个MFC类型)都建在了一个工程下,这样可以在修改dll时通过下面的步骤设置生成dll的输出目...
  • sbfksmq
  • sbfksmq
  • 2016年06月17日 18:43
  • 3439

Qt动态库调试方法2

之前写过一个Qt动态库调试方法的博客, 那种方法应用的场景是,在没有调用动态库的主程序的代码的情况下对与动态库进行调试。 但也存在许多问题,比如不能准确的确定程序崩溃的地方。 今天讲的方...
  • u012199908
  • u012199908
  • 2016年02月23日 14:30
  • 1039

VS2010动态库调试方法

打开调用动态库的程序,之后在“解决方案资源管理器”中,选中“解决方案’XXX’”,之后在右键菜单中选择“添加->现有项目”,之后在“添加现有项目”对话框中选择动态库程序的vcxproj文件,如图1所示...
  • hou09tian
  • hou09tian
  • 2017年05月27日 06:12
  • 1248

VS2010如何调试动态库

项目A是dll动态库项目。项目B是调用dll动态库的exe项目。怎么调试dll动态库里的程序呢? B生成解决方案之后,选择只运行,不调试(不能调试,因为要在dll项目中调试)。 然后在A项目的调试...
  • u012702039
  • u012702039
  • 2014年12月23日 13:48
  • 2101

linux下动态链接库使用与单步调试

//动态库调试时,可以在库函数中设置断点,使用n代表不进入库函数单步调试,使用s代//表进入库函数单步调试   //注意:可以使用ldd libtest.so查看动态库的依赖情况 //在默认情况下,运...
  • qq_34680315
  • qq_34680315
  • 2016年04月16日 11:34
  • 453

VS之动态库调试

程序开发中,经常会使用到动态库,动态库不能直接运行,需要依赖其他程序调用,那么我们该如何调试我们的动态库呢?本文通过一个简单的例子说明。...
  • bingdianlanxin
  • bingdianlanxin
  • 2015年01月02日 15:48
  • 2707

linux gdb调试动态库(so)的方法

原文地址: http://www.gonwan.com/?tag=gdb 在本例中使用了libcurl.so.4库 step1: 编译libcurl.so.4的可调试版本: # su...
  • u012684933
  • u012684933
  • 2015年03月04日 15:48
  • 7754
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:MEMWATCH 调试动态库2
举报原因:
原因补充:

(最多只允许输入30个字)