python-多任务编程-进程

 

  • 1.1进程的概念

  • 进程是操作系统进行资源分配的基本单位。

  • 进程是Python程序中实现多任务的一种方式

1.2多进程的使用

  1. 导入进程包

    • import multiprocessing

  2. 创建子进程并指定执行的任务

    • sub_process = multiprocessing.Process (target=任务名)

  3. 启动进程执行任务

    • sub_process.start()

Process(group,target,name,args,kwargs)**

- group:指定进程组,目前只能使用None
- target:执行的目标任务名
- name:进程名字
- args:以元组方式给执行任务传参
- kwargs: 以字典方式给执行任务传参

**Process创建的实例对象的常用方法:**

- start():启动子进程实例(创建子进程)
- join():等待子进程执行结束
- terminate():不管任务是否完成,立即终止子进程

**Process创建的实例对象的常用属性:**

name:当前进程的别名,默认为Process-N,N为从1开始递增的整数
  • 1.3获取进程编号

  • 获取当前进程编号

    • os.getpid()

  • 获取当前父进程编号

    • os.getppid()

  • 获取进程编号可以查看父子进程的关系

  • 1.4进程执行带有参数的任务

  • 进程执行任务并传参有两种方式:

    • 元组方式传参(args): 元组方式传参一定要和参数的顺序保持一致。

    • 字典方式传参(kwargs): 字典方式传参字典中的key一定要和参数名保持一致。

1.5进程的注意点

  • 进程之间不共享全局变量

    • 创建子进程会对主进程资源进行拷贝,也就是说子进程是主进程的一个副本,好比是一对双胞胎,之所以进程之间不共享全局变量,是因为操作的不是同一个进程里面的全局变量,只不过不同进程里面的全局变量名字相同而已。

  • 主进程会等待所有的子进程执行结束再结束

    • 为了保证子进程能够正常的运行,主进程会等所有的子进程执行完成以后再销毁,设置守护主进程的目的是主进程退出子进程销毁,不让主进程再等待子进程去执行

      • 设置守护主进程方式: 子进程对象.daemon = True

      • 销毁子进程方式: 子进程对象.terminate()

import multiprocessing
import time


# 定义进程所需要执行的任务
def task():
   for i in range(10):
       print("任务执行中...")
       time.sleep(0.2)

if __name__ == '__main__':
   # 创建子进程
   sub_process = multiprocessing.Process(target=task)
   # 设置守护主进程,主进程退出子进程直接销毁,子进程的生命周期依赖与主进程
   # sub_process.daemon = True
   sub_process.start()

   time.sleep(0.5)
   print("over")
   # 让子进程销毁
   sub_process.terminate()
   exit()

   # 总结: 主进程会等待所有的子进程执行完成以后程序再退出
   # 如果想要主进程退出子进程销毁,可以设置守护主进程或者在主进程退出之前让子进程销毁

 

上一篇:Rocketmq 不同的topic要配不同的consumegroup


下一篇:call继承