一、进程的创建
Python
的multiprocessing
模块提供了Process
类,该类可用来在各平台下创建新进程。其构造函数是:
__init__(self, group=None, target=None, name=None, args=(), kwargs={})
其中,各个参数的含义如下:
group:
该参数未实现,不需要传参target
:为新建进程指定执行任务,也就是指定一个函数args
:以元组的方式,为target指定的方法传递参数,如果传入的是元组中有多个参数的话则传入方式是(arg1,arg2,….argn,)kwargs
:以字典的方法,为target指定的方法传递参数。name
: 为新建进程设置名称
1、一些常用方法介绍
start()
方法用于启动进程
run()
方法用于运行所要执行的任务
is_alive()
方法用于判断当前进程是否还活着
getPid()
方法用于获取进程的ID号。
直接创建Process类的实例对象,由此就可以创建一个新的进程;
这个就类似于直接创建实例化线程Thread类
from multiprocessing import Process import os # 定义要调用的方法 def async_fun(name, add): for arc in add: print(name + str(os.getpid()) + " " + arc) if __name__ == '__main__': my_tuple = ("码农飞哥", "今天是宅家的一天", "30岁了还没对象焦虑呀") # 创建进程 process = Process(target=async_fun, args=("子进程", my_tuple)) # 启动子进程 process.start() # 启动主进程 async_fun("主进程", my_tuple)
运行结果是:
主进程11610 码农飞哥
主进程11610 今天是宅家的一天
主进程11610 30岁了还没对象焦虑呀
子进程11612 码农飞哥
子进程11612 今天是宅家的一天
子进程11612 30岁了还没对象焦虑呀
这里需要注意的一点是,必须要将代码放在if __name__ == '__main__':
代码块中。通过os.getpid()
方法来获取进程号。
通过继承Process类的子类,创建实例对象,也可以创建新的进程。
第二种方式就是通过继承Process
类的子类,创建实例对象,也可以创建新的进程,不过这种方式需要重写父类的run()方法。这种方法就类似于直接继承Thread
类创建线程。
import multiprocessing import os # 定义要调用的方法 def async_fun(name, add): for arc in add: print(name + str(os.getpid()) + " " + arc) class MyProcess(multiprocessing.Process): def __init__(self, name, add): multiprocessin<span style="color:transparent">本文来源gaodai#ma#com搞*!代#%^码网%</span>g.Process.__init__(self) self.add = add self.name = name # 重写run()方法 def run(self): async_fun(self.name, self.add) if __name__ == '__main__': my_tuple = ("码农飞哥", "今天是宅家的一天", "宅家也不能虚度") myprocess = MyProcess("子进程", my_tuple) myprocess.start() # 主进程 async_fun("主进程", my_tuple)