一、 Process对象的join方法

在主进程运行过程中如果想并发地执行其他的任务,我们可以开启子进程,此时主进程的任务与子进程的任务分两种情况

情况一:在主进程的任务与子进程的任务彼此独立的情况下,主进程的任务先执行完毕后,主进程还需要等待子进程执行完毕,然后统一回收资源。

情况二:如果主进程的任务在执行到某一个阶段时,需要等待子进程执行完毕后才能继续执行,就需要有一种机制能够让主进程检测子进程是否运行完毕,在子进程执行完毕后才继续执行,否则一直在原地阻塞,这就是join方法的作用

阻塞当前进程,直到调用join方法的那个进程执行完,再继续执行当前进程。

#!/usr/bin/env python
# -*- coding:utf-8 -*-
import time
from multiprocessing import Process def task(name):
print('%s is runing' % name)
time.sleep(1)
print('%s is done' % name) if __name__ == '__main__':
p1 = Process(target=task, args=('xiaojiu',))
p2 = Process(target=task, args=('hh',))
p3 = Process(target=task, args=('wawa',)) p1.start()
p1.join() #这里xiaojiu 执行完毕之后才会执行其他进程
p2.start()
p3.start()
print('主进程') #输出 xiaojiu is runing
xiaojiu is done
主进程
hh is runing
wawa is runing
hh is done
wawa is done

二、 Process对象的其他属性或方法

进程对象的其他方法一:terminate与is_alive

#!/usr/bin/env python
# -*- coding:utf-8 -*-
import time
from multiprocessing import Process def task(name):
print('%s is runing' % name)
time.sleep(1)
print('%s is done' % name) if __name__ == '__main__':
p1 = Process(target=task, args=('xiaojiu',))
p2 = Process(target=task, args=('hh',),name=('子进程2')) #改变进程名称
p3 = Process(target=task, args=('wawa',)) p1.start()
# p1.join() #这里xiaojiu 执行完毕之后才会执行其他进程
p1.terminate() #关闭进程,不会立即关闭,因为关闭的是进程信号。
print(p1.is_alive()) #查看是否存活
print(p1.name) #可以查看进程的名称 # Process-1
print(p2.name) #子进程2
print(p3.name)# Process-3 p2.start()
p3.start()
print('主进程') #输出 True
Process-1
子进程2
Process-3
主进程
hh is runing
wawa is runing
hh is done
wawa is done

最新文章

  1. 从 IClassFactory 为 CLSID 为 {00024500-0000-0000-C000-000000000046} 的 COM 组件创建实例失败,原因是出现以下错误: 8001010a解决办法
  2. sql join 优化
  3. Editplus从下载到使用
  4. hdoj 1789 Doing Homework again
  5. mapreduce实战:统计美国各个气象站30年来的平均气温项目分析
  6. 用H5实现微信的四个界面
  7. c++中各种数据类型所占字节
  8. ACE 主动对象模式的按部就班的实现方法
  9. 闭包、lambda和interface
  10. CSS中@import与link的具体区别
  11. [SinGuLaRiTy] 组合数学
  12. 机器视觉----LBP
  13. [扩展推荐] —— Laravel Log 增强
  14. Mysql exists 与 in
  15. redis过期机制
  16. linux command 4
  17. Twisted 简介
  18. win10无法访问别的机器的共享目录
  19. java 获取浏览器类型
  20. 网络之Json生成解析

热门文章

  1. matplotlib中subplots的用法
  2. 通过关闭线程底层资源关闭类似synchronized及IO阻塞的情况
  3. 关于try catch块执行流程
  4. Spring—SSJ集成&声明式事务管理
  5. 容器编排系统K8s之flannel网络模型
  6. Logstash学习之路(五)使用Logstash抽取mysql数据到kakfa
  7. LInux维护一:VirtualMachine磁盘扩容
  8. LeetCode237 删除链表中的节点
  9. Java 在pom.xml中配置build resources, 来防止我们资源导出失败问题(Maven项目)
  10. web测试误区:浏览器后退键退出系统会话失效