gpt4 book ai didi

c++ - 如何解释 kcachegrind 的结果

转载 作者:IT老高 更新时间:2023-10-28 22:39:10 28 4
gpt4 key购买 nike

谁能告诉我如何对 kcachegrind 的结果感兴趣。

我有两个版本的代码(v1、v2)都在 Debug模式下编译。我通过带有选项的 valgrind 运行它们:

valgrind --tool=callgrind -v ....

由此生成的输出文件在 kcachegrind 中打开。现在我已经发现代码的 v2 版本比第一个版本 v1 运行得更快。但是我如何从 kcachegrind 的调用图中获取结果。

在 kcachegrind All Callers 选项卡中,我有以下列:Incl. , 距离, 被叫, 来电者.

IIUC、Calledcaller 是程序中调用“调用者”的次数。但我不知道其他人。

另一件事是选择特定功能,然后“调用者”选项卡显示了更多信息。 Ir, Ir per call, count, caller并在类型选项卡中:`EventType,Incl。 self ,简短,公式。

我在这里没有任何想法。

到目前为止,我已经阅读了这些问题:

KCachegrind interpretation confusion Confused about profiling result

最佳答案

我使用 QCacheGrind,所以如果我的屏幕上的某些内容与您看到的不完全相同,我深表歉意。据我了解,QCacheGrind 是 KCacheGrind 的直接 Qt 端口。此外,我可以在指令计数和总指令的百分比之间切换。为了保持一致性,我将引用任何可以以这种方式切换的列上的指令计数 View 。

“所有来电者”标签列应代表以下内容:

  • Incl.:这个函数作为一个整体生成的指令数,按每个调用者 segmentation 。因为调用者是一个层次结构(因此是距离列),如果你的调用堆栈很深,可能有几个具有相同的值。

  • 距离:分隔多少个函数调用是从平面配置文件面板中选择的函数中选择的行。

  • 被调用:调用者调用最终导致所选函数执行的函数的次数。

  • 调用者:直接调用或调用所选函数的另一个调用者的函数(由距离确定)。

“来电者”选项卡更加简单明了。它显示了与您选择的函数的距离为 1 的函数。换句话说,这些是直接调用您选择的函数的函数。

  • Ir:被选择的函数被这个调用者调用后总共执行的指令数。

  • Ir per call:每次调用执行的指令数。

  • 计数:调用者调用所选函数的次数。

  • 调用者:直接调用所选函数的函数。

有关事件,请参阅 this手册页。我怀疑如果您没有定义自己的类型,那么您应该看到的只是“指令获取”和可能的“周期估计”。这些列的快速 segmentation 如下:

  • Incl.:同样是这个函数执行的总指令以及它在它下面调用的所有函数。

  • Self:由该函数独占执行的指令。此计数器仅跟踪此函数使用的指令,而不跟踪此函数调用的函数使用的任何指令。

  • 短和公式:定义自定义事件类型时使用这些列。除非您最终定义了自己的类型,否则您的应该是空白或非常短的(如 CEst = Ir)。

关于c++ - 如何解释 kcachegrind 的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23786152/

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