1.创建进程的2中方法:
multiprocessing和使用 Thread类创建多线程方法类似,使用 Process类创建多进程也有以下 2种方式:
方式1:直接创建 Process类的实例对象,由此就可以创建一个新的进程;
方式2:通过继承 Process类的子类,创建实例对象,也可以创建新的进程。
(1).通过Process类创建进程
和使用 thread 类创建子线程的方式非常类似,使用 Process 类创建实例化对象,其本质是调用该类的构造方法创建新进程。Process 类的构造方法格式如下:def __init__(self,group=None,target=None,name=None,args=(),kwargs={}) 其中,各个参数的含义为:
group:该参数未进行实现,不需要传参;
target:为新建进程指定执行任务,也就是指定一个函数;
name:为新建进程设置名称;
args:为 target 参数指定的参数传递非关键字参数;
kwargs:为 target 参数指定的参数传递关键字参数。
示例:
from multiprocessing import Process
import os,time
print('当前进程ID:',os.getpid())
#定义一个函数,准备作为新进程的target参数
def action(name,*add):
print(name)
for arc in add:
print('%s--当前进程%d' % (arc,os.getpid()))
if __name__ == '__main__':
#定义为进程方法传入的参数
my_tuple = ('python','shell','java')
#创建子进程,执行action()函数
my_process = Process(target=action,args=('my_process进程',*my_tuple))
#启动子进程
my_process.start()
#让主进程执行该函数
action('主进程:',*my_tuple)
结果如下:
当前进程ID: 36736
主进程:
python--当前进程36736
shell--当前进程36736
java--当前进程36736
当前进程ID: 29616
my_process进程
python--当前进程29616
shell--当前进程29616
java--当前进程29616
(2).通过Process继承类创建进程
和使用 thread 子类创建线程的方式类似,除了直接使用 Process 类创建进程,还可以通过创建 Process 的子类来创建进程。
需要注意的是,在创建 Process 的子类时,需在子类内容重写 run() 方法。实际上,该方法所起到的作用,就如同第一种创建方式中 target 参数执行的函数。
另外,通过 Process 子类创建进程,和使用 Process 类一样,先创建该类的实例对象,然后调用 start() 方法启动该进程。下面程序演示如何通过 Process 子类创建一个进程。
示例:
from multiprocessing import Process
import os,time
print('当前进程ID:',os.getpid())
#定义一个函数,供主进程使用
def action(name,*add):
05-11
4516
![](https://csdnimg.cn/release/blogv2/dist/pc/img/readCountWhite.png)
12-24
1027
![](https://csdnimg.cn/release/blogv2/dist/pc/img/readCountWhite.png)
“相关推荐”对你有帮助么?
-
非常没帮助
-
没帮助
-
一般
-
有帮助
-
非常有帮助
提交