profiling - 自动化 gdb : show backtrace every 10 ms

标签 profiling gdb backtrace

我想为 gdb 编写一个脚本,它将每 10 毫秒保存一次进程的 backtrace(堆栈)。我该怎么做?

它可以类似于“身无分文”的调用图分析(对于那些不能使用任何高级分析器的人)。

是的,有很多高级分析器。适用于流行的 CPU 和流行的操作系统。 Shark 非常令人印象深刻且易于使用,但我想通过使用 gdb 获得此类脚本的基本功能。

最佳答案

你能得到lsstack吗?也许您可以从应用程序外部的脚本运行它。为什么是 10 毫秒?百分比将在 100 毫秒或更长时间时大致相同。如果应用程序太快,您可以使用外循环人为地减慢它的速度,这也不会改变百分比。就此而言,如果应用程序运行时间足够长并且您的目标是找出性能问题所在,您可以只使用 Ctrl-C 在 gdb 下手动获取示例。

关于profiling - 自动化 gdb : show backtrace every 10 ms,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2512482/

相关文章:

java - 什么是烫发空间?

linux - 哪个工具或命令可以提供非常准确的 Linux 内存使用状态?

gcc - GCC功能后缀“isra”是什么意思?

d - 如何在 D 回溯中显示行号?

c - 在 C 中分析运行时

debugging - 没有工作台的 VxWorks 调试

gdb - 找到变量 Buf 的确切地址

gdbserver 跟踪点臂支持

java - 未知的崩溃报告安卓

linux - 不依赖于特定于操作系统的核心转储的崩溃进程的回溯