多进程为什么是顺序执行?

wxvp 2018-03-01 01:00:49
from multiprocessing import Pool
import os, time, random

def pr():
for i in range(10):
print('r'+str(i))
time.sleep(random.random() * 3)

def pw():
for i in range(10):
print('w' + str(i))
time.sleep(random.random() * 3)

if __name__=='__main__':
p = Pool(2)
p.apply_async(pw())
p.apply_async(pr())
p.close()
p.join()

上述代码种函数pr与pw 为什么执行结果是顺序的,而不是乱序的?
...全文
553 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
混沌鳄鱼 2018-03-01
  • 打赏
  • 举报
回复
进程池不是你这个用法 两个worker分别执行一次, 并不是并发. 要达到你要的效果要开两个子进程

from multiprocessing import Process
import os, time, random

def pr():
    for i in range(10):
        print('r'+str(i))
        time.sleep(random.random() * 3)

def pw():
    for i in range(10):
        print('w' + str(i))
        time.sleep(random.random() * 3)

if __name__=='__main__':
    p1 = Process(target=pr)
    p2 = Process(target=pw)

    p1.start()
    p2.start()

    p1.join()
    p2.join()

37,720

社区成员

发帖
与我相关
我的任务
社区描述
JavaScript,VBScript,AngleScript,ActionScript,Shell,Perl,Ruby,Lua,Tcl,Scala,MaxScript 等脚本语言交流。
社区管理员
  • 脚本语言(Perl/Python)社区
  • IT.BOB
加入社区
  • 近7日
  • 近30日
  • 至今

试试用AI创作助手写篇文章吧