start() 方法来启动进程,真正实现了多进程运行,这时无需等待 run 方法体代码执行完毕而直接继续执行下面的代码:调用 Process 类的 start() 方法来启动一个进程,这时此进程处于就绪(可运行)状态,并没有运行,一旦得到 cpu 时间片,就开始执行 run() 方法,这里方法 run() 称为进程体,当进程结束后,不可以重新启动。
run() 方法只是类的一个普通方法,如果直接调用 run 方法,程序中依然只有主线程这一个线程,其程序执行路径还是只有一条,还是要顺序执行,还是要等待 run 方法体执行完毕后才可继续执行下面的代码,这样就没有达到写线程的目的。
验证:
import multiprocessing
import time
def download():
print('开始下载')
for i in range(3):
print('-----1------')
time.sleep(1)
def upload():
print('上传完毕')
for i in range(3):
print('-----2------')
time.sleep(1)
def main():
#queue = multiprocessing.Queue() #实例化队列
process1 = multiprocessing.Process(target=upload)
process2 = multiprocessing.Process(target=download)
process1.run()
process2.run()
if __name__ == '__main__':
main()
运行结果:
上传完毕
-----2------
-----2------
-----2------
开始下载
-----1------
-----1------
-----1------
如果使用start方法:
import multiprocessing
import time
def download():
print('开始下载')
for i in range(3):
print('-----1------')
time.sleep(1)
def upload():
print('上传完毕')
for i in range(3):
print('-----2------')
time.sleep(1)
def main():
#queue = multiprocessing.Queue() #实例化队列
process1 = multiprocessing.Process(target=upload)
process2 = multiprocessing.Process(target=download)
# process1.run()
# process2.run()
process1.start()
process2.start()
if __name__ == '__main__':
main()
执行结果:
上传完毕
-----2------
开始下载
-----1------
-----2------
-----1------
-----2------
-----1------
原文链接:https://blog.csdn.net/LCY133/article/details/107173364