一、概念
进程:进程,是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。
重点:1. 是一次运行活动,比如qq是程序,pycharm是程序,只有运行起来才是进程。
2.是系统进行资源分配和调度的基本单位,每个进程运行时,系统都会为他分配各自的内存,数据。每个进程间的空间是各自独立的。
二、实例结构
importmultiprocessingimporttimedefworker_1(interval):print "worker_1"time.sleep(interval)print "end worker_1"
defworker_2(interval):print "worker_2"time.sleep(interval)print "end worker_2"
defworker_3(interval):print "worker_3"time.sleep(interval)print "end worker_3"
if __name__ == "__main__":
p1= multiprocessing.Process(target = worker_1, args = (2,))
p2= multiprocessing.Process(target = worker_2, args = (3,))
p3= multiprocessing.Process(target = worker_3, args = (4,))
p1.start()
p2.start()
p3.start()print("The number of CPU is:" +str(multiprocessing.cpu_count()))for p inmultiprocessing.active_children():print("child p.name:" + p.name + "\tp.id" +str(p.pid))print ("END!!!!!!!!!!!!!!!!!")
输出:
The number of CPU is:4child p.name:Process-1p.id5791
child p.name:Process-3p.id5793
child p.name:Process-2p.id5792
END!!!!!!!!!!!!!!!!!
worker_1
worker_2
worker_3
end worker_1
end worker_2
end worker_3
三、进程池
python中,进程池内部会维护一个进程序列。当需要时,程序会去进程池中获取一个进程。如果进程池序列中没有可供使用的进程,那么程序就会等待,直到进程池中有可用进程为止。
因为每个进程需要有自己的内存,数据,和cpu消耗,我们不可能开大量的进程,进程池就为我们提供了这样的便捷,在进程池中固定好可用进程的数量,实现多进程操作。
实例:
from multiprocessing importPoolimporttimedeffunc(arg):
time.sleep(1)print('arg is',arg)if __name__ == '__main__':
pl= Pool(2) # 同时可以开启2个进程for i in range(10):
pl.apply_async(func=f