#进程池Pool:apply  apply_async-close-join-get  map  callback

#1、进程池Pool:执行下面代码发现任务012先执行,345后执行,因为进程池只有3个进程,6480进程先处理1,接着处理3和5。
# 可以设置线程的数量去轮流执行它的任务:例如下面例子设置3个进程去轮流执行6个任务。
#map 创建和开启子进程:
from multiprocessing import Pool
import time
import os
import random
def func(i): #i接收0-5
print(i,os.getpid())
time.sleep(random.randint(1,3)) if __name__ == '__main__':
p = Pool(3) #开启3个进程来处理6个任务。3个3个的并发:一个进程在同一时间只能执行一个任务。
p.map(func,range(6)) #6个任务。把0-5导入到func去执行。
# 0 16156
# 1 6480
# 2 15412
# 3 6480
# 4 15412
# 5 6480 #2、
#2.1进程池出现的原因:1、开启过多进程会浪费时间,譬如下面的例子,我们只需要开启三个进程来处理六个任务,而不需要开启六个进程。
#            2、操作系统调度过多进程会影响效率。
#2.2开启进程池:池子里有几个进程,有任务来了,就用这个池子里的进程去处理任务,任务处理完之后,
# 再把进程放回池子里,池子里的进程就可以去处理别的任务了。当所有的任务处理完之后,
# 进程池关闭,回收所有的进程。
#2.3开启进程的数量最好是cpu的数量加1。 #3、apply相当于target,是同步调用,代码是按顺序执行的,没有并发的效果,一般不用,
# 因为是同步的话,一个进程就可以了,没必要利用主进程开启子进程的方式来实现同步。
from multiprocessing import Pool
import time
def func(i):
time.sleep(1)
i += 1
print(i) if __name__ == '__main__':
p = Pool(3)
for i in range(6):
p.apply(func,args=(i,))
#
#
#
#
#
# #4、apply_async是异步调用,创建和开启子进程:
# p.close()和p.join()上面的主进程代码执行之后,主进程就结束了。但是进程池的进程还没结束,
# 会让内存产生一大堆没有被回收的进程。所以必须写上这两句代码。使用get拿到结果。
from multiprocessing import Pool
import time
def func(i):
time.sleep(1)
i += 1
return i if __name__ == '__main__':
p = Pool(3)
ret_l = []
for i in range(6):
ret = p.apply_async(func,args=(i,)) #子进程返回结果i给func,结果i = ret.get()
ret_l.append(ret)
p.close() #进程池关闭,不能再往进程池添加新的任务。
p.join() #阻塞等待,主进程等待子进程结束之后才结束。
[print(ret.get()) for ret in ret_l] #异步调用;把子进程返回的结果都放在列表里面,最后才一次性拿取,实现并发。 # #下面代码没有并发效果:
# if __name__ == '__main__':
# p = Pool(3)
# for i in range(6):
# ret = p.apply_async(func,args=(i,))
# print(ret.get()) #子进程每返回一个结果之后才能拿到一个结果,相当于同步,没有并发的效果。
# p.close()
# p.join() #5、map可接收返回值:
from multiprocessing import Pool
def func(i):
i += 1
return i
if __name__ == '__main__':
p = Pool(3)
ret = p.map(func,range(6))#map的最后一个参数是可迭代的,例如range(6)
print(ret)
# [1, 2, 3, 4, 5, 6] # 6、回调函数:把func的返回值传给call做进一步处理。从pid可以看出,call函数是在主进程当中执行:
from multiprocessing import Pool
import os
def func(i):
print('子进程func%s %s'%(i,os.getpid()))
i += 1
return i def call(arg):
print('call %s' % os.getpid())
arg += 1
print(arg) if __name__ == '__main__':
print('主进程%s' % os.getpid())
p = Pool(3)
for i in range(6):
p.apply_async(func,args=(i,),callback=call)
p.close()
p.join()
#
#
#
#
#
#

