zoukankan      html  css  js  c++  java
  • 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('程序执行完毕。');
  • 相关阅读:
    Otter详解
    为什么要使用Netty
    haproxy实现mysql集群负载均衡
    Mysql主从复制
    java编程思想读书笔记三(HashMap详解)
    代码界的石器时代
    补码的产生与应用
    java编程思想读书笔记二(对象的创建)
    java编程思想读书笔记一(面向对象)
    Apache VFS
  • 原文地址:https://www.cnblogs.com/whuls/p/9356519.html
Copyright © 2011-2022 走看看