to myself 的分类学习日志

做自己想做的事
posts - 232, comments - 6, trackbacks - 0, articles - 0

内存越界和泄露调试工具

Posted on 2009-03-04 11:13 kongkongzi 阅读(325) 评论(0)  编辑 收藏 引用 所属分类: tools

1,valgrind的官方网址是:http://valgrind.org 。你可以在它的网站上下载到最新的valgrind,它是开放源码和免费的。
valgrind包含几个标准的工具,它们是: 1、memcheck 2、cachegrind 3、helgrind
Valgrind用法(memory leak check)
valgrind [valgrind-option] program [program-args]
它的参数中可以用--tool=toolname指定使用什么工具如:
valgrind -tool=memcheck,如不指定,默认使用memcheck.
检查内存错误要在上面的输出中看两个关键字
ERROR SUMMARY 和 LEAK SUMMARY
valgrind –tool=memcheck –leak-check=yes [command] [para]
常用的options:
-v     更详细的信息, 增加错误数统计。
--leak-check=no|summary|full 要求对leak给出详细信息?
--log-file= 将输出的信息写入到filename.PID的文件里,PID是运行程序的进行ID
--tool= 运行 valgrind中名为toolname的工具。默认memcheck。

Valgrind 使用
用法: valgrind [options] prog-and-args [options]: 常用选项,适用于所有Valgrind工具

   1.-tool= 最常用的选项。运行 valgrind中名为toolname的工具。默认memcheck。
   2.h –help 显示帮助信息。
   3.-version 显示valgrind内核的版本,每个工具都有各自的版本。
   4.q –quiet 安静地运行,只打印错误信息。
   5.v –verbose 更详细的信息, 增加错误数统计。
   6. -trace-children=no|yes 跟踪子线程? [no]
   7. -track-fds=no|yes 跟踪打开的文件描述?[no]
   8.-time-stamp=no|yes 增加时间戳到LOG信息? [no]
   9.-log-fd= 输出LOG到描述符文件 [2=stderr]
  10.-log-file= 将输出的信息写入到filename.PID的文件里,PID是运行程序的进行ID
  11.-log-file-exactly= 输出LOG信息到 file
  12.-log-file-qualifier= 取得环境变量的值来做为输出信息的文件名。 [none]
  13.-log-socket=ipaddr:port 输出LOG到socket ,ipaddr:port

LOG信息输出

   1.-xml=yes 将信息以xml格式输出,只有memcheck可用
   2.-num-callers= show  callers in stack traces [12]
   3.-error-limit=no|yes 如果太多错误,则停止显示新错误? [yes]
   4. -error-exitcode= 如果发现错误则返回错误代码 [0=disable]
   5.-db-attach=no|yes 当出现错误,valgrind会自动启动调试器gdb。[no]
   6.-db-command= 启动调试器的命令行选项[gdb -nw %f %p]

适用于Memcheck工具的相关选项:

   1.-leak-check=no|summary|full 要求对leak给出详细信息? [summary]
   2.-leak-resolution=low|med|high how much bt merging in leak check [low]
   3.-show-reachable=no|yes show reachable blocks in leak check? [no]

valgrind –-tool=memcheck --trace-children=yes --log-file=./leak.out --error-limit=no --leak-check=full ./test
valgrind --leak-check=full --show-reachable=yes --trace-children=yes  ./test
在杀掉进程(Ctrl+C等)之后,结果才能出来。


valgrind --leak-check=full --show-reachable=yes --trace-children=yes --xml=yes --log-file="log.xml" ./a.out


jiffer blog: http://blog.sina.com.cn/linux114