day42-进程池的更多相关文章

  1. python进程池:multiprocessing.pool

    本文转至http://www.cnblogs.com/kaituorensheng/p/4465768.html,在其基础上进行了一些小小改动. 在利用Python进行系统管理的时候,特别是同时操作多 ...

  2. 64位进程池HashCode兼容处理

    背景 net旧项目使用32位生成的HashCode,存储到数据库中.迁移到64位上,就需要对HashCode做兼容处理. 解决方案 1:进程池配置支持32位程序. 2:对Hashcode做兼容处理,[ ...

  3. Linux客户/服务器程序设计范式2——并发服务器(进程池)

    引言 让服务器在启动阶段调用fork创建一个子进程池,通过子进程来处理客户端请求.子进程与父进程之间使用socketpair进行通信(为了方便使用sendmsg与recvmsg,如果使用匿名管道,则无 ...

  4. PYTHON多进程编码结束之进程池POOL

    结束昨晚开始的测试. 最后一个POOL. A,使用POOL的返回结果 #coding: utf-8 import multiprocessing import time def func(msg): ...

  5. python(进程池/线程池)

    进程池 import multiprocessing import time def do_calculation(data): print(multiprocessing.current_proce ...

  6. python进程池剖析(三)

    之前文章对python中进程池的原理.数据流以及应用从代码角度做了简单的剖析,现在让我们回头看看标准库中对进程池的实现都有哪些值得我们学习的地方.我们知道,进程池内部由多个线程互相协作,向客户端提供可 ...

  7. python进程池剖析(二)

    之前文章中介绍了python中multiprocessing模块中自带的进程池Pool,并对进程池中的数据结构和各个线程之间的合作关系进行了简单分析,这节来看下客户端如何对向进程池分配任务,并获取结果 ...

  8. python进程池剖析(一)

    python中两个常用来处理进程的模块分别是subprocess和multiprocessing,其中subprocess通常用于执行外部程序,比如一些第三方应用程序,而不是Python程序.如果需要 ...

  9. python多进程,以及进程池并发

    模拟多进程 #!/usr/bin/env python#-*- coding:utf-8 -*-import timefrom multiprocessing import Process def s ...

  10. 使用进程池规避Python的GIL限制

    操作系统 : CentOS7.3.1611_x64 python版本:2.7.5 问题描述 Python的GIL会对CPU密集型的程序产生影响,如果完全使用Python来编程,怎么避开GIL的限制呢? ...

随机推荐

  1. 身边的人工智能&人工智能发展史

    智能家具 扫地机器人 智能音箱 个人助手 在线翻译 谷歌翻译 微软翻译 YouTube 视频翻译 图像识别 人脸识别 AI+摄像头 下棋高手 Alphago 2017年打败柯洁 成为世界第一 Alph ...

  2. blueimp,预览遮罩范围控制

    blueimg gallery github地址:https://github.com/blueimp/Gallery/blob/master/README.md 使用前提,引用css和js < ...

  3. OSS 图片处理流程

    1.步骤一 2.步骤二 3.步骤三 4.步骤四 5.步骤五(步骤4完成会自动添加cname用户解析,不需要自己去加,只需要点击进来看下是否添加成功即可) 通过以上步骤就可以实现了图片服务的配置

  4. 最短路——迪杰斯特拉算法 HDU_3790

    初识最短路,今天只弄了一个迪杰斯特拉算法,而且还没弄成熟,只会最基本的O(n^2),想弄个优先队列都发现尼玛被坑爆了,那个不应该用迪杰斯特拉算法写 表示还是不会优化版的迪杰斯特拉算法,(使用优先队列) ...

  5. cafe-ssd數據集訓練

    训练方式::https://blog.csdn.net/xiao_lxl/article/details/79106837 caffe-ssd训练自己的数据集 https://blog.csdn.ne ...

  6. ubuntu服务器上配置tomcat

    前言 嗯,最近想在自己的腾讯云服务器上跑个项目玩玩,由于服务器是重装的系统,所以,只能自己手动装tomcat. 不过,tomcat是基于java的,必须又java环境tomcat才能够使用,因此首先要 ...

  7. 卡常的编译命令(含O2优化)

    不解释,直接来 //包括O2,O3之类的编译命令 //直接copy and paste #pragma GCC optimize(2) #pragma GCC optimize(3) #pragma ...

  8. C#压缩解压zip 文件

    /// <summary> /// Zip 压缩文件 /// </summary> public class Zip { public Zip() { } #region 加压 ...

  9. UVA 658 状态压缩+隐式图+优先队列dijstla

    不可多得的好题目啊,我看了别人题解才做出来的,这种题目一看就会做的实在是大神啊,而且我看别人博客都看了好久才明白...还是对状态压缩不是很熟练,理解几个位运算用了好久时间.有些题目自己看着别人的题解做 ...

  10. 题解 P4942 【小凯的数字】

    题目 为什么看到很多题解区的 dalao 都用逆元?是我太菜了吧 [分析] 首先,根据弃九验算法的原理,显然可以得到:一个 \(n\) 位数 \(a_1a_2a_3\dots a_n\equiv a_ ...