添加 grpof -pg 选项使我的多线程应用程序非多线程
Posted
技术标签:
【中文标题】添加 grpof -pg 选项使我的多线程应用程序非多线程【英文标题】:Adding grpof -pg Options Makes My Multithreaded Application Non-multithreaded 【发布时间】:2011-11-28 19:18:02 【问题描述】:我正在尝试分析我的多线程应用程序的性能。
所以我在编译时添加了“-pg”选项。
我在线程池中使用固定数量的线程:如果有 4 个 CPU 核心,将有 12+1 = 13 个线程在运行。
让我大吃一惊的是,在我添加“-pg”选项后,只有一个线程在运行,而其他线程根本没有运行(top
命令中的状态“S”)。
top - 12:16:03 up 2 days, 21:46, 4 users, load average: 1.02, 1.07, 1.32
Tasks: 13 total, 1 running, 12 sleeping, 0 stopped, 0 zombie
Cpu(s): 0.6%us, 25.6%sy, 0.0%ni, 73.7%id, 0.0%wa, 0.0%hi, 0.1%si, 0.0%st
Mem: 9224140k total, 5070060k used, 4154080k free, 214480k buffers
Swap: 9431164k total, 0k used, 9431164k free, 1722216k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
3252 plee 20 0 3111m 2.3g 3292 S 0 26.0 0:03.32 MyMultithreaded
3251 plee 20 0 3111m 2.3g 3292 R 99 26.0 12:02.83 MyMultithreaded
3250 plee 20 0 3111m 2.3g 3292 S 0 26.0 0:03.01 MyMultithreaded
3249 plee 20 0 3111m 2.3g 3292 S 0 26.0 0:02.88 MyMultithreaded
3248 plee 20 0 3111m 2.3g 3292 S 0 26.0 0:03.12 MyMultithreaded
3247 plee 20 0 3111m 2.3g 3292 S 0 26.0 0:03.14 MyMultithreaded
3246 plee 20 0 3111m 2.3g 3292 S 0 26.0 0:03.46 MyMultithreaded
3245 plee 20 0 3111m 2.3g 3292 S 0 26.0 0:03.32 MyMultithreaded
3244 plee 20 0 3111m 2.3g 3292 S 0 26.0 0:03.16 MyMultithreaded
3243 plee 20 0 3111m 2.3g 3292 S 0 26.0 0:03.27 MyMultithreaded
3242 plee 20 0 3111m 2.3g 3292 S 0 26.0 0:03.12 MyMultithreaded
3241 plee 20 0 3111m 2.3g 3292 S 0 26.0 0:02.87 MyMultithreaded
3240 plee 20 0 3111m 2.3g 3292 S 0 26.0 0:03.23 MyMultithreaded
那么有什么解决办法吗?
这有什么关系: http://sam.zoy.org/writings/programming/gprof.html
谢谢。
彼得
【问题讨论】:
顺便说一句,我尝试使用 gprof-helper (sam.zoy.org/writings/programming/gprof.html),仍然是相同的行为,没有运气。 【参考方案1】:我安装并试用了 OProfile,它运行良好,它还可以为您提供 gprof 风格的结果。
opgprof ./bin/MyProgramBinary # Generate the gmon.out file
gprof -p ./bin/MyProgramBinary > gmon.txt
【讨论】:
以上是关于添加 grpof -pg 选项使我的多线程应用程序非多线程的主要内容,如果未能解决你的问题,请参考以下文章