多线程,多进程使用场景

既然有GIL锁,为什么还使用多线程?

      CPU运行程序的时候,从内存中读取数据块,但是内存不支持断电保存的功能。一旦断电,数据就会丢失。所以需要把数据存到物理磁盘中,所以CPU运行程序的时候需要先从磁盘中读出来,放到内存中,CPU才能取到数据。磁盘的读取比较慢,CPU在物理磁盘中取数据时,需要等待磁盘准备数据,什么时候数据准备好了,CPU才能使用数据,这样造成了资源的浪费,写数据是一样的,当CPU往磁盘写入数据的时候就会等待,等数据存入到磁盘中了CPU才能执行别的程序。造成了CPU空闲阻塞状态,如果有大量的IO操作,就会频繁出现阻塞行为,那么GIL锁就会自动被释放,这样就会保证多线程同时运行的效果,虽然不是全部的。一跳主线运行的时候,大概运行了100条指令的时候就会释放GIL锁,或者出现阻塞的时候就会释放GIL锁。

多线程的应用场景:

        CPU密集型的程序,整个程序运行中过程中不需要等待任何的IO操作,只有大量的CPU进行运算,这种线程不合适,进程实现更加合适,因为每个进程中都有一个线程,独享一个GIL锁,这样就不涉及抢的问题了,各自运行各自的程序。所以进程实现更加合适、

协程的使用场景:

        协程内部是线程内容划分的更小的单位,协程跟操作系统没有关系,只是程序员自己划分出来的,类似于一个线程中的一跳主线中的两个函数交替运行,达到同时运行的效果,用yield关键字可以让函数暂停下来,next()函数可以让程序继续运行,互相配合达到了协程的效果,上下文切换快速,不需要竞争资源,一条主线。

 

转载于:https://www.cnblogs.com/zhangshuyang/p/8064899.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值