◎知识点
子进程的创建与启动之直接实例化Process
子进程的创建与启动之继承Process
◎脚本练习
▽ 子进程的创建与启动之直接实例化Process
""" 标准库模块multiprocessing中提供了一个类对象Process,用于表示进程。 使用类对象Process创建并启动子进程的第1种方式为: (1) 根据类对象Process创建进程实例对象 (2) 调用进程实例对象的方法start()启动进程 调用方法start()后,会自动调用方法run(),方法run()会自动调用参数target指定的函数 Process的特殊方法__init__()的定义如下: __init__(self, group=None, target=None, name=None, args=(), kwargs={}) 调用特殊方法__init__()必须指定关键字实参,其中, (1) 参数group用于指定进程实例对象所属的进程组,默认不属于任何进程组 (2) 参数target用于指定被方法run()调用的函数,默认没有函数被调用 (3) 参数name用于指定创建的进程实例对象的名称,第n个子进程的默认名称为'Process-n' (4) 参数args用于指定target接收的位置参数,用元组表示,默认不接收位置参数 (5) 参数kwargs用于指定target接收的关键字参数,用字典表示,默认不接收关键字参数 """ from multiprocessing import Process, current_process import time def do_sth(arg1, arg2): print('子进程启动(%d--%s)' % (current_process().pid, current_process().name)) print('arg1 = %d, arg2 = %d' % (arg1, arg2)) print('子进程结束(%d--%s)' % (current_process().pid, current_process().name)) if __name__ == '__main__': print('父进程启动(%d--%s)' % (current_process().pid, current_process().name)) process = Process(target=do_sth, args=(5, 8), name='myprocess') process.start() time.sleep(2) print('父进程结束(%d--%s)' % (current_process().pid, current_process().name))
▽ 子进程的创建与启动之继承Process
""" 使用类对象Process创建并启动子进程的第2种方式为: (1) 自定义继承自Process的类对象,重写特殊方法__init__()和方法run() (2) 根据自定义的类对象创建进程实例对象 (3) 调用进程实例对象的方法start()启动进程 调用方法start后,会自动调用重写后的方法run() 与第1种方式相比,相当于把参数target指定的函数体转移到了方法run()中。因此,在创建 进程实例对象时无需再指定参数target 第1种方式创建进程实例对象时指定的其它参数,在第2种方式中可以传递给重写后的特殊方法__init__() """ print('-'*20) class MyProcess(Process): def __init__(self, name, args): super().__init__(name = name) self.args = args def run(self): print('子进程启动(%d--%s)' % (current_process().pid, current_process().name)) print('arg1 = %d, arg2 = %d' % self.args) print('子进程结束(%d--%s)' % (current_process().pid, current_process().name)) if __name__ == '__main__': print('父进程启动(%d--%s)' % (current_process().pid, current_process().name)) mp = MyProcess(name = 'myprocess1', args= (5, 8)) mp.start() time.sleep(2) print('父进程结束(%d--%s)' % (current_process().pid, current_process().name))