重回博客 谈一谈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感觉这个前辈写 ...
随机推荐
- SQL查询根节点
/* 标题:查询指定节点及其所有父节点的函数 作者:爱新觉罗.毓华(十八年风雨,守得冰山雪莲花开) 时间:2008-05-12 地点:广东深圳 */ create table tb(id varcha ...
- jQuery 动画的执行
jQuery 动画的执行 <%@ page language="java" import="java.util.*" pageEncoding=" ...
- POJ2774(二分+哈希)
Long Long Message Time Limit: 4000MS Memory Limit: 131072K Total Submissions: 27234 Accepted: 11 ...
- MyBatis 源码分析——SqlSession接口和Executor类
mybatis框架在操作数据的时候,离不开SqlSession接口实例类的作用.可以说SqlSession接口实例是开发过程中打交道最多的一个类.即是DefaultSqlSession类.如果笔者记得 ...
- WPF开发进阶 - Fody/PropertyChanged(一)
INotifyPropertyChanged 在WPF MVVM模式开发中,实现INotifyPropertyChanged的ViewModel是非常重要且常见的类: public class Mai ...
- MongoDB基础之九 replication复制集
准备工作:创建目录 mkdir -p /home/m17 //home/m18 /home/m19 /home/mlog 1:启动3个实例,且声明实例属于某复制集 # ./bin/mongod --d ...
- Swift2.2 看完这篇博客 你不想懂也会懂得----二叉树
一:初衷 我自己也好奇,为什么莫名其妙的想起写这个,其实数据里面包含的结构和逻辑我自己觉得才是最原始经典的,最近也在学swift,就向着利用swift整理一些二叉树.自己刚开始的时候也是用OC看着别的 ...
- 蓝牙门禁Android客户端
先来了解下Android传统蓝牙连接的大致简单的流程: 其中涉及到几个类依次来介绍,废话不多说,下面是从Android4.4开发指南蓝牙所用到的类的截图: 第一个类BluetoothAdapter: ...
- webpack1.x 升级到 webpack2.x 英文文档翻译
近日项目要升级到webpack2.2,原来使用的webpack版本是1.12,在升级项目的同时,翻译一下官方的升级文档,去掉了一些不常用的配置 resolve.root, resolve.fallba ...
- Raspberry树莓派学习笔记2—配置RobotFramework自动化测试环境
一般RobotFramework都是安装在Windows/Linux的PC机上,这里将简单介绍在树莓派硬件平台上配置RobotFramework的开发和运行环境. 树莓派上配置了自动化测试软件,可以考 ...