python实现守护进程、守护线程、守护非守护并行


Posted in Python onMay 05, 2018

守护进程

1、守护子进程

主进程创建守护进程

  1. 其一:守护进程会在主进程代码执行结束后就终止
  2. 其二:守护进程内无法再开启子进程,否则抛出异常:AssertionError: daemonic processes are not allowed to havechildren

注意:进程之间是互相独立的,主进程代码运行结束,守护进程随即终止

我们来看一个例子

from multiprocessing import Process
import os,time,random

def task():
  print('%s is running' %os.getpid())
  time.sleep(2)
  print('%s is done' %os.getpid())

  #守护进程内无法再开启子进程,否则抛出异常
  # p = Process(target=time.sleep, args=(3,))
  # p.start()

if __name__ == '__main__':
  p=Process(target=task)
  p.daemon = True #1、必须在p.start()之前
  p.start()
  print('主')

输出结果如下:

原因是:主进程程序启动执行到p子进程,由于子进程需要开辟内存空间,由于需要耗费时间,所以主进程会首先输出“主”,由于主进程执行完毕,那么守护子进程p也就被干掉了,随之主进程也就退出了

如果上面代码修改如下,加上 p.join()这一行代码

if __name__ == '__main__':
  p=Process(target=task)
  p.daemon = True #1、必须在p.start()之前
  p.start()
  p.join()
  print('主')

那么程序会输出如下:

14732 is running

14732 is done

join以前也分析过,是起到阻塞作用,子进程执行完毕,才执行主进程,所以加上join

1、执行到join,是起到阻塞作用,就会执行子进程,然后执行完毕,在执行主进程

2、也可以这样理解,执行到join,由于主进程print(“主”)没有执行完,所以守护进程不会被干掉,继续执行

1、守护子进程、非守护子进程并存

在上面的例子是子进程只有一个守护进程,在主进程执行完毕,守护子进程就会被干掉 ,我们在来看一个,子进程既有守护子进程,又包含非守护子进程

from multiprocessing import Process
from threading import Thread
import time,os
def foo():
  print(123)
  time.sleep(1)
  print("end123")

def bar():

  print(456)
  time.sleep(3)
  print("end456")

if __name__ == '__main__':
  p1=Process(target=foo)
  p2 = Process(target=bar)
  p1.daemon=True
  p1.start()
  p2.start()
  print("main-------")

输出如下:

main-------
456
end456

原因如下:由于p1,p2都是子进程,需要开辟内存空间,需要耗费时间,所以会优先输出主进程“main”,由于p1是守护子进程,p2是非守护子进程,当主进程执行完毕(注意之类主进程还没有退出,因为还有p2非守护进程),p1守护进程也就退了,但是还有一个p2非守护进程,所以p2会执行自己的代码任务,当p2执行完毕,那么主进程也就退出了,进而整个程序就退出了

守护线程

守护子线程

无论是进程还是线程,都遵循:守护xxx会等待主xxx运行完毕后被销毁

需要强调的是:运行完毕并非终止运行

1.对主进程来说,运行完毕指的是主进程代码运行完毕

2.对主线程来说,运行完毕指的是主线程所在的进程内所有非守护线程统统运行完毕,主线程才算运行完毕

详细解释:

1 主进程在其代码结束后就已经算运行完毕了(守护进程在此时就被回收),然后主进程会一直等非守护的子进程都运行完毕后回收子进程的资源(否则会产生僵尸进程),才会结束,

2 主线程在其他非守护线程运行完毕后才算运行完毕(守护线程在此时就被回收)。因为主线程的结束意味着进程的结束,进程整体的资源都将被回收,而进程必须保证非守护线程都运行完毕后才能结束。

我们先来看一个例子

from multiprocessing import Process
from threading import Thread
import os,time,random
def task():
  # t=Thread(target=time.sleep,args=(3,))
  # t.start()
  print('%s is running' %os.getpid())
  time.sleep(2)
  print('%s is done' %os.getpid())

if __name__ == '__main__':
  t=Thread(target=task)
  t.daemon = True
  t.start()
  print('主')

 输出如下:

13368 is running

原因是:

在执行到守护子线程t,由于主线程子线程通用一块内存,所以不存在不同进程创建各自空间,所以就先输出子进程的执行任务代码,所以输出print(‘%s is running' %os.getpid()),由于time.sleep(2),所以就会执行主线程“main”,然后主线程执行完毕,那么即使2秒过后,由于主线程执行完毕,那么子守护线程也就退出了,所以 print(‘%s is done' %os.getpid())就不会执行了

守护子线程非守护子进程并存

我们解析来看一个守护子线程非守护子进程并存的例子

from threading import Thread
import time
def foo():
  print(123)
  time.sleep(1)
  print("end123")

def bar():
  print(456)
  time.sleep(3)
  print("end456")

