23

考虑这个多线程程序:

import threading

class SomeThread(threading.Thread):
  def run(self):
    a = 1
    print a

def main():
  print 'hola'
  someThread = SomeThread()
  someThread.start()

if __name__ == '__main__':
  main()

当我用 pdb 调试这个程序时,在提示符处我首先在两个打印语句的每一个处设置一个断点。然后我继续。pdb 在print 'hola'. 我再次继续,在另一个线程中查看打印的效果,但 pdb 没有中断。

帮助命令没有列出任何切换线程上下文的内容,例如 gdb...所以...在一个线程上下文中设置断点是不可能的,该断点将在另一个上下文中跳闸?

4

2 回答 2

9

这对我有用:

import threading
import pdb

class SomeThread(threading.Thread):
  def run(self):
    a = 1
    print a
    pdb.set_trace()

def main():
  print 'hola'
  pdb.set_trace()
  someThread = SomeThread()
  someThread.start()

if __name__ == '__main__':
  main()

这给了我:

C:\Code>python b.py
hola
> c:\code\b.py(13)main()
-> someThread = SomeThread()
(Pdb) l
  8         pdb.set_trace()
  9
 10     def main():
 11       print 'hola'
 12       pdb.set_trace()
 13  ->   someThread = SomeThread()
 14       someThread.start()
 15
 16     if __name__ == '__main__':
 17       main()
[EOF]
(Pdb) c
1
--Return--
> c:\code\b.py(8)run()->None
-> pdb.set_trace()
(Pdb) l
  3
  4     class SomeThread(threading.Thread):
  5       def run(self):
  6         a = 1
  7         print a
  8  ->     pdb.set_trace()
  9
 10     def main():
 11       print 'hola'
 12       pdb.set_trace()
 13       someThread = SomeThread()
(Pdb)

这是在 Windows 7 和 Python 2.7.2 下。您使用的是什么操作系统和 Python 版本?

于 2012-10-11T00:24:23.767 回答
-3

在您到达第一个断点后,我假设您在到达此行时正在使用 (n) 下一行

someThread.start()

确保您使用的是 (s) step-into 而不是 (n) next。 pdb 命令

于 2012-10-11T01:20:29.397 回答