Linux内存调试工具初探-MEMWATCH
2015-12-02 23:18
507 查看
C 语言作为 Linux 系统上标准的编程语言给予了我们对动态内存分配很大的控制权。这种自由可能会导致严重的内存管理问题,可能导致程序崩溃或随时间的推移导致性能降级。
内存泄漏(即
1. Memwatch简介
Memwatch是C语言的内存检测器。除了检测内存的功能外,它同样可以做其它的一些事情,而我们主要还是在于讲述它的基本功能。如果你真的想要知道所有相关的具体细节,可详细查看头文件memwatch.h以及源代码。
它使用C于处理器的功能,Memwatch使用它自己定义的功能函数取代所有在你的程序中用ANSI C定义的内存分配函数,Memwatch的内存分配函数包含了了所有的分配记录信息。
Memwatch可以在交叉编译后的目标板上运行。
2. Memwatch功能
(1) 主要有基本的内存管理函数
-mwMalloc()
-mwFree()
-mwCalloc()
-mwRealloc()
(2) MemWatch能够检测的功能包括
-双重释放(double-free)、
-错误释放(erroneous free)、
-内存泄漏(unfreed memory)、
-溢出(Overflow)、
-下溢(Underflow)
3. 编译
当编译时, 相让memwatch起作用, 编译是加上-DMEMWATCH
4. memwatch.log内容
在正常操作的情况下,memwatch会创建一个名叫memwatch.log的文件。但有的时候,memwatch.log文件并不能被创建。此时,memwatch会尝试创建命名类似memwatNN.log的文件,其中NN是01到99之间的数字。如果还是失败,则没有log文件。
5. 应用实例
清单 1. 内存样本(test1.c)
清单 1 中的代码将分配两个 512 字节的内存块,然后指向第一个内存块的指针被设定为指向第二个内存块。结果,第二个内存块的地址丢失,从而产生了内存泄漏。
现在我们编译清单 1 的 memwatch.c。下面是一个 makefile 示例:
test1
当您运行 test1 程序后,它会生成一个关于泄漏的内存的报告。清单 2 展示了示例 memwatch.log 输出文件。
清单 2. test1 memwatch.log 文件
MEMWATCH 为您显示真正导致问题的行。如果您释放一个已经释放过的指针,它会告诉您。对于没有释放的内存也一样。日志结尾部分显示统计信息,包括泄漏了多少内存,使用了多少内存,以及总共分配了多少内存。
内存泄漏(即
malloc()内存在对应的
free()调用执行后永不被释放)和缓冲区溢出(例如对以前分配到某数组的内存进行写操作)是一些常见的问题,它们可能很难检测到。这一部分将讨论几个调试工具,它们极大地简化了检测和找出内存问题的过程
1. Memwatch简介
Memwatch是C语言的内存检测器。除了检测内存的功能外,它同样可以做其它的一些事情,而我们主要还是在于讲述它的基本功能。如果你真的想要知道所有相关的具体细节,可详细查看头文件memwatch.h以及源代码。
它使用C于处理器的功能,Memwatch使用它自己定义的功能函数取代所有在你的程序中用ANSI C定义的内存分配函数,Memwatch的内存分配函数包含了了所有的分配记录信息。
Memwatch可以在交叉编译后的目标板上运行。
2. Memwatch功能
(1) 主要有基本的内存管理函数
-mwMalloc()
-mwFree()
-mwCalloc()
-mwRealloc()
(2) MemWatch能够检测的功能包括
-双重释放(double-free)、
-错误释放(erroneous free)、
-内存泄漏(unfreed memory)、
-溢出(Overflow)、
-下溢(Underflow)
3. 编译
当编译时, 相让memwatch起作用, 编译是加上-DMEMWATCH
4. memwatch.log内容
在正常操作的情况下,memwatch会创建一个名叫memwatch.log的文件。但有的时候,memwatch.log文件并不能被创建。此时,memwatch会尝试创建命名类似memwatNN.log的文件,其中NN是01到99之间的数字。如果还是失败,则没有log文件。
5. 应用实例
清单 1. 内存样本(test1.c)
#include <stdlib.h> #include <stdio.h> #include "memwatch.h" int main(void) { char *ptr1; char *ptr2; ptr1 = malloc(512); ptr2 = malloc(512); ptr2 = ptr1; free(ptr2); free(ptr1); } |
现在我们编译清单 1 的 memwatch.c。下面是一个 makefile 示例:
test1
gcc -DMEMWATCH -DMW_STDIO test1.c memwatch c -o test1 |
清单 2. test1 memwatch.log 文件
MEMWATCH 2.67 Copyright (C) 1992-1999 Johan Lindh ... double-free: <4> test1.c(15), 0x80517b4 was freed from test1.c(14) ... unfreed: <2> test1.c(11), 512 bytes at 0x80519e4 {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 |
相关文章推荐
- linux下后台执行程序的方法
- CentOS 7 NFS服务器和客户端设置
- CentOS Linux解决Device eth0 does not seem to be present
- Linux环境下段错误的产生原因及调试方法小结
- linux samba配置
- linux串口驱动分析
- Linux 汇编语言(GNU GAS汇编)开发指南
- memcpy, memccpy函数实现——string.h库函数
- Linux学习笔记(三)
- Linux内核Socket CAN中文文档
- 在linux的SQL*Plus下用上下键翻历史命令
- Linux学习笔记(一、ls命令及文件属性)
- 菜鸟学Linux命令:lsof命令 查找指定用户、进程、端口打开的文件
- linux下安装lnmp环境
- linux中export和source的作用和区别
- linux增加vlan网卡配置
- Linux下C++的编程——开偏介绍
- arm-linux内核启动学习笔记(一)
- 第二天 Linux常见命令
- Linux简单命令之一