nodejs教程之异步I/O


Posted in NodeJs onNovember 21, 2014

前言

在我映像中,异步最早出现与ajax,当时我还在搞.net,然后.net居然出了一个异步的控件......

虽然我最后知道了他不是异步的......然后,前端异步用得特别多,如果不是异步的程序,你都不好意思说是自己写的NodeJs是机遇javascript做出来的,

异步编程模型这一特点也被带了过来,异步有很多优点,但是对设计而言却是一个噩梦,异步会打乱时序,所以加大了设计困难,

但是异步对性能提升、对用户体验有了革命性的提高,所以NodeJS的 异步特性相当明显,今天我们就来简单学习

异步I/O

其实在操作系统层面上,只有两种I/O方式,堵塞和非堵塞

在堵塞模型中,应用程序需要等待I/O完成才返回结果,他的特点是调用后腰等待系统完成所有操作才行,这个会造成CPU的等待,而非堵塞调用后会马上返回

我初学是看的是一本书,但是这里感觉没有描述清楚,而且异步模型来说其实很大只是感受层面的提高,举一个简单的例子

我现在有一个搜索页和列表页两个单页应用的view,我搜索时候就是需要通过各种渠道搜索,深圳需要调用第三方,第三方再从具体渠道获取数据

这个时候当然很慢,我如果直接由A切入B在B在搞一个loading框什么的加载数据自然没有问题,但是现在问题是我A切换到B需要动画效果

这个就要求切换时候Bview渲染已经结束,至少不会再运到过程中获取数据开始渲染,所以此时异步可能就不那么好使,就是是异步请求数据,也是要数据获取才能加载页面

这个仍然是堵塞加载,这个在业务上是没有办法的

任何技术皆非完美,堵塞造成CPU等待浪费,非堵塞打乱逻辑不说可能还需要轮询以确认是否完成加载(曾经我使用轮询检测一个dom是否生成)

NodeJs采用的是事件循环机制,在进程启动时,Node会创建一个死循环,每执行一次循环体的过程就是一次Tick,每个Tick的过程就是才看是否有事件需要处理

如果有就取出事件相关,执行之,然后进入下一逻辑,没有就退出循环

每个Tick过程中,每个事件循环中有一个或者多个观察者,判断是否有事件要处理的过程就是向这些观察者询问是否需要处理这个事件

以我们html的事件模型为例

对html来说,其实他的每个DOM都是一个观察者,页面的DOM观察着我们的Web Page的变化,我们对一个DOM提供一个addEventListener后,便会对其注册一个回调函数,我们注册的事件会被放到一个“容器”对象中,这时只是注册,这些函数在满足条件后会被触发(页面变化时),相关的事件会从容器中取出执行

我们现在点击了一次页面上一个点,然后我们会由容器中取出click事件集合,我们会找到相关的dom,然后触发这些dom的回调函数

事件可能来自用户的点击或者数据变化,在Node中事件主要来自于网络请求,文件I/O,这些事件都会有对应的观察者,如文件观察者,网络观察者

这也是一个典型生产/消费模型,异步I/O ,网络请求提供事件生产,事件传递到各个观察者,观察者注册事件,事件循环负责取出事件然后执行事件

PS:以click为例,各个DOM观察者先注册事件,页面进程不停的监视页面,用户click页面生产事件,然后由容器中取出注册的click事件并执行,

一般的函数逻辑由我们控制:

 var forEach = function (list, callback) {

     for (var i = 0, len = list.length; i < len; i++) {

         callback(list[i], i, list);

     }

 }

异步的情况下回调函数不由开发者控制了,每次js发起调用会产生一个过渡产品请求对象

 fs.open = function (path, flags, mode, callback) {

   bingding.open(pathModule._makeLong(path), stringToFlags(flags), mode, callback);

 };

fs.open根据路径和参数打开一个文件,从而得到相关数据,内部调用了c++相关接口,过程中会产生一个中间对象,我们的所有状态会在其中......

PS:看了这么久,我感觉不太好

结语

以上就是关于nodejs中异步I/O的全部内容了,个人总结,如有遗漏或者错误,还请大家指出。

