【问题标题】:How to interpret results from kcachegrind如何解释 kcachegrind 的结果
【发布时间】:2014-07-10 06:29:43
【问题描述】:

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

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

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

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

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

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

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

我在这里没有任何想法。

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

KCachegrind interpretation confusion Confused about profiling result

【问题讨论】:

    标签: c++ profiling valgrind kcachegrind callgrind


    【解决方案1】:

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

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

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

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

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

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

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

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

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

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

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

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

    • 包括:此函数执行的总指令以及它在其下调用的所有函数。

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

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

    【讨论】:

    猜你喜欢
    • 2010-11-08
    • 1970-01-01
    • 2017-05-02
    • 2017-04-25
    • 1970-01-01
    • 1970-01-01
    • 2018-06-14
    • 2021-08-12
    • 2021-05-17
    相关资源
    最近更新 更多