首页 技术 正文
技术 2022年11月15日
0 收藏 362 点赞 2,501 浏览 1433 个字

一、join控制子进程的一种方式

  当主进程需要在子进程结束之后结束时,我们需要用到join来控制子进程。

import time
import random
from multiprocessing import Process
def func(index):
time.sleep(random.random())
print('第%s个邮件已经发送完毕'%index)
if __name__ == '__main__':
p_list = []
for i in range(10):
p = Process(target= func,args=(i,))
p.start()
p_list.append(p)
for p in p_list:
p.join() # 阻塞 直到p进程执行完毕就结束阻塞
print('10个邮件已经发送完成')

10个发邮件的子进程是同时创建的,但是是随机分批次执行的,两个for循环几乎是同时进行的,一边执行,一边发送。

二、join控制子进程的一种方式

  当我们需要一面向对象编程时

import os
from multiprocessing import Process
class MyProcess(Process):
def __init__(self,arg):
super().__init__() # 调用父类的__init__方法
self.arg = arg
def run(self):
print('子进程',os.getpid(),os.getppid(),self.arg)
if __name__ == '__main__':
for i in range(10):
p = MyProcess('参数')
p.start() # 开启一个子进程,让这个子进程执行run方法
# p.join()
print('主进程:',os.getpid())

三、守护进程

import time
from multiprocessing import Process
def func():
print('子进程 start')
time.sleep(3)
print('子进程 end')
if __name__ == '__main__':
p = Process(target= func)
p.daemon = True # 设置p为一个守护进程,必须在start之前完成
p.start()
time.sleep(2)
print('主进程')

1、通过daemon给主进程设置一个守护进程。必须在start之前完成

2、守护进程会随着主进程的代码执行完毕而结束

import time
from multiprocessing import Process
def func1():
count = 1
while True:
time.sleep(0.5)
print(count*'*')
count +=1
def func2():
print('func2 start')
time.sleep(5)
print('func2 end')
if __name__ == '__main__':
p1 = Process(target=func1)
p1.daemon = True
p1.start()
Process(target=func2).start()
time.sleep(3)
print('主程序')

结果为:

func2 start
*
**
***
****
*****
主程序
func2 end
如果主进程代码已经执行完毕,但是子进程还没有执行完,守护进程不会继续执行
守护进程会随着主进程的代码执行结束而结束
主进程会等待子进程结束,守护进程只等待主进程代码结束就结束了
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,999
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,511
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,357
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,140
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,770
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,848