NodeJs 相关文章推荐
nodejs入门详解(多篇文章结合)
Mar 07 NodeJs
Nodejs极简入门教程(三):进程
Oct 27 NodeJs
async/await与promise(nodejs中的异步操作问题)
Mar 03 NodeJs
nodejs处理图片的中间件node-images详解
May 08 NodeJs
详解Nodejs之静态资源处理
Jun 05 NodeJs
详解nodejs的express如何自动生成项目框架
Jul 12 NodeJs
ubuntu编译nodejs所需的软件并安装
Sep 12 NodeJs
nodejs操作mongodb的填删改查模块的制作及引入实例
Jan 02 NodeJs
nodejs 简单实现动态html的方法
May 12 NodeJs
Nodejs处理异常操作示例
Dec 25 NodeJs
Nodejs中的require函数的具体使用方法
Apr 02 NodeJs
如何利用nodejs实现命令行游戏
Nov 24 NodeJs
nodejs教程之入门
Nov 21 #NodeJs
nodejs 提示‘xxx’ 不是内部或外部命令解决方法
Nov 20 #NodeJs
nodejs开发环境配置与使用
Nov 17 #NodeJs
Nodejs全栈框架StrongLoop推荐
Nov 09 #NodeJs
初始Nodejs
Nov 08 #NodeJs
Nodejs极简入门教程(三):进程
Oct 27 #NodeJs
Nodejs极简入门教程(二):定时器
Oct 25 #NodeJs
You might like
JQuery jsonp 使用示例代码
2009/08/12 Javascript
jQuery学习笔记[1] jQuery中的DOM操作
2010/12/03 Javascript
js showModalDialog参数的使用详解
2014/01/07 Javascript
JavaScript使用slice函数获取数组部分元素的方法
2015/04/06 Javascript
Highcharts入门之简介
2016/08/02 Javascript
AngularJS入门教程之REST和定制服务详解
2016/08/19 Javascript
vue.js动态数据绑定学习笔记
2017/05/19 Javascript
JavaScript正则表达式函数总结(常用)
2018/02/22 Javascript
浅谈angularJS2中的界面跳转方法
2018/08/31 Javascript
vue+canvas实现炫酷时钟效果的倒计时插件(已发布到npm的vue2插件,开箱即用)
2018/11/05 Javascript
vue输入节流,避免实时请求接口的实例代码
2019/10/30 Javascript
如何基于javascript实现贪吃蛇游戏
2020/02/09 Javascript
eslint+prettier统一代码风格的实现方法
2020/07/22 Javascript
vue 路由缓存 路由嵌套 路由守卫 监听物理返回操作
2020/08/06 Javascript
[02:08]2014DOTA2国际邀请赛 430专访:力争取得小组前二
2014/07/11 DOTA
将图片文件嵌入到wxpython代码中的实现方法
2014/08/11 Python
Python找出list中最常出现元素的方法
2016/06/14 Python
python中的计时器timeit的使用方法
2017/10/20 Python
Python3安装Scrapy的方法步骤
2017/11/23 Python
python 实现将txt文件多行合并为一行并将中间的空格去掉方法
2018/12/20 Python
python GUI库图形界面开发之PyQt5打印控件QPrinter详细使用方法与实例
2020/02/28 Python
Python3操作读写CSV文件使用包过程解析
2020/04/10 Python
关于python中remove的一些坑小结
2021/01/04 Python
HTML5去掉输入框type为number时的上下箭头的实现方法
2020/01/03 HTML / CSS
从当地商店送来的杂货:Instacart
2018/08/19 全球购物
机械工程师的岗位职责
2013/11/17 职场文书
公务员转正鉴定材料
2014/02/11 职场文书
表决心的诗句大全
2014/03/11 职场文书
大学生第一学年自我鉴定
2014/09/12 职场文书
2014大学生党员评议个人总结
2014/09/22 职场文书
幼儿园园务工作总结2015
2015/05/18 职场文书
退货证明模板
2015/06/23 职场文书
公司行政管理制度范本
2015/08/05 职场文书
Vue.js中v-for指令的用法介绍
2022/03/13 Vue.js
springboot用户数据修改的详细实现
2022/04/06 Java/Android
开发微信小程序之WXSS样式教程
2022/04/18 HTML / CSS