python线程wait_python – subprocess.wait()不等待Popen进程完成(使用线程时)?

当使用subprocess.Popen()从我的

python脚本中生成同一应用程序的几个实例时,我遇到一些问题,使用线程让它们同时运行.在每个线程中,我使用popen()调用运行应用程序,然后等待它通过调用wait()来完成.问题似乎是wait() – 调用实际上并不等待进程完成.我仅使用一个线程进行实验,并在进程开始时打印文本消息,以及完成时.所以线程函数看起来像这样:

def worker():

while True:

job = q.get() # q is a global Queue of jobs

print('Starting process %d' % job['id'])

proc = subprocess.Popen(job['cmd'], shell=True)

proc.wait()

print('Finished process %d' % job['id'])

job.task_done()

但即使我只使用一个线程,它会打印出几个“启动进程…”消息,然后任何“完成进程…”消息出现.有没有wait()实际上不等待的情况?我有几个不同的外部应用程序(C控制台应用程序),反过来将有几个实例同时运行,其中一些我的代码工作,但对于其他的它不会.外部应用程序可能会有某些问题影响到wait()的调用?

用于创建线程的代码如下所示:

for i in range(1):

t = Thread(target=worker)

t.daemon = True

t.start()

q.join() # Wait for the queue to empty

更新1:

我还应该补充说,对于某些外部应用程序,我有时会得到一个-1073471801的返回码(proc.returncode).例如,其中一个外部应用程序会给Popen被调用的前两次的返回码,而不是最后两个(当我有四个作业时).

更新2:

为了清理起来,现在我在队列中有四个工作,这四个不同的测试用例.当我运行代码时,对于其中一个外部应用程序,前两个Popen调用生成返回代码-1073471801.但是,如果我打印了Popen调用的确切命令,并在命令窗口中运行它,它将执行没有任何问题.

解决了!

我设法解决了我遇到的问题.我认为问题是我缺乏线程编程经验.我错过了一个事实,当我创建了我的第一个工作线程,他们将继续生活,直到python脚本退出.我错误地创建了更多的工作线程,每次我把新的项目放在队列(我为每个外部程序我想运行批量进行).所以当我得到第四个外部应用程序时,我有四个线程同时运行,尽管我只是以为我有一个.

你可能感兴趣的:(python线程wait)