Nodejs学习笔记(2) 阻塞/非阻塞实例 与 Nodejs事件

 

 


1. Node.js异步编程的特点

参考资料:http://www.runoob.com/nodejs/nodejs-callback.html

 Node.js 异步编程的直接体现就是回调。

 异步编程依托于回调来实现,但不能说使用了回调后程序就异步化了。

 回调函数在完成任务后就会被调用,Node 使用了大量的回调函数,Node 所有 API 都支持回调函数。

 例如,我们可以一边读取文件,一边执行其他命令,在文件读取完成后,我们将文件内容作为回调函数的参数返回。这样在执行代码时就没有阻塞或等待文件 I/O 操作。这就大大提高了 Node.js 的性能,可以处理大量的并发请求。

 回调函数一般作为参数的最后一个参数出现

2. 阻塞与非阻塞的实例

参考资料:http://www.runoob.com/nodejs/nodejs-callback.html

2.1 阻塞代码实例

创建一个文件 input.txt ,内容如下:

菜鸟教程官网地址:www.runoob.com

创建 main.js 文件, 代码如下:

var fs = require("fs");

var data = fs.readFileSync('input.txt');

console.log(data.toString());
console.log("程序执行结束!");

以上代码执行结果如下:

$ node main.js
菜鸟教程官网地址:www.runoob.com

程序执行结束!

2.2 非阻塞代码实例

创建一个文件 input.txt ,内容如下:

菜鸟教程官网地址:www.runoob.com

创建 main.js 文件, 代码如下:

var fs = require("fs");

fs.readFile('input.txt', function (err, data) {
    if (err) return console.error(err);
    console.log(data.toString());
});

console.log("程序执行结束!");

以上代码执行结果如下:

$ node main.js
程序执行结束!
菜鸟教程官网地址:www.runoob.com

3. Node.js的事件驱动

参考资料:http://www.runoob.com/nodejs/nodejs-event-loop.html

 Node.js 基本上所有的事件机制都是用设计模式中观察者模式实现。

 Node.js 单线程类似进入一个while(true)的事件循环,直到没有事件观察者退出,每个异步事件都生成一个事件观察者,如果有事件发生就调用该回调函数。

 Node.js 的事件驱动程序需要引用events模块, 通过实例化EventEmitter类来绑定和监听事件。

4. 事件循环实例

参考资料:http://www.runoob.com/nodejs/nodejs-event-loop.html

/**
 * 依赖和实例化
 */
// 引入 events 模块
var events = require('events');
// 实例化 eventEmitter 类(事件触发器),用来绑定和监听事件
var eventEmitter = new events.EventEmitter();

/**
 * eventEmitter.on() 绑定事件
 * eventEmitter.emit() 触发事件
 * ps: 事件触发必须写在在事件绑定之后,且应该注意事件的名称一致
 *     使用程序绑定事件时,应该创建代表函数的变量,使用该变量进行绑定
 */
// 1. 使用程序绑定事件
var connectHandler = function connected() { //创建程序
    console.log('连接成功。');
    eventEmitter.emit('data_received'); // 触发 data_received 事件
}
eventEmitter.on('connection', connectHandler); // 绑定 connection 事件处理程序

// 2. 使用匿名函数绑定事件
eventEmitter.on('data_received', function(){
    console.log('数据接收成功。');
});

// 3. 触发 connection 事件
eventEmitter.emit('connection');

/**
 * 结束
 */
console.log('程序执行完毕。');
posted @ 2018-07-19 21:30  whuls  阅读(805)  评论(0编辑  收藏  举报