首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >gcc gprof/gcov/other -如何获得函数调用/退出的顺序+控制流语句

gcc gprof/gcov/other -如何获得函数调用/退出的顺序+控制流语句
EN

Stack Overflow用户
提问于 2016-09-02 15:41:08
回答 1查看 479关注 0票数 1

背景

我们有嵌入式GUI产品的测试人员,当测试人员声明“测试失败”时,有时我们开发人员很难重现确切的问题,因为我们没有所发生的事情的准确跟踪。

我们目前确实有一个日志框架,但是我们的开发人员必须在代码中手动输入这些日志语句,这很好。。。除非发生了难以重现的错误,而且我们在‘正确’位置没有一个日志语句,然后当我们重新构建时,用相同的步骤重新运行测试,我们得到了不同的结果。

问题

我们希望有一个解决方案,其中编译器产生额外的插装代码,允许我们查看事件的确切序列,至少包括

  1. 函数输入/退出(已由-finstrument-functions提供)
  2. 输入control-flow语句,即输入if/ enter,我们跳到哪个case语句

日志将如下所示:

代码语言:javascript
复制
int main() entered
if-line 5 entered
else-line 10 entered
void EventLoop() entered
. . .

另外一些富有的人是

  1. 函数条目出口上的参数值(用于按引用类型传递)
  2. 函数返回值

问题

是否有任何gcc工具甚至付费工具可以自动完成此测试?

EN

回答 1

Stack Overflow用户

发布于 2016-09-02 16:28:12

您可以为此使用gdb,并且可以将其自动化(我已经为其提供了一个工具,您可以找到它这里,也可以尝试使用gcov。

gcov实现是这样的,它在启动程序时加载最新的gcov数据。但是:您可以手动转储和加载数据。如果调用__gcov_flush,它将转储当前数据并重置当前状态。但是:如果您多次这样做,它总是会合并数据,因此您还需要重新命名gcov数据文件。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39296202

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档