if __name__ == '__main__':
  t1=Thread(target=foo)
  t2 = Thread(target=bar)

  t1.daemon=True

  t2.start()
  t1.start()
  print("main-------")

输出如下:

456
123
main-------

end123

end456

原因是:

t1是守护子线程,t2非守护子线程,跟主线程使用一块内存,所以会输出t1,t1子线程的任务代码,所以执行456,123由于t1,t2都有睡眠时间,所以执行主线程代码,然后对主线程来说,运行完毕指的是主线程所在的进程内所有非守护线程统统运行完毕,主线程才算运行完毕,所以会执行t1,t2睡眠后的任务代码,然后程序退出。

我们会问为什么t1守护子线程,也会执行sleep后的代码,不是说主线程代码执行完毕,守护线程就被干掉了吗?这里要注意是对主线程来说,运行完毕指的是主线程所在的进程内所有非守护线程统统运行完毕,主线程才算运行完毕,当时t2还没执行完毕

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
Python常用的日期时间处理方法示例
Feb 08 Python
基于Python中numpy数组的合并实例讲解
Apr 04 Python
解决Python print输出不换行没空格的问题
Nov 14 Python
django多个APP的urls设置方法(views重复问题解决)
Jul 19 Python
python 环境搭建 及python-3.4.4的下载和安装过程
Jul 20 Python
Python 堆叠柱状图绘制方法
Jul 29 Python
python实现图像检索的三种(直方图/OpenCV/哈希法)
Aug 08 Python
python__new__内置静态方法使用解析
Jan 07 Python
Python虚拟环境venv用法详解
May 25 Python
Flask中jinja2的继承实现方法及实例
Mar 03 Python
使用tensorflow 实现反向传播求导
May 26 Python
python数字图像处理之图像自动阈值分割示例
Jun 28 Python
Linux(Redhat)安装python3.6虚拟环境(推荐)
May 05 #Python
Python3中的json模块使用详解
May 05 #Python
Python 编码规范(Google Python Style Guide)
May 05 #Python
python 编码规范整理
May 05 #Python
PYTHON基础-时间日期处理小结
May 05 #Python
python 日期操作类代码
May 05 #Python
Python批量发送post请求的实现代码
May 05 #Python
You might like
php 中include()与require()的对比
2006/10/09 PHP
fleaphp常用方法分页之Pager使用方法
2011/04/23 PHP
PHP使用imagick读取PDF生成png缩略图的两种方法
2014/03/20 PHP
PHP curl伪造IP地址和header信息代码实例
2015/04/27 PHP
PHP载入图像imagecreatefrom_gif_jpeg_png系列函数用法分析
2016/11/14 PHP
php 实现Hash表功能实例详解
2016/11/29 PHP
jquery弹出框的用法示例(一)
2013/08/26 Javascript
JS求解三元一次方程组值的方法
2017/01/03 Javascript
layui框架table 数据表格的方法级渲染详解
2018/08/19 Javascript
vue+element项目中过滤输入框特殊字符小结
2019/08/07 Javascript
vue实现表单录入小案例
2019/09/27 Javascript
微信小程序吸底区域适配iPhoneX的实现
2020/04/09 Javascript
如何在微信小程序中使用骨架屏的步骤
2020/06/12 Javascript
[40:27]完美世界DOTA2联赛PWL S3 PXG vs GXR 第一场 12.19
2020/12/24 DOTA
Python自定义函数的创建、调用和函数的参数详解
2014/03/11 Python
Python urlopen()函数 示例分享
2014/06/12 Python
python按综合、销量排序抓取100页的淘宝商品列表信息
2018/02/24 Python
在Python中,不用while和for循环遍历列表的实例
2019/02/20 Python
win10下安装Anaconda的教程(python环境+jupyter_notebook)
2019/10/23 Python
如何理解Python中的变量
2020/06/01 Python
python如何编写类似nmap的扫描工具
2020/11/06 Python
python palywright库基本使用
2021/01/21 Python
英国家喻户晓的折扣商场:TK Maxx
2017/05/26 全球购物
英文求职信结束语大全
2013/10/26 职场文书
儿子婚宴答谢词
2014/01/09 职场文书
档案检查欢迎词
2014/01/13 职场文书
网络管理专业求职信
2014/03/15 职场文书
基层党组织公开承诺书
2014/03/28 职场文书
奶茶店创业计划书
2014/08/14 职场文书
中国梦演讲稿5分钟
2014/08/19 职场文书
个人政风行风自查自纠报告
2014/10/21 职场文书
《1942》观后感
2015/06/08 职场文书
关于应聘教师的自荐信
2016/01/28 职场文书
《棉鞋里的阳光》教学反思
2016/02/20 职场文书
ROS系统将python包编译为可执行文件的简单步骤
2021/07/25 Python
HTML+JS实现在线朗读器
2022/02/15 Javascript