重回博客 谈一谈Node中的异步和单线程

重回博客,这个帐号之前注册后就只发了一篇博客。听朋友建议,决定一周两次更新。

第一篇谈论一下最近想的比较多的异步的问题。

传统多线程异步

传统的异步是多线程的,当要同时做两件事的时候,他们是执行在不同的线程里的。这就像是柜台卖东西,来了一个人就得找一个员工陪他,直到这个人走了这个员工才能接待下一个客人。店内的员工就像线程池里的空闲线程,空闲的时候可以去接待客人,可是同时只能接待一个人,要接待其他人就得找另外一个人。

电脑里的线程相当于一个员工团队,哪里需要去哪里。多线程的异步好处在于可以更多的占用系统的资源,每次开辟线程,就像是从这个团队里找一个人来,团队人总共就那么多,抢一个过来就多一点劳动力,接待的客人也就更多。而这样做的缺点在于创建和销毁线程的开销是非常大的,每个线程都需要占用资源,这样资源分配不过来,柜台没办法接待太多客人。并且如果有一个客人看的时间太久了就会让一名接待人员一直不能去接待其他客人,这样本来就吃紧的资源就更分配不过来了。

node.JS的单线程异步

如果拘泥于传统的异步,肯定会发出疑问:单线程怎么能异步?

让我们来想一个问题,什么是异步?最直白的回答就是"让两个操作同时进行"。可是在单线程里,一次只能做一件事情,怎们能有异步呢。如果是普通的操作自然是不能,可是io可以,因为io操作的等待时间内是不占用任何系统资源的,也就是说你尽可以放它慢慢弄,只要执行完了通知我一声就行了。

什么意思呢,我们拿烧水做饭的例子来讲。

在同步的模式下,我们先烧水,我们就等水烧开,烧开后再来切菜、煮饭,然后等饭煮熟后再来炒菜。

在多线程异步下,我们先烧水,这个同时我们要切菜和煮饭,那叫另一个人来切菜,切完菜后他发现要煮饭,可是自己接下来要炒菜,那看看刚刚烧水的人烧完了没有,烧完了就让他来煮饭,没烧完再叫另一个人来煮饭,自己继续炒菜。最后大家都做完了,这个事情就算玩了。

而单线程异步下,我们先烧水,然后放着水在那里烧,再去切菜。这时候菜切完了,先去检查水烧好了没,如果烧好了就用这个水去做点事,如果没烧好,继续放着烧,然后煮饭也和烧水一样,我不是放人去盯着有没有煮好,而是做完一件事情去看这件事有没有做好。

在node中,对于io的操作使用通知的方式,而不像传统的异步操作,使用线程去监视他。

我对node的事件轮询的理解是这样的,主线程分配任务下去,注册回调函数。主线程里在执行代码的时候io继续等待,主线程执行完毕后进行轮询,因为这个时候主线程是空闲状态,所以可以一直轮询,直到发现有某一个io操作给他发了信号告诉他我现在弄好了,你可以用这个数据,主线程的资源就拿来执行回调函数。也就是说从始至终都只有主线程在做事情,主线程要不然是在执行函数,要不然就是在进行事件的轮询,去寻找有哪个事件完成了需要执行他的回调函数。

换句话说,我们继续用刚刚的例子,这个人不是在切菜或者炒菜,就是在检查水有没有烧开,饭有没有煮熟。所以即使是单线程依旧能使用异步模式。

总结

多线程并不是异步的必须因素,这里谈一下io,io操作本身并不执行在程序中,而是交给别人去做,等他做好了我们再拿到结果。我之前考虑最多的就是io难道不阻塞吗,后来才明白io的时候线程是0消耗的,完全处于等待状态。

所谓的单线程异步,正是合理分配了io的等待时间,让主线程去做其他事情,在主线程空闲的时候才来检查等待的任务有没有完成。总的来说,node适合io多,高并发的事,因为这些事情不必等待,也不必创建新的线程,而是分给别人去做,node只需要等待结果就好了。但它并不适合计算密集型的事情,因为当一个计算阻塞了主线程,就无法使下一个任务被轮询到,后面所有的任务都会被阻塞住。

时间: 2024-08-02 10:55:37

重回博客 谈一谈Node中的异步和单线程的相关文章

基于MEAN全栈架构的多用户博客系统(Angular2+Node+MongoDB)

