如何查找linux热点代码,c++ linux perf:如何解释和查找热点

我试用了linux’

perf实用程序,今天有麻烦解释其结果。我习惯了valgrind的callgrind,这是一个完全不同的方法,基于抽样的perf方法。

我做了什么:

perf record -g -p $(pidof someapp)

perf report -g -n

现在我看到这样的东西:

+ 16.92% kdevelop libsqlite3.so.0.8.6 [.] 0x3fe57 ↑

+ 10.61% kdevelop libQtGui.so.4.7.3 [.] 0x81e344 ▮

+ 7.09% kdevelop libc-2.14.so [.] 0x85804 ▒

+ 4.96% kdevelop libQtGui.so.4.7.3 [.] 0x265b69 ▒

+ 3.50% kdevelop libQtCore.so.4.7.3 [.] 0x18608d ▒

+ 2.68% kdevelop libc-2.14.so [.] memcpy ▒

+ 1.15% kdevelop [kernel.kallsyms] [k] copy_user_generic_string ▒

+ 0.90% kdevelop libQtGui.so.4.7.3 [.] QTransform::translate(double, double) ▒

+ 0.88% kdevelop libc-2.14.so [.] __libc_malloc ▒

+ 0.85% kdevelop libc-2.14.so [.] memcpy

...

好的,这些功能可能很慢,但是如何找到他们从哪里被调用?由于所有这些热点都在外部库中,我看不到优化我的代码的方法。

基本上我正在寻找一种用累计成本注释的callgraph,其中我的函数具有比我调用的库函数更高的包含抽样成本。

这是可能与perf吗?如果是这样 – 怎么样?

注意:我发现“E”解开调用图并给出一些更多的信息。但是呼号图通常不够深,和/或随机终止,而不给出关于在哪里花费多少信息的信息。例:

- 10.26% kate libkatepartinterfaces.so.4.6.0 [.] Kate::TextLoader::readLine(int&...

Kate::TextLoader::readLine(int&, int&)

Kate::TextBuffer::load(QString const&, bool&, bool&)

KateBuffer::openFile(QString const&)

KateDocument::openFile()

0x7fe37a81121c

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值