from multiprocessing import Process
def text(): print("--子进程--")
p = Process(target=text) p.start() p.join() print("--主进程--")
在 Ubuntu 中执行没有问题 在 win7 下,pycharm 中运行 报错如下: Traceback (most recent call last): File "<string>", line 1, in <module> File "C:\anaconda\envs\py36\lib\multiprocessing\spawn.py", line 105, in spawn_main exitcode = _main(fd) File "C:\anaconda\envs\py36\lib\multiprocessing\spawn.py", line 113, in _main preparation_data = reduction.pickle.load(from_parent) _pickle.UnpicklingError: invalid load key, '\x00'.
请大家指点我一下,这个问题搜了好久没找到。
1
tukey OP 编辑的时候排版好的,发布就乱了,sorry.
|
2
fslong 2018-03-31 17:16:17 +08:00
刚好我昨天才学到这里,由于 Windows 没有 fork 调用,在 Linux 上能用的多进程代码,在 Windows 上会报错。Windows 上可以使用 multiprocessing,详见: https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/0014319272686365ec7ceaeca33428c914edf8f70cca383000
|
3
tukey OP @fslong 谢谢,这个知识点我在廖雪峰老师那里学了,我在使用 multiprocessing 时也遇到了问题,_pickle.UnpicklingError: invalid load key, '\x00'.
|
4
SErHo 2018-03-31 17:24:46 +08:00 via iPhone
放在 if main 里面跑试试。
|
5
zjqzxc 2018-03-31 17:28:34 +08:00
if __name__ == '__main__':
加到 p = Process(target=text) 之前 |
6
zjqzxc 2018-03-31 17:29:30 +08:00
原因:
https://segmentfault.com/q/1010000003869715 “这是 Windows 上多进程的实现问题。在 Windows 上,子进程会自动 import 启动它的这个文件,而在 import 的时候是会执行这些语句的。如果你这么写的话就会无限递归创建子进程报错。所以必须把创建子进程的部分用那个 if 判断保护起来,import 的时候 __name__ 不是 __main__ ,就不会递归运行了。” |
7
tukey OP @zjqzxc 你好,我重新写的如下
from multiprocessing import Process def text(): print("子进程") if __name__ == "__main__": p = Process(target=text) p.start() p.join() print("主进程") 也有问题 |