请问有支持MingW32的好用免费性能分析器吗?

我在另一个线程中问如何分析我的程序,人们给了我很多很好的回答,但是我尝试使用几个免费的分析器时,包括例如AMD Codeanalyst,它们只支持Microsoft PDB格式,并且MingW无法生成这些格式。

那么有多线程Lua脚本和用MingW编译的应用程序,哪个分析器可以帮助我分析性能呢?

编辑:gprof很差,回答为什么我不想要它是正确的......如果我列出它列出的所有麻烦函数,它们都与我遇到的问题无关(有一个特定的操作会导致大幅度减慢,我无法弄清原因,gprof也无法弄清原因)。

原文链接 https://stackoverflow.com/questions/3597530

点赞
stackoverflow用户30225
stackoverflow用户30225

将下面翻译成中文并且保留原本的 markdown 格式

gprof不能完成这个任务吗?

我认为MingW提供了相应的gprof版本。

2010-08-30 03:08:55
stackoverflow用户398577
stackoverflow用户398577

如果您想对 Lua 脚本进行分析,我建议使用 LuaProfiler: http://luaprofiler.luaforge.net/manual.html。它工作得相当不错。

我强烈建议您实现一些计时器或自己的分析器来获取一个简单的分析工具。一个非常简单的工具是仅在代码中某些点被触发时输出时间,将这些时间输出到文本文件中,然后编写一个简单的 Lua 或 Python 脚本来解析该文件并过滤感兴趣的信息。

我在我的大多数兴趣项目中使用了这个(或稍微复杂一些的)版本的分析工具,它已经被证明非常有用。

2010-08-30 05:49:13
stackoverflow用户23771
stackoverflow用户23771

如果你不想使用 gprof,我不感到惊讶。

我花了一些时间才弄清楚如何在 GDB 下进行此操作,但这是我所做的。运行应用程序并将焦点切换到应用程序的输出窗口,即使它只是一个 DOS 窗口。然后我按下 Control-Break 键(当它变慢时)。然后 GDB 暂停,我使用 info threads 查看线程,通常是 1 和 2。我切换到我想要的线程,比如 thread 2。然后我使用 bt 查看堆栈跟踪。这告诉我当我按下 Control-Break 时程序正在做什么。我这样做了很多次,比如 10 或 20 次,如果有性能问题,无论是什么问题,都会在堆栈的多个样本中显示出来。它让程序变慢的程度越大,我就越不需要进行多次采样。

关于它如何以及为什么起作用的完整分析,请参见该链接。

附:我启动 GDB 时还会执行 handle SIGINT stop print nopass

2010-08-30 18:47:58