python多进程 保活_python多进程总结

一、概念

进程:进程,是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。

重点: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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值