valgrind试用手记

作者:帅得不敢出门    C++哈哈堂群31843264  转载请保留此信息

valgrind
Valgrind is an instrumentation framework for building dynamic analysis tools. There are Valgrind tools that can automatically detect many memory management and
threading bugs, and profile your programs in detail. You can also use Valgrind to build new tools.
下载:
svn co svn://svn.valgrind.org/valgrind/trunk valgrind
安装:
cd valgrind
  ./autogen.sh
  ./configure --prefix=...
  make
  sudo make install
使用方法:要检测的程序必须加-g选项,推荐使用-O0,不优化
内存检测:
如果你运行程序时命令是这样的:
  myprog arg1 arg2
检测时改成这样:
  valgrind --leak-check=yes myprog arg1 arg2 ,默认是memcheck
  valgrind --tool=cachegrind myprog arg1 arg2 ,这个调用的则是cachegrind,输出结果在当前目录下的cachegrind.out.<pid> pid为程序的pid
Valgrind工具包包含多个工具,如Memcheck,Cachegrind,Helgrind, Callgrind,Massif,你可以用上面的--tool=来指定,指定时没有大写

exp-ptrcheck, a heap, stack and global array overrun detector
valgrind --tool=exp-ptrcheck --log-file=val.log ./fbv -g /windows/F/photos/102_4085.JPG
输出如下:
==17627== exp-ptrcheck, a heap, stack and global array overrun detector
==17627== NOTE: This is an Experimental-Class Valgrind Tool
==17627== Copyright (C) 2003-2010, and GNU GPL'd, by OpenWorks Ltd et al.
==17627== Using Valgrind-3.7.0.SVN and LibVEX; rerun with -h for copyright info
==17627== Command: ./fbv -g /windows/F/photos/102_4085.JPG
==17627== Parent PID: 2448
==17627==
==17627==
==17627== For counts of detected and suppressed errors, rerun with: -v
==17627== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 0 from 0)

valgrind --tool=callgrind  ./fbv -g /windows/F/photos/102_4085.JPG  同时另一个命令行下运行:
callgrind_control -b
输出如下:
PID 17678: ./fbv -g /windows/F/photos/102_4085.JPG [requesting 'Status'...]

  Frame: Backtrace for Thread 1
   [ 0]  rotate (1 x)
   [ 1]  show_image (1 x)
   [ 2]  main (1 x)
   [ 3]  (below main) (1 x)
   [ 4]  0x080495a0 (1 x)
   [ 5]  0x00000850
程序结束后,产生文件callgrind.out.<pid>
callgrind_annotate [options] callgrind.out.<pid> 产生较精简的函数summary

Massif is a heap profiler. It measures how much heap memory your program uses. This includes both the useful space,
 and the extra bytes allocated for book-keeping and alignment purposes. It can also measure the size of your
 program's stack(s), although it does not do so by default.

valgrind --tool=massif ./fbv -g /windows/F/photos/102_4085.JPG 生成堆使用情况的log
ms_print massif.out.19747 对log做些处理产生可易理解的信息
--------------------------------------------------------------------------------
  n        time(i)         total(B)   useful-heap(B) extra-heap(B)    stacks(B)
--------------------------------------------------------------------------------
 46    444,727,063       12,190,488       12,190,464            24            0
 47    444,727,955       12,715,808       12,715,776            32            0
 48    446,465,375       12,190,488       12,190,464            24            0
 49    446,466,273       15,336,224       15,336,192            32            0
 50    456,720,045       15,336,224       15,336,192            32            0
100.00% (15,336,192B) (heap allocation functions) malloc/new/new[], --alloc-fns, etc.
->61.54% (9,437,184B) 0x8049820: show_image (in /home/zengming/workspace/fbv/fbv)
| ->61.54% (9,437,184B) 0x804A87D: main (in /home/zengming/workspace/fbv/fbv)
............

DHAT is a tool for examining how programs use their heap allocations.
valgrind --tool=exp-dhat ./fbv -g /windows/F/photos/102_4085.JPG
==19813==
==19813== ======== SUMMARY STATISTICS ========
==19813==
==19813== guest_insns:  456,751,347
==19813==
==19813== max_live:     15,336,192 in 4 blocks
==19813==
==19813== tot_alloc:    16,539,148 in 25 blocks
==19813==
==19813== insns per allocated byte: 27
==19813==
==19813==
==19813== ======== ORDERED BY decreasing "max-bytes-live": top 10 allocators ========
==19813==
==19813== -------------------- 1 of 10 --------------------
==19813== max-live:    9,437,184 in 1 blocks
==19813== tot-alloc:   9,437,184 in 1 blocks (avg size 9437184.00)
==19813== deaths:      1, at avg age 456,008,575 (99.83% of prog lifetime)
==19813== acc-ratios:  0.25 rd, 1.00 wr  (2,359,296 b-read, 9,437,184 b-written)
==19813==    at 0x4026BB4: malloc (vg_replace_malloc.c:236)
==19813==    by 0x8049821: show_image (in /home/zengming/workspace/fbv/fbv)
==19813==    by 0x804A87E: main (in /home/zengming/workspace/fbv/fbv)
...............
英文说明:http://www.valgrind.org/docs/manual/manual.html

你可能感兴趣的:(image,SVN,command,alignment,statistics,Allocation)