
Perf 是 Linux 下最强大的性能分析工具之一,能直接对接内核事件,精准定位 C++ 程序的 CPU 热点、函数调用开销、缓存失效、分支预测失败等底层瓶颈。关键不是“跑 perf record”,而是选对事件、过滤干扰、结合符号信息读懂输出。
快速定位 CPU 瓶颈函数(最常用场景)
先确认程序已编译带调试符号(-g),且未过度优化(-O2 可接受,避免 -O3 内联过度导致函数名丢失)。运行:
perf record -g -p $(pidof your_program) sleep 10或对单次运行采样:
perf record -g ./your_program arg1 arg2然后生成火焰图或直接查看调用栈:
立即学习“C++免费学习笔记(深入)”;
perf report -g --no-children重点关注 Self 列占比高的函数——这是该函数自身耗时(不含子调用),通常就是瓶颈源头。若某函数 Self 很低但 Children 很高,说明它只是“中转站”,真正耗时在它调用的下层函数里。
识别缓存与内存访问问题
C++ 性能常卡在 L1/L2 缓存未命中或内存带宽上。用以下命令捕获关键硬件事件:
标签: linux svg 工具 栈 c++ 热点 性能瓶颈
还木有评论哦,快来抢沙发吧~