1.如何进行nodejs异步编程
我建设玩一下AJAX,是希望您体验一下异步,并不是希望您了解AJAX这机制的实现方法,因为AJAX是一个特别典型且简单的异步场景,比如:
执行某个函数 ->; 执行语句A,B,C,D ->; 在D语句发起异步请求,同时向引擎注册一个回调事件 ->; 执行E,F,G ->;退出函数块 ,引擎Loop。Loop。Loop,此时异步的请求得到了Response,之前注册的回调被执行。
实际上Node.js主要是为了应对主流web app存在大量I/O等待而CPU闲置的场景所衍生的解决方案,而在架构上,它的后端有一个底层的worker封装,每当你有一个诸如addUser这样的I/O操作时,它们都会被交由worker去执行从而达到让出尽快让出当前函数的执行权的目的,在向引擎注册完回调后,内部会通过事件轮询去检查该I/O事件的句柄,当句柄显示该事件操作完成后,则注册的回调则被执行。
所以,假设有人(按题设,简化一下场景,有且只有2个人)同时请求addUser(A)和userList(B),B的请求会在执行完A的请求内部所有同步代码后被执行,而哪怕worker此时仍然在进行addUser 这一 I/O操作,用户B也并不会被引擎挂起或者等待。这就是为什么Node.js单节点却一样可以拥有高负载能力的原因。
至于什么样的代码是异步的,你看看node文档里fs模块的使用方法就知道了,大概的形式就是如下这种。
module.method( args [,callback] )
当然还有一种比较极端的情况,假设您使用的数据库是山寨的,驱动是基于同步实现的,那么B就该等多久等多久把,树荫底下喝杯茶,下个棋,和后面的C,D,E,F,G打个招呼呗~~~
我推荐您先去玩一下前端的AJAX了解一下 异步编程方式,体验一下异步的“感觉”,然后看一本叫《JavaScript异步编程》的书。
Node.js 是一款基于Event-driven的模型构建的Framework,它典型的特征就是通过内置的事件轮询来调度事件,通常来说node.js的数据库驱动都是基于异步实现的,所以在实际情况中,A提交博客和B注册用户这两个请求是可以同时由Node.js 来handle,并按照实际操作的处理事件分别调度给予浏览器响应。
当然,假设您在业务代码里写了一个耗时很久的同步代码(比如直接写一个while(true)的loop,Node就死了),由于JavaScript本身单线程的限制,所以整个App就会被block住,后续的事件/程序只有等到该段代码执行完成之后才会被处理,这也是为什么我们通常不建议在Node.js层做大规模计算(JS本身的计算效率太低,会导致Node吞吐量会大大降低),而倾向由C++的拓展去实现。
2.如何进行nodejs异步编程
我建设玩一下AJAX,是希望您体验一下异步,并不是希望您了解AJAX这机制的实现方法,因为AJAX是一个特别典型且简单的异步场景,比如:执行某个函数 -> 执行语句A,B,C,D -> 在D语句发起异步请求,同时向引擎注册一个回调事件 -> 执行E,F,G ->退出函数块 ,引擎Loop。
Loop。Loop,此时异步的请求得到了Response,之前注册的回调被执行。
实际上Node.js主要是为了应对主流web app存在大量I/O等待而CPU闲置的场景所衍生的解决方案,而在架构上,它的后端有一个底层的worker封装,每当你有一个诸如addUser这样的I/O操作时,它们都会被交由worker去执行从而达到让出尽快让出当前函数的执行权的目的,在向引擎注册完回调后,内部会通过事件轮询去检查该I/O事件的句柄,当句柄显示该事件操作完成后,则注册的回调则被执行。所以,假设有人(按题设,简化一下场景,有且只有2个人)同时请求addUser(A)和userList(B),B的请求会在执行完A的请求内部所有同步代码后被执行,而哪怕worker此时仍然在进行addUser 这一 I/O操作,用户B也并不会被引擎挂起或者等待。
这就是为什么Node.js单节点却一样可以拥有高负载能力的原因。至于什么样的代码是异步的,你看看node文档里fs模块的使用方法就知道了,大概的形式就是如下这种。
module.method( args [,callback] )当然还有一种比较极端的情况,假设您使用的数据库是山寨的,驱动是基于同步实现的,那么B就该等多久等多久把,树荫底下喝杯茶,下个棋,和后面的C,D,E,F,G打个招呼呗~~~我推荐您先去玩一下前端的AJAX了解一下 异步编程方式,体验一下异步的“感觉”,然后看一本关于java的书。Node.js 是一款基于Event-driven的模型构建的Framework,它典型的特征就是通过内置的事件轮询来调度事件,通常来说node.js的数据库驱动都是基于异步实现的,所以在实际情况中,A提交博客和B注册用户这两个请求是可以同时由Node.js 来handle,并按照实际操作的处理事件分别调度给予浏览器响应。
当然,假设您在业务代码里写了一个耗时很久的同步代码(比如直接写一个while(true)的loop,Node就死了),由于JavaScript本身单线程的限制,所以整个App就会被block住,后续的事件/程序只有等到该段代码执行完成之后才会被处理,这也是为什么我们通常不建议在Node.js层做大规模计算(JS本身的计算效率太低,会导致Node吞吐量会大大降低),而倾向由C++的拓展去实现。
3.nodejs 异步应该如何处理
结果当然是空数组因为异步,会先执行console.log(),要想得到只能把console.log()写在回调函数里。回调函数是当函数执行结束后才会调用的。
var fileArr = [];
//读取文件目录
fs.readdir(lastest_pages_path,function(err,files){
if(err){
console.log(err);
return;
}
fileArr.push(files);
console.log(fileArr);
}
4.如何优雅的处理Nodejs中的异步回调
Nodejs最大的亮点就在于事件驱动, 非阻塞I/O 模型,这使得Nodejs具有很强的并发处理能力,非常适合编写网络应用。
在Nodejs中大部分的I/O操作几乎都是异步的,也就是我们处理I/O的操作结果基本上都需要在回调函数中处理,比如下面的这个读取文件内容的函数:fs.readFile('/etc/passwd', function (err, data) { if (err) throw err; console.log(data);});那,我们读取两个文件,将这两个文件的内容合并到一起处理怎么办呢?大多数接触js不久的人可能会这么干:fs.readFile('/etc/passwd', function (err, data) { if (err) throw err; fs.readFile('/etc/passwd2', function (err, data2) { if (err) throw err; // 在这里处理data和data2的数据 });});那要是处理多个类似的场景,岂不是回调函数一层层的嵌套啊,这就是大家常说的回调金字塔或回调地狱(-js.com/article/1687.cn/article/6260。
转载请注明出处育才学习网 » nodejs异步怎么写