Chinaunix首页 | 论坛 | 博客
  • 博客访问: 4008148
  • 博文数量: 536
  • 博客积分: 10470
  • 博客等级: 上将
  • 技术积分: 4825
  • 用 户 组: 普通用户
  • 注册时间: 2006-05-26 14:08
文章分类

全部博文(536)

文章存档

2024年(3)

2021年(1)

2019年(1)

2017年(1)

2016年(2)

2013年(2)

2012年(10)

2011年(43)

2010年(10)

2009年(17)

2008年(121)

2007年(252)

2006年(73)

分类: C/C++

2011-05-23 13:52:01

gcov:
通过gcov+GCC,我们可以计算每行代码的运行次数,并标记出没有被执行的代码。

使用gcov时,需要打开GCC的fprofile-arcs和ftest-coverage两个选项。它们会在编译时加入一些 gcov所需的附加信息。其中,gcov中常用的选项有-b分支统计信息。与gcov类似的商业软件还有Bullseye Coverage和CTC++ Test Coverage Analyser等。

示例:我们有一个源程序temp.cpp
1)打开gcc相应编译选项,编译该文件
    g++ -g temp.cpp -o hello -fprofile-arcs -ftest-coverage
   它将生成一个.gcno文件
2)运行生成的可执行文件
    ./hello
   它将生成一个.gcda文件
3)运行gcov
    gcov temp.cpp
   它将生成我们所需的.cpp.gcov报告文件。

[相关资料]

gcov: a Test Coverage Progra

http://www.kimbly.com/blog/000331.html
Code Coverage for C++
----------------------------------------------------------------------------------------------------------------
gprof
通过gprof,我们可以看出函数之间的调用关系及执行的时间。
使用gprof时,需要打开GCC的pg选项。

示例:
1)打开gcc相应编译选项,编译该文件
    g++ -g temp.cpp -o hello -pg
2)运行生成的可执行文件
    ./hello
   它将生成一个gmon.out文件
3)运行gprof
    gprof -b ./hello
   它将显示运行的报告信息

[相关资料]

GNU gprof

gprof: gmon.out file is missing call-graph data
阅读(2172) | 评论(0) | 转发(1) |
给主人留下些什么吧!~~