gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-30 05:23:11 25 4
gpt4 key购买 nike

背景

我们有嵌入式 GUI 产品的测试人员,当测试人员宣布“测试失败”时,有时我们开发人员很难重现确切的问题,因为我们没有发生的事情的确切痕迹。

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

问题

我们想要一个解决方案,其中编译器生成额外的检测代码,使我们能够看到事件的确切序列,包括最低限度:

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

日志看起来像这样:

int main() entered
if-line 5 entered
else-line 10 entered
void EventLoop() entered
. . .

一些额外的可有可无的东西是

  1. 函数入口导出的参数值(对于引用传递类型)
  2. 函数返回值

问题

是否有任何 gcc 工具甚至付费工具可以自动执行此检测?

最佳答案

您可以为此使用 gdb,也可以将其自动化(我正在开发一个工具,您可以找到它 here 或者您可以尝试使用 gcov。

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

关于c++ - gcc gprof/gcov/other - 如何获得函数调用/退出序列+控制流语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39296202/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com