python multiprocessing模块_Python进程Multiprocessing模块原理解析

先看看下面的几个方法:

star() 方法启动进程,

join() 方法实现进程间的同步,等待所有进程退出。

close() 用来阻止多余的进程涌入进程池 Pool 造成进程阻塞。

参数:

target 是函数名字,需要调用的函数

args 函数需要的参数,以 tuple 的形式传入

用法:

multiprocessing.Process(group=None, target=None, name=None, args=(), kwargs={}, *, daemon=None)

写一个的例子:

from multiprocessing import Pool

import os,time

def pr(str):

print("The " + str + " is %s" %(os.getpid()))

time.sleep(1)

print("The " + str + " is close")

if __name__ == "__main__":

print('-------------------------------')

print("the current pid: "+ str(os.getpid()))

# 默认为自己电脑的核数

p = Pool(2)

for i in range(5):

p.apply_async(pr,args=('xdxd',))

p.close()

p.join()

print("----------close-----------------")

通过结果可以看出,是2个进程同时启动,同时启动的进程数与pool中设置的数量和自己电脑的核数有关

结果:

-------------------------------

the current pid: 9562

The xdxd is 9563

The xdxd is 9564

The xdxd is close

The xdxd is close

The xdxd is 9563

The xdxd is 9564

The xdxd is close

The xdxd is close

The xdxd is 9563

The xdxd is close

----------close-----------------

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持python博客。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值