请选择 进入手机版|继续访问电脑版
发新帖

Python 多进程的程序代码 Linux 中可以执行,但是 win7 中用 pycharm 调试报错 ...

[复制链接]
8352 12

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
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 "", line 1, in File "C:\anaconda\envs\py36\lib\multiprocessing\spawn.py", line 105, in spawn_mainexitcode = _main(fd)File "C:\anaconda\envs\py36\lib\multiprocessing\spawn.py", line 113, in _mainpreparation_data = reduction.pickle.load(from_parent)_pickle.UnpicklingError: invalid load key, '\x00'.
请大家指点我一下,这个问题搜了好久没找到。

举报 使用道具

回复

精彩评论12

tukey  新手上路  发表于 2018-4-3 13:01:21 | 显示全部楼层
编辑的时候排版好的,发布就乱了,sorry.

举报 使用道具

回复
fslong  新手上路  发表于 2018-4-3 13:13:39 | 显示全部楼层
刚好我昨天才学到这里,由于 Windows 没有 fork 调用,在 Linux 上能用的多进程代码,在 Windows 上会报错。Windows 上可以使用 multiprocessing,详见: https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42a6d3a2e542c000/0014319272686365ec7ceaeca33428c914edf8f70cca383000

举报 使用道具

回复
tukey  新手上路  发表于 2018-4-3 13:14:52 | 显示全部楼层
@fslong 谢谢,这个知识点我在廖雪峰老师那里学了,我在使用 multiprocessing 时也遇到了问题,_pickle.UnpicklingError: invalid load key, '\x00'.

举报 使用道具

回复
serho  新手上路  发表于 2018-4-3 14:05:06 | 显示全部楼层
放在 if main 里面跑试试。

举报 使用道具

回复
zjqzxc  新手上路  发表于 2018-4-3 14:05:22 | 显示全部楼层
if __name__ == '__main__':  
加到 p = Process(target=text) 之前

举报 使用道具

回复
zjqzxc  新手上路  发表于 2018-4-3 14:16:04 | 显示全部楼层
原因:
https://segmentfault.com/q/1010000003869715

“这是 Windows 上多进程的实现问题。在 Windows 上,子进程会自动 import 启动它的这个文件,而在 import 的时候是会执行这些语句的。如果你这么写的话就会无限递归创建子进程报错。所以必须把创建子进程的部分用那个 if 判断保护起来,import 的时候 __name__ 不是 __main__ ,就不会递归运行了。”

举报 使用道具

回复
tukey  新手上路  发表于 2018-4-3 14:22:49 | 显示全部楼层
@zjqzxc 你好,我重新写的如下
from multiprocessing import Process
def text():
    print("子进程")
if __name__ == "__main__":
    p = Process(target=text)
    p.start()
    p.join()
    print("主进程")

也有问题

举报 使用道具

回复
tukey  新手上路  发表于 2018-4-3 14:23:49 | 显示全部楼层
@SErHo 放了试了下,还是报错,我换个 Python 的版本试一下。

举报 使用道具

回复
wwqgtxx  新手上路  发表于 2018-4-3 14:25:55 | 显示全部楼层
@tukey 刚用 win10 1709 和 py3.6 试了你 7#的代码,没问题的

举报 使用道具

回复
tukey  新手上路  发表于 2018-4-3 14:48:18 | 显示全部楼层
@wwqgtxx 好的谢谢,我用的 win7,在 Ubuntu 平台上跑没问题,可能 win 有点问题。

举报 使用道具

回复
wwqgtxx  新手上路  发表于 2018-4-3 15:02:36 | 显示全部楼层
@tukey 检查两个地方,第一个是不是控制台字符集冲突问题,你 print 英文试试,第二个,看你用的 anaconda,你可以试试原版的 cpython 是否正常

举报 使用道具

回复
tukey  新手上路  发表于 2018-4-3 15:19:19 | 显示全部楼层
@wwqgtxx 试了下,在 cmd 里用命令 python+py 文件执行没有问题。

举报 使用道具

回复
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表