重回博客 谈一谈Node中的异步和单线程
重回博客,这个帐号之前注册后就只发了一篇博客。听朋友建议,决定一周两次更新。
第一篇谈论一下最近想的比较多的异步的问题。
传统多线程异步
传统的异步是多线程的,当要同时做两件事的时候,他们是执行在不同的线程里的。这就像是柜台卖东西,来了一个人就得找一个员工陪他,直到这个人走了这个员工才能接待下一个客人。店内的员工就像线程池里的空闲线程,空闲的时候可以去接待客人,可是同时只能接待一个人,要接待其他人就得找另外一个人。
电脑里的线程相当于一个员工团队,哪里需要去哪里。多线程的异步好处在于可以更多的占用系统的资源,每次开辟线程,就像是从这个团队里找一个人来,团队人总共就那么多,抢一个过来就多一点劳动力,接待的客人也就更多。而这样做的缺点在于创建和销毁线程的开销是非常大的,每个线程都需要占用资源,这样资源分配不过来,柜台没办法接待太多客人。并且如果有一个客人看的时间太久了就会让一名接待人员一直不能去接待其他客人,这样本来就吃紧的资源就更分配不过来了。
node.JS的单线程异步
如果拘泥于传统的异步,肯定会发出疑问:单线程怎么能异步?
让我们来想一个问题,什么是异步?最直白的回答就是"让两个操作同时进行"。可是在单线程里,一次只能做一件事情,怎们能有异步呢。如果是普通的操作自然是不能,可是io可以,因为io操作的等待时间内是不占用任何系统资源的,也就是说你尽可以放它慢慢弄,只要执行完了通知我一声就行了。
什么意思呢,我们拿烧水做饭的例子来讲。
在同步的模式下,我们先烧水,我们就等水烧开,烧开后再来切菜、煮饭,然后等饭煮熟后再来炒菜。
在多线程异步下,我们先烧水,这个同时我们要切菜和煮饭,那叫另一个人来切菜,切完菜后他发现要煮饭,可是自己接下来要炒菜,那看看刚刚烧水的人烧完了没有,烧完了就让他来煮饭,没烧完再叫另一个人来煮饭,自己继续炒菜。最后大家都做完了,这个事情就算玩了。
而单线程异步下,我们先烧水,然后放着水在那里烧,再去切菜。这时候菜切完了,先去检查水烧好了没,如果烧好了就用这个水去做点事,如果没烧好,继续放着烧,然后煮饭也和烧水一样,我不是放人去盯着有没有煮好,而是做完一件事情去看这件事有没有做好。
在node中,对于io的操作使用通知的方式,而不像传统的异步操作,使用线程去监视他。
我对node的事件轮询的理解是这样的,主线程分配任务下去,注册回调函数。主线程里在执行代码的时候io继续等待,主线程执行完毕后进行轮询,因为这个时候主线程是空闲状态,所以可以一直轮询,直到发现有某一个io操作给他发了信号告诉他我现在弄好了,你可以用这个数据,主线程的资源就拿来执行回调函数。也就是说从始至终都只有主线程在做事情,主线程要不然是在执行函数,要不然就是在进行事件的轮询,去寻找有哪个事件完成了需要执行他的回调函数。
换句话说,我们继续用刚刚的例子,这个人不是在切菜或者炒菜,就是在检查水有没有烧开,饭有没有煮熟。所以即使是单线程依旧能使用异步模式。
总结
多线程并不是异步的必须因素,这里谈一下io,io操作本身并不执行在程序中,而是交给别人去做,等他做好了我们再拿到结果。我之前考虑最多的就是io难道不阻塞吗,后来才明白io的时候线程是0消耗的,完全处于等待状态。
所谓的单线程异步,正是合理分配了io的等待时间,让主线程去做其他事情,在主线程空闲的时候才来检查等待的任务有没有完成。总的来说,node适合io多,高并发的事,因为这些事情不必等待,也不必创建新的线程,而是分给别人去做,node只需要等待结果就好了。但它并不适合计算密集型的事情,因为当一个计算阻塞了主线程,就无法使下一个任务被轮询到,后面所有的任务都会被阻塞住。
重回博客 谈一谈Node中的异步和单线程的更多相关文章
- 用flask开发个人博客(4)—— flask中4种全局变量
https://blog.csdn.net/hyman_c/article/details/53512109 一 current_app current_app代表当前的flask程序实例,使用时需 ...
- 博客代码:iframe—网页中嵌入其他网页
iframe 是一个可以把另外一个网页嵌入到一个网页里的代码,非常有用.对于一个内容不错的网页,要方便地把它搬到自己的博客里,用这个代码最合适.而对于在新浪博客里不支持的一些网页效果和代码,可先把他们 ...
- 第65章 博客帖子 - Identity Server 4 中文文档(v1.0.0)
第65章 博客帖子 65.1 团队帖子 65.1.1 2019 IdentityServer中的范围和声明设计 尝试使用IdentityServer4的设备流程 OAuth2中隐含流的状态 另一种保护 ...
- 写带有清晰图片的博客:如何将word中的图片复制到windows live writer保持大小不变--清晰度不变
写blog的习惯,先在word写了,复制到windows live writer,再发布到博客园.word中的文章,图片有缩放比例,复制到windows live writer后图片变得不清晰.除了一 ...
- 【技术博客】 关于laravel5.1中文件上传测试的若干尝试
关于laravel5.1中文件上传测试的若干尝试 作者:ZGJ 版本:v1.0 PM注:本人这两天也正在尝试解决这一问题,如有进展将及时更新这一博客 在我们的软工第二阶段中,我开始着手进行后端控制器的 ...
- django开发博客01-页面展示数据库中的数据
1.首先在views.py中引入models.py的 Category这个类 然后在函数中(blog)写执行逻辑 categorys 返回的对象是是一个list"<QuerySet [ ...
- 夺命雷公狗---node.js---19之项目的构建在node+express+mongo的博客项目4mongodb在项目中的基本引入
首先我们在命令行下先建立这个库: 然后我们在项目中引入mongodb的模块: var MongoClient = require('mongodb').MongoClient; var DB_STR ...
- 夺命雷公狗---node.js---20之项目的构建在node+express+mongo的博客项目5mongodb在项目中实现添加数据
我们上一步就引入了mongodb了,那么下一步就要开始写添加数据了,不过有个前提是先将表单的数据处理好: 最基本的这部现在已经成功了,因为最基本的这步就是先将表单处的提交方式和提交地址给处理好,这里和 ...
- (新人的第一篇博客)树状数组中lowbit(i)=i&(-i) 的简单文字证明
第一次写博好激动o(≧v≦)o~~初一狗语无伦次还请多多指教 先了解树状数组http://blog.csdn.net/int64ago/article/details/7429868感觉这个前辈写 ...
随机推荐
- MongoDB安装环境搭建
Mongodb的默认端口号27017 _id是全局唯一值,不要去给这个列赋值,默认是唯一的,如果赋值,列入有两列的_id:2,则会报冲突不能插入 [root@HE4 ~]# tar xvf mongo ...
- 天兔(Lepus)监控系统快速安装部署
Lepus安装需要Lamp环境,Lamp环境的安装个人认为比较费劲,XAMPP的一键部署LAMP环境省心省力, lepus官网手册也建议采用XAMPP的方式安装,lepus也是在XAMPP上进行研发的 ...
- Linux文件权限与目录配置
一.linux文件属性 用户组概念:假如主机有两个团体,第一个团体名为projecta,里面有class1,class2,class3:第二个团体名为projecb,里面有class4,class5, ...
- RIP 相对寻址
知识共享许可协议本作品采用知识共享署名 4.0 国际许可协议进行许可.转载保留声明头部与原文链接https://luzeshu.com/blog/rip-relative-addressing 本博客 ...
- oracle的位图索引和函数索引
1.位图索引 位图索引适用于性别.婚姻状态.行政区等只有几列固定值的类型列,身份证号等就不适合位图索引,位图索引适用于静态数据,频繁更新的字段不适用建立位图索引,因为更新会导致索引块区的变更,还会引起 ...
- HDU5878(打表)
I Count Two Three Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ...
- Raft 实现日志复制同步
Raft 实现日志复制同步 本篇文章以 John Ousterhout(斯坦福大学教授) 和 Diego Ongaro(斯坦福大学获得博士学位,Raft算法发明人) 在 Youtube 上的讲解视频及 ...
- GitHub客户端发布托管代码
初试GitHub及客户端使用 突然想分享代码,于是记起来曾几何时有人提到过GitHub这个东西,于是便各种百度,注册申请了一个账号,下载了windows客户端,全英文网站就连新手教程也是全英的,现在想 ...
- eNSP仿真学习,网络入门!
为了简单的认识Internet的框架的整体结构,简单学习华为的eNSP软件来高度模拟仿真网络框架!(华为和思科公司都发布了自己的网络设备仿真软件,当然我就用国产的吧~) 华为官方的eNSP学习论坛网站 ...
- 模块化写法-IIFE解析
一.IIFE解释 全拼Imdiately Invoked Function Expression,立即执行的函数表达式. 像如下的代码所示,就是一个匿名立即执行函数: (function(windo ...