Node.js的非阻塞I/O、异步与事件驱动介绍

 更新时间:2022年06月24日 15:34:51   作者:小旭2021  
这篇文章介绍了Node.js的非阻塞I/O、异步与事件驱动,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

1、Node.js的单线程 非阻塞 I/O 事件驱动

在 Java、PHP 或者.net 等服务器端语言中,会为每一个客户端连接创建一个新的线程。
而每个线程需要耗费大约 2MB 内存。也就是说,理论上,一个 8GB 内存的服务器可以同时连接的最大用户数为 4000 个左右。要让 Web 应用程序支持更多的用户,就需要增加服务器的数量,而 Web 应用程序的硬件成本当然就上升了。
Node.js 不为每个客户连接创建一个新的线程, 而仅仅使用一个线程。当有用户连接了,就触发一个内部事件,通过非阻塞 I/O、事件驱动机制,让 Node.js 程序宏观上也是并行的。
使用 Node.js,一个 8GB 内存的服务器,可以同时处理超过 4 万用户的连接。

2、Node.js回调处理异步

//错误的写法:
function getData(){
    //模拟请求数据
    var result='';
    setTimeout
    (function(){
        result='这是请求到的数据'
        },200);
        return result;
}
console.log(getData());/*异步导致请求不到数据*/
     
//正确的处理异步:
function getData(callback){
    //模拟请求数据
    var result='';
    setTimeout
    (function(){
        result='这是请求到的数据';
        callback(result);
        },200);
    }
    getData(function(data){
    console.log(data);
})

3、Node.js events模块处理异步

Node.js 有多个内置的事件,我们可以通过引入 events 模块,并通过实例化 EventEmitter类来绑定和监听事件。

// 引入 events 模块
var events = require('events');
var EventEmitter=new events.EventEmitter(); /*实例化事件对象*/
EventEmitter.on
('toparent',function(){
console.log('接收到了广播事件');
})
setTimeout
(function(){
    console.log('广播');
    EventEmitter.emit
    ('toparent'); /*发送广播*/
},1000)

Node.js 事件循环

/*
 Node.js 事件循环:
 
 Node.js 是单进程单线程应用程序,但是通过事件和回调支持并发,所以性能非常高。
 
 Node.js 的每一个 API 都是异步的,并作为一个独立线程运行,使用异步函数调用,并处理并发。
 
 Node.js 有多个内置的事件,我们可以通过引入 events 模块,并通过实例化 EventEmitter 类来绑定和监听事件,
 
 */
 
// 引入 events 模块
var events = require('events');
 
var EventEmitter = new events.EventEmitter();
 
//监听to_mime的广播
EventEmitter.on('to_mime', function (data) {
  console.log(data, '接收to_mime的数据');
})
 
//监听to_parent的广播
EventEmitter.on('to_parent', function (data) {
  console.log(data, '接收to_parent的数据');
  //广播to_mime事件
  EventEmitter.emit('to_mime', '发送to_mime的数据')
})
 
setTimeout(function () {
  console.log('开始广播...');
  //广播to_parent事件
  EventEmitter.emit('to_parent', '发送to_parent的数据')
}, 1000);

执行结果

开始广播...
发送to_parent的数据 接收to_parent的数据
发送to_mime的数据 接收to_mime的数据

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • 深入理解Node.js 事件循环和回调函数

    深入理解Node.js 事件循环和回调函数

    这篇文章主要介绍了深入理解Node.js 事件循环和回调函数,详细的介绍Node.js 事件循环和Node.js回调函数,需要学习的可以参考一下。
    2016-11-11
  • Nodejs使用dgram模块创建UDP服务详解

    Nodejs使用dgram模块创建UDP服务详解

    这篇文章主要为大家介绍了Nodejs使用dgram模块创建UDP服务详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • npm报错:request to httpsregistry.npm.taobao.org failed, reason certificate has expired的解决方案

    npm报错:request to httpsregistry.npm.taobao.org 

    这篇文章主要介绍了npm报错:request to httpsregistry.npm.taobao.org failed, reason certificate has expired的解决方案,文中有详细的解决方案,需要的朋友可以参考下
    2024-03-03
  • websocket实现Vue 3和Node.js之间的实时消息推送

    websocket实现Vue 3和Node.js之间的实时消息推送

    使用 WebSocket 实现实时消息推送是一种高效的方式,可以在客户端和服务器之间建立长连接,实现低延迟的双向通信,以下是一个简单的示例,展示如何在前端使用 Vue 3 和后端使用 Node.js 搭建一个 WebSocket 实现实时消息推送的应用
    2024-06-06
  • 关于Sequelize连接查询时inlude中model和association的区别详解

    关于Sequelize连接查询时inlude中model和association的区别详解

    这篇文章主要介绍了关于Sequelize连接查询时inlude中model与association的区别,文中介绍的很详细,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-02-02
  • Node.js开源应用框架HapiJS介绍

    Node.js开源应用框架HapiJS介绍

    这篇文章主要介绍了Node.js开源应用框架HapiJS介绍,本文讲解了HapiJS介绍、HapiJS安装和项目配置和开发实例等内容,需要的朋友可以参考下
    2015-01-01
  • autojs的nodejs打包成品app经验分享

    autojs的nodejs打包成品app经验分享

    这篇文章主要为大家介绍了autojs的nodejs打包成品app经验分享,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01
  • nodeJs的安装与npm全局环境变量的配置详解

    nodeJs的安装与npm全局环境变量的配置详解

    这篇文章主要介绍了nodeJs的安装与npm全局环境变量的配置详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-01-01
  • nodejs初始化init的示例代码

    nodejs初始化init的示例代码

    今天小编就为大家分享一篇nodejs初始化init的示例代码,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-10-10
  • nodejs实现一个自定义的require方法的详细流程

    nodejs实现一个自定义的require方法的详细流程

    大家对nodejs中的require方法应该不会陌生,这个方法可以用来导入nodejs的内置模块,自定义模块,第三方模块等,使用频率非常高,那么这个方法内部是如何实现的呢?本篇文章就是从头到尾拆分实现流程,最终实现一个自定义的require方法,需要的朋友可以参考下
    2025-03-03

最新评论