25

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

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

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

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

在 kcachegrindAll Callers选项卡中,我有以下列Incl. , Distance, Called, Caller

IIUC,Called并且caller是程序中调用“调用者”的次数。但我不知道其他人。

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

我在这里没有任何想法。

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

KCachegrind 解释混乱 对分析结果感到困惑

4

1 回答 1

28

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

“所有呼叫者”选项卡列应代表以下内容:

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

  • 距离:从“平面轮廓”面板中选择的函数中选择的函数调用分隔多少。

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

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

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

  • Ir:被该调用者调用后,所选函数总共执行的指令数。

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

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

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

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

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

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

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

于 2018-06-10T07:01:14.067 回答