目录
pycharm多进程踩坑–Python
所遇到的情况
如下:
在进程中创建类实例,回调函数去获取实例时,报如下错误,注意在cmd和linux下面运行是没问题的。

执行的代码
如下:
# --coding: utf-8 --
# @User: JasonHU
# @Time: 2020/11/25 21:11
# @IDE: Pycharm
# author: hzc
import multiprocessing as mp
import time
class test:
def __init__(self, x):
self.x = x
def printf(self):
print(self.x)
def foo_pool(x, y):
time.sleep(5)
instance = test(x * x + y)
return instance
result_list = []
def log_result(result):
# This is called whenever foo_pool(i) returns a result.
# result_list is modified only by the main process, not the pool workers.
# result_list.append(result)
print(type(result))
def apply_async_with_callback():
pool = mp.Pool(1)
for i in range(10):
pool.apply_async(foo_pool, args=(i, 2), callback=log_result)
pool.close()
pool.join()
print(result_list)
if __name__ == '__main__':
apply_async_with_callback()
解决办法
我在网上找了很久都没有找到解决方案
由于考虑到是pycharm的问题
因而改变了一下pycharm的版本(从2020.2.3->2018.3.7)
运行结果正常
如下:

总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
- python3 设置多进程名称并在ps命令中可见(Centos7 系统)
- Python使用multiprocessing如何实现多进程
- Python中多进程处理的Process和Pool的用法详解
- python多进程并发的实现示例
- Python多进程Process和管道Pipe的使用方式
- Python使用logging实现多进程安全的日志模块
声明:本站(华域联盟www.cnhackhy.com)所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

评论(0)