进程的执行问题

进程的执行问题

if __name__ == '__main__':
   q = Queue()
   w1 = Write(q)
   r1 = Read(q)
   w1.start()
   r1.start()

到这里2个进程已经就绪状态了吧

这两个进程的执行顺序是怎样的?执行结果是写一条读一条,进程不是应该一个一个执行的吗?

也就是说先执行写进程的4条,然后在执行读进程吗?为什么看起来是同时进行的?

   w1.join()
   r1.terminate()

正在回答 回答被采纳积分+1

登陆购买课程后可参与讨论,去登陆

1回答
慕之熠_灿烈 2019-06-26 14:04:30

同学,您好。

Python中的多进程可实现了真正的并行操作,就是多个CPU同时执行任务,也就是说自定义的进程w1和r1在使用start()方法调用定义的run( )方法时,是同时开启了两个进程来实现对应的逻辑代码。执行结果之所以为写一条数据就读一条数据是因为在写的进程中定义了sleep( )方法,使得程序暂时停止,而此时读的进程中一直是在不断的循环当中读取消息队列中的数据,所以才造成了执行先后的“假象”。

如果我的回答解决了您的疑惑,望采纳!!^_^ 祝学习愉快~~~~~

  • 提问者 洛奇丶大 #1
    那么就是说多进程和多线程都是并行操作的?
    2019-06-26 14:13:49
  • 慕之熠_灿烈 回复 提问者 洛奇丶大 #2
    这样的结论是不准确的,Python中多线程并不是并行执行的,因为在Python设计之初有全局解释器锁(GIL)的存在,所以多线程操作未能实现真正的并行效果;而多进程操作是可以充分利用多核CPU实现并行执行的效果的。 如果我的回答解决了您的疑惑,望采纳!!^_^ 祝学习愉快~~~~~
    2019-06-26 14:56:47
问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
1.Python零基础入门
  • 参与学习           人
  • 提交作业       2727    份
  • 解答问题       8160    个

想要进入Python Web、爬虫、人工智能等高薪领域,你需要掌握本阶段的Python基础知识,课程安排带你高效学习轻松入门,学完你也能听得懂Python工程师的行业梗。

了解课程
请稍等 ...
意见反馈 帮助中心 APP下载
官方微信

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师