我的程序已挂起,我决定ltrace
和strace
。
strace -p pid
给了我一个"无限的"在屏幕上打印:
lseek(3, 57114624, SEEK_SET) = 57114624
read(3, "\r\r\207\0\n\6O\0\16b\f\277\v\370\v1\ni\tm\10\245\7\335\7\25\6O\5v\5v"..., 4096) = 4096
lseek(3, 57118720, SEEK_SET) = 57118720
read(3, "\r\1(\0\21\0`\0\0174\16l\r\246\f\336\f\26\vO\n\207\t\277\10\371\6\233\5\323\5\v"..., 4096) = 4096
...
ltrace -p pid
给予同样的"无限的"印刷:
memcmp(0x12efab68, 0x12eface8, 15, 0x12eface8) = 0xfffffff8
memset(0x12fa48e0, '\0', 72) = 0x12fa48e0
memset(0x12fa4928, '\0', 144) = 0x12fa4928
lseek64(3, 0x2c30000, 0, 0x2c30000) = 0x2c30000
memcpy(0x12efab68, "DIRAC.HLTFarm.lhcb", 18) = 0x12efab68
memcmp(0x12efab68, 0x12eface8, 15, 0x12eface8) = 0xfffffff8
memcpy(0x12efab68, "DIRAC.HLTFarm.lhcb", 18^C) = 0x12efab68
基于这些结果,我可以对程序的进展做出什么结论?
答案 0 :(得分:1)
附加调试器(带gdb -p pid
)并获取回溯(使用bt
命令)。这将更详细地告诉您程序正在旋转的位置。您可能必须安装调试信息才能获得有用的回溯。