进程池的通信

#此例中将多个任务放入进程池中并且任务之间实现数据交互;进程池的通信我们会使用到队列,而此队列不是普通的队列;
一、导入进程模块 Import multiprocessing,并定义主函数,在其中实现主要功能;
在这里插入图片描述
1,创建进程池通信 processing.Manager().Queue()
只能用于进程池中的队列;
2,创建一个进程池 multiprocessing.pool()
pool(3) 括号内可以填写进程池的数量,代表3个进程池
3、向进程池中添加任务 pol.apply_async() (方法应用,参数)
4、需要关闭进程池 pol.close(), 此处的关闭时间是关闭进程池的状态,不允许其他的任务在添加进来,否则程序运行报错;

二、实现两个函数,fb1 fb2 作为多任务添加到进程池中运行;
在这里插入图片描述
1、定义两个函数,并将创建的队列的方法作为参数传入函数中;
因为我们要使用队列中实现的两个方法:put(输入值)、 get(获取值)
2、同时此处最好做捕获异常,否则函数内代码有误不会报错,无提示信息;

三、运行正常的结果;

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值