为什么计算密集型用多进程,IO密集型用多线程

计算:消耗CPU;代码执行,算数,for都是计算

io:不消耗CPU;打开文件,写入文件,网络操作都是io;

       如果遇到io,该线程会释放CPU的执行权限,转而去执行别的线程

由于python有gill锁,开启多条线程,同一时刻只能有一条线程执行

计算密集型

开了多线程,实际上由于gill锁的存在,同一时刻只能有一个线程在执行,就会浪费多核优势

我们希望能够充分利用多核优势,让每个CPU都能利用起来,所以开启进程

因为gill锁只能锁住同一个进程下的线程

开启多个进程就能利用多核优势

io密集型

只要遇到io就会释放CPU的执行权限

进程内开了多个io线程,线程多半都在等待,开启多进程不能提高效率,反而消耗资源,所以使用多线程即可

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值