我有一个简单的 python 程序,我用它来测试带有子进程的 asyncio:
import sys, time
for x in range(100):
print("processing (%s/100) " % x)
sys.stdout.flush()
print("enjoy")
sys.stdout.flush()
在命令行上运行它会产生所需的结果。
但是,当从 asyncio 调用时,它永远不会完成
process = yield from asyncio.create_subprocess_exec(
*["python", "program.py"],
stdout=async_subprocess.PIPE,
stderr=async_subprocess.STDOUT,
cwd=working_dir
)
# this never finishes
yield from process.communicate()
ps ax
显示这个过程是<defunct>
,不知道这意味着什么