19

我有一些非常奇怪的行为,我只是不理解,因此无法解释,所以我希望这里有人可以帮助我。我注意到的第一件事是 ipdb 不再让我定义变量:

ipdb> what=5
ipdb> what
*** NameError: name 'what' is not defined
whatelse=6

过了一会儿,我发现 ipdb 在我的输入中返回了这个(再次运行代码之后):

dir()
ipdb> ['args', 'content_type', 'function', 'ipdb', 'item_code', 'kwargs', 'object_id', 'request', 'ud_dict', 'update_querydict', 'what', 'whatelse']
what=5
ipdb> what
5
ipdb> whatelse=7
ipdb> whatelse
ipdb> 6
whatelse
ipdb> 7
whatelse
ipdb> 6
whatelse
ipdb> 7

对我来说,这看起来就像我有两个交错的调试会话,我可以以某种奇怪的交替模式访问它们。我怎样才能摆脱它?

编辑: 杀死所有python进程并重新运行代码确实有帮助。现在一切都恢复正常了。但由于我只是不明白发生了什么,我会对所发生的事情的答案以及如何重现该行为非常感兴趣。

4

1 回答 1

10

如果您有两个进程都在消耗stdin,它们可能会导致与您所描述的非常相似的症状。

>>> import subprocess
>>> subprocess.Popen('python', shell=True)
<subprocess.Popen object at 0x0000000001DEFEB8>
>>> Python 2.6.5 (r265:79096, Mar 19 2010, 18:02:59) [MSC v.1500 64 bit (AMD64)] on win32
Type "help", "copyright", "credits" or "license" for more information.
>>>
>>> a = 5
>>> a
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
NameError: name 'a' is not defined
>>> a
5
>>> a = 6
>>> a
5
>>> a
6
>>> a
5
>>> a
6
>>> a
5
>>> a
6

我第一次调用a时,它是未定义的,即使我已经在上面的行中定义了它。我再次调用它,它是 5。然后我将它设置为 6,随后的每个调用都在两者之间交替。这似乎正是您正在经历的。

stdin是行缓冲,导致交替的文本行传递给交替的进程,在这种情况下是两个 Python 实例。

于 2014-01-29T01:11:34.613 回答