博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
协程笔记
阅读量:4706 次
发布时间:2019-06-10

本文共 1719 字,大约阅读时间需要 5 分钟。

协程是啥首先我们得知道协程是啥?    协程其实可以认为是比线程更小的执行单元。    为啥说他是一个执行单元,因为他自带CPU上下文。    这样只要在合适的时机,我们可以把一个协程 切换到 另一个协程。    只要这个过程中保存或恢复 CPU上下文那么程序还是可以运行的。协程和线程差异    那么这个过程看起来比线程差不多哇。    其实不然 线程切换从系统层面远不止 保存和恢复 CPU上下文这么简单。    操作系统为了程序运行的高效性每个线程都有自己缓存Cache等等数据,    操作系统还会帮你做这些数据的恢复操作。    所以线程的切换非常耗性能。    但是协程的切换只是单纯的操作CPU的上下文,所以一秒钟切换个上百万次系统都抗的住。协程的问题    但是协程有一个问题,就是系统并不感知,所以操作系统不会帮你做切换。    那么谁来帮你做切换?    让需要执行的协程更多的获得CPU时间才是问题的关键。笔者知道协程的实现相关的    目前的协程框架一般都是设计成 1:N 模式。    所谓 1:N 就是一个线程作为一个容器里面放置多个协程。    那么谁来适时的切换这些协程?答案是有协程自己主动让出CPU,    也就是每个协程池里面有一个调度器,这个调度器是被动调度的。    意思就是他不会主动调度。    而且当一个协程发现自己执行不下去了(比如异步等待网络的数据回来,但是当前还没有数据到),    这个时候就可以由这个协程通知调度器,这个时候执行到调度器的代码,    调度器根据事先设计好的调度算法找到当前最需要CPU的协程。    切换这个协程的CPU上下文把CPU的运行权交个这个协程,    直到这个协程出现执行不下去需要等等的情况,或者它调用主动让出CPU的API之类,触发下一次调度。    对的没错就是类似于 领导人模式那么这个实现有没有问题?    其实是有问题的,假设这个线程中有一个协程是CPU密集型的他没有IO操作,    也就是自己不会主动触发调度器调度的过程,那么就会出现其他协程得不到执行的情况,    所以这种情况下需要程序员自己避免。    这是一个问题,假设业务开发的人员并不懂这个原理的话就可能会出现问题。最后讲讲协程的好处    在IO密集型的程序中由于IO操作远远小于CPU的操作,所以往往需要CPU去等IO操作。    同步IO下系统需要切换线程,让操作系统可以在IO过程中执行其他的东西。    这样虽然代码是符合人类的思维习惯但是由于大量的线程切换带来了大量的性能的浪费,尤其是IO密集型的程序。    所以人们发明了异步IO。就是当数据到达的时候触发我的回调。来减少线程切换带来性能损失。    但是这样的坏处也是很大的,主要的坏处就是操作被“分片”了,代码写的不是 “一气呵成” 这种。     而是每次来段数据就要判断  数据够不够处理哇,够处理就处理吧,不够处理就在等等吧。这样代码的可读性很低,其实也不符合人类的习惯。      但是协程可以很好解决这个问题。比如 把一个IO操作 写成一个协程。当触发IO操作的时候就自动让出CPU给其他协程。    要知道协程的切换很轻的。协程通过这种对异步IO的封装 既保留了性能也保证了代码的 容易编写和可读性。    在高IO密集型的程序下很好。但是高CPU密集型的程序下没啥好处。多进程对应多CPU多线程对应多核CPU事件驱动、协程:挖掘单核CPU的潜力io密集型:多进程->多线程->事件驱动->协程CPU密集型:多进程->多线程事件驱动本质是 异步+回调,是单线程,回调方式严重依赖闭包线程:抢占式多任务协程:协作式多任务,牺牲公平时换取吞吐量多线程中如果io操作密集,就会不停切换线程导致开销过大,换成协程就可以在遇到io阻塞时主动让出执行权换成另一个线程执行,这样可以减少操作系统调度,提高效率,但是如果是CPU密集型,就会出现一个协程一直在执行,其他协程拿不到执行权,牺牲了公平性。

 

转载于:https://www.cnblogs.com/greatfish/p/7420379.html

你可能感兴趣的文章
Spring事务
查看>>
java编程基础(三)流程控制语句
查看>>
让数据库跑的更快的7个MySQL优化建议
查看>>
jquery 取id模糊查询
查看>>
解决在vue中,自用mask模态框出来后,下层的元素依旧可以滑动的问题
查看>>
PAT(B) 1014 福尔摩斯的约会(Java)
查看>>
PAT甲级题解-1123. Is It a Complete AVL Tree (30)-AVL树+满二叉树
查看>>
项目开发总结报告(GB8567——88)
查看>>
SSH加固
查看>>
端口扫描base
查看>>
iOS IM开发的一些开源、框架和教程等资料
查看>>
FansUnion:共同写博客计划终究还是“流产”了
查看>>
python 二维字典
查看>>
Arrays类学习笔记
查看>>
实验吧之【天下武功唯快不破】
查看>>
2019-3-25多线程的同步与互斥(互斥锁、条件变量、读写锁、自旋锁、信号量)...
查看>>
win7-64 mysql的安装
查看>>
dcm4chee 修改默认(0002,0013) ImplementationVersionName
查看>>
maven3在eclipse3.4.2中创建java web项目
查看>>
发布时间 sql语句
查看>>