回调函数
Node.js 异步编程的直接体现就是回调。
Node 使用了大量的回调函数,Node 所有 API 都支持回调函数。
这样可以提高node 的性能,处理大量的并发请求。
回调函数一般作为函数的最后一个参数出现。
1.项目根目录创建 test.js
var fs = require('fs');
var data = fs.readFileSync('input.txt');
console.log(data.toString());//转化成字符串
console.log('finished');
fs:文件系统,属于nodejs中的一个模块
fs.readFileSync(path[, options])
用于读取文件信息
-
path
<string> | <Buffer> | <URL> | <integer> 文件名或文件描述符。 -
options
<Object> | <string> -
encoding
<string> | <null> 默认为null
。 -
flag
<string> 详见支持的文件系统flag。默认为'r'
。 - 返回: <string> | <Buffer>
2.项目更目录创建test2.js
var fs = require('fs');
fs.readFile('input.txt',(err,data)=>{
if(err){
console.error(err)
}
console.log(data.toString());
})
console.log('finished');
以上2者的区别是使用的API不同,readFileSync 与 readFile
readFileSync:同步读取文件信息
readFile:异步读取文件信息(异步读取文件的时候由操作系统在后台进行读取,不会阻碍下面的代码执行。同步读取的时候会阻碍下面的代码执行。)
事件循环
Nodejs是单进程单线程的应用程序,但是V8引擎提供的大量异步接口,这些接口可以处理大量的并发,所以性能很高。nodejs几乎每一个api都支持回调函数。
1.事件驱动程序
nodejs使用事件驱动模型,当web server接收到请求,会先把他关闭然后进行处理。
然后去服务接收下一个请求。
当之前处理的请求完成后,再将它放回到队列中,
当队列中它到达开头的位置时,再将结果返回给用户。
模型非常高效,因为当 web server 可以一直接收请求并且不需要等待任何读写操作,这些操作都是将它关闭后另外处理的。
Node.js 有多个内置的事件,我们可以通过引入 events 模块,并通过实例化 EventEmitter 类来绑定和监听事件。
2.实例demo
var events = require('events');//引用事件触发器
var eventEmitter = new events.EventEmitter();//创建 eventEmitter 对象
//创建一个函数
var connectHandler = function connected(){
console.log('连接成功');
// 触发 data_received事件
eventEmitter.emit('data_received');
}
//绑定事件处理函数,监听 connection 事件,该事件执行的时候,回调connectHandler
eventEmitter.on('connection',connectHandler);
//使用匿名海曙绑定 data_received 事件
eventEmitter.on('data_received',()=>{
console.log('数据接收成功');
});
// 触发 connection 事件
eventEmitter.emit('connection');
console.log('程序执行完毕');
回顾:
执行顺序:
1️⃣eventEmitter.emit('connection');
触发connection
2️⃣又因为eventEmitter.on('connection',connectHandler);
监听了connection,此时回调执行connectHandler
3️⃣执行 connectHandler 则打印 连接成功,并且函数内部调用 data_received
4️⃣eventEmitter.on('data_received',()=>{....
这里又监听了data_received,因此打印 数据接收成功。
5️⃣最后打印 程序执行完毕