2011-11-28 83 views
0

我试图剖析我的多线程应用程序的性能。添加grpof -pg选项使我的多线程应用程序非多线程

所以我编译时加了“-pg”选项。

我在线程池中使用了固定数量的线程:如果有4个CPU内核,将会有12 + 1 = 13个线程在运行。

我感到非常意外的是,在添加“-pg”选项后,只有一个线程正在运行,其他线程根本没有运行(状态“S”在top命令中)。

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

感谢。

彼得

+0

顺便说一句,我尝试使用gprof-helper(http://sam.zoy.org/writings/programming/gprof.html),仍然同样的行为,没有运气。 –

+0

可能会尝试oprofile – phs

回答

0

我安装并试用了OProfile的,它的作品没关系,它也可以给你gprof的风格效果。

opgprof ./bin/MyProgramBinary # Generate the gmon.out file 
gprof -p ./bin/MyProgramBinary > gmon.txt