基于MEAN全栈架构的多用户博客系统(Angular2+Node+MongoDB)课程学习地址:http://www.xuetuwuyou.com/course/223课程出自学途无忧网:http://www.xuetuwuyou.com 课程介绍一.课程简介MEAN是一个Javascript平台的现代Web开发框架总称,它是MongoDB + Express +AngularJS + NodeJS 四个框架的第一个字母组合.它与传统LAMP一样是一种全套开发工具的简称.本课程结合项目全面系统的

博客代码:iframe—网页中嵌入其他网页

iframe 是一个可以把另外一个网页嵌入到一个网页里的代码,非常有用.对于一个内容不错的网页,要方便地把它搬到自己的博客里,用这个代码最合适.而对于在新浪博客里不支持的一些网页效果和代码,可先把他们设置好,在支持他们的网站上使用,或上传到一个免费的网络空间或网络硬盘里,获取相应的网页地址,然后用 iframe嵌入到新浪博客里,非常好用! 一.固定位置的iframe代码: <DIV align=center><IFRAME src="http://weather.265.com

用flask开发个人博客(4)—— flask中4种全局变量

https://blog.csdn.net/hyman_c/article/details/53512109 一  current_app current_app代表当前的flask程序实例,使用时需要flask的程序上下文激活,我们以本专栏第一篇文章中写的test.py为例介绍下它的用法: 1.1 激活程序上下文 [python] view plain copy >>> from test import app >>> from flask import curren

写带有清晰图片的博客:如何将word中的图片复制到windows live writer保持大小不变--清晰度不变

写blog的习惯,先在word写了,复制到windows live writer,再发布到博客园.word中的文章,图片有缩放比例,复制到windows live writer后图片变得不清晰.除了一张一张 设置图片缩放比例为100%外,再复制到windows live writer.这样做太麻烦.就百度了下面的解决办法. word中图片小,复制出来的就不清楚,你需要设置图片大小为原始大小,复制到windows live writer图片才可能清楚. 还需要设置Windows live writ

如何在博客园的markdown编辑器中输入数学公式

如果您在mardown编辑器中不仅输入markdown,还想输入LateX数学公式,需要将LateX数学公式放在某个html标签之中,比如<p></p>,这样可以避免数学公式中的一些字符被markdown引擎处理. 比如下面的数学公式: \begin{align}\notag \dot{x}&=\mathbf{A}x+\mathbf{B}u\y&=\begin{bmatrix}1&0\0&1\end{bmatrix}x+\begin{bmatrix}

重回博客园

六年前注册的博客园账号,结果一篇文章没有写.六年前在博客园和CSDN之间,我选择了CSDN,但是CSDN的广告实在是太多,编写实在是太过于麻烦,最终还是在2019年的结束时刻打算离开.之前CSDN上的内容,也不打算搬家到这里了,这里就算是一个重新开始的地方吧. 标 2019-12-29 10:46:18 原文地址:https://www.cnblogs.com/WenLee/p/12114383.html

夺命雷公狗---node.js---19之项目的构建在node+express+mongo的博客项目4mongodb在项目中的基本引入

首先我们在命令行下先建立这个库: 然后我们在项目中引入mongodb的模块: var MongoClient = require('mongodb').MongoClient; var DB_STR = "mongodb://localhost:27017/blog";//这里的是在mongodb下建立的库 var ObjectId = require('mongodb').ObjectId; //这里主要是用来处理mongodb下id的 这样在项目中的mongodb即可成功引入了..

夺命雷公狗---node.js---20之项目的构建在node+express+mongo的博客项目5mongodb在项目中实现添加数据

我们上一步就引入了mongodb了,那么下一步就要开始写添加数据了,不过有个前提是先将表单的数据处理好: 最基本的这部现在已经成功了,因为最基本的这步就是先将表单处的提交方式和提交地址给处理好,这里和PHP的基本上是一样... 然后我们在后端处理下接收的内容.. 已经在后端成功接收到了,那么下一步就是直接让他入库了... /** * Created by leigood on 2016/8/31. */ var express = require('express'); var router =

(新人的第一篇博客)树状数组中lowbit(i)=i&amp;(-i) 的简单文字证明

第一次写博好激动o(≧v≦)o~~初一狗语无伦次还请多多指教 先了解树状数组http://blog.csdn.net/int64ago/article/details/7429868感觉这个前辈写的很好 但是里面提到的lowbit则是一笔带过,那么lowbit究竟是个什么鬼呢??? 首先明白一个概念,计算机中-i=(i的取反+1),也就是i的补码 而lowbit,就是求(树状数组中)一个数二进制的1的最低位,例如01100110,lowbit=00000010:再例如01100000,lowbi