Node.js学习笔记之事件循环和callback

简介: 简单叙述一下什么是事件循环还是拿之前的餐厅来举例,我们去点了个番茄炒蛋,服务生告诉后厨做一个番茄炒蛋,张三也去了餐厅,点了个麻辣小龙虾,服务生又告诉后厨做一份麻辣小龙虾,小李也去了,点了个蛋炒饭。

简单叙述一下什么是事件循环

还是拿之前的餐厅来举例,我们去点了个番茄炒蛋,服务生告诉后厨做一个番茄炒蛋,张三也去了餐厅,点了个麻辣小龙虾,服务生又告诉后厨做一份麻辣小龙虾,小李也去了,点了个蛋炒饭。

解析一下这个情景,餐厅是一个事件循环,其中我们的点餐叫做线程。服务生第一个把我要的番茄炒蛋端过来了,于是我的线程结束了,因为麻辣小龙虾做的慢,蛋炒饭做完了,服务生又给小李端上来了蛋炒饭,小李虽然是后来的,但是他的过程要比张三快,最后小龙虾好了,服务生给张三端上来小龙虾,至此三个线程都结束了。

用代码实现一个简易版的事件循环

const eventloop = {
    // 事件队列
    queue: [],
    loop(){
        while(this.queue.length){
            // 如果有事件就进行处理
            var callback = this.queue.shift();
            callback();
        }
        // 每50毫秒会检测一下事件
        setTimeout(this.loop.bind(this),50);
    },
    // 添加事件
    add(callback){
        this.queue.push(callback);
    }
}

eventloop.loop();

// 分别在 500毫秒跟800毫秒,往队列中加入两个事件
setTimeout(()=>{
    eventloop.add(function(){
        console.log('第一个');
    })
},500)
setTimeout(()=>{
    eventloop.add(function(){
        console.log('第二个');
    })
},800)

有话说

当然,在真实情况中会比这复杂的多,不会每50毫秒去检测一次,要快的多,添加的事件也不会只有回调函数,例如一些文件读写操作等。我们的事件队列可能还会有文件处理队列,定时操作队列等多种不同的队列。

callback

  • 回调函数格式规范

    • error-first callback
    • Node-style callback
  • 第一个参数是error,后面的参数才是结果

场景

你在面试之后,面试官让你回去等消息。

结果:

  • 不过

ps:面试过了我们就笑一下,面试不过我们就哭!

先上代码:

    interview(function(err){
        if(err){
            return console.log('cry at 1st');
        }
        interview(function(err){
            if(err){
                return console.log('cry at 2nd');
            }
            interview(function(err){
                if(err){
                    return console.log('cry at 3rd');
                }
                console.log('smile');
            });
        })
    })
function interview(callback) {
    setTimeout(()=>{
        if(Math.random() < 0.8){
            callback('success');
        } else {
            callback( new Error('fail')); 
        }
    },1000)
}

这是一个正常的面试流程:

  • 一面------>挂掉
  • 一面------->二面------>挂掉
  • 一面------->二面------>三面------>挂掉
  • 一面------->二面------>三面------>入职

看是看着这种嵌套是真的恶心,这种问题就叫做回调地狱,这也是比较容易出现在异步中的问题,另外一个问题就是并发了,我们用同时面试两家公司为例,毕竟这也是正常能够出现的现象。

这时候张三说了:我会写我会写,还是上面代码的理念,我加一个计数器,面试过了就count++,count为2的时候,就证明两个面试都过了,这样可以用if判断并写一些逻辑。

简单描述一下张三的代码结构:

var count = 0;
interview(function (err) {
    if(err){
        return console.log('cry');
    }
    count++
})
interview(function (err) {
    if(err){
        return console.log('cry');
    }
    count++
    if(count){
        
    }
})

大致是这个样子,看起来很麻烦。这个问题就涉及到异步流程控制问题,也就是异步的并发,针对这个问题,我们强大的社区当然是有解决方案的。

  • npm包:async.js
  • thunk编程方式
现在好像这两个方式都不用了😭
相关文章
|
2月前
|
设计模式 JavaScript API
Node.js 事件循环
Node.js 事件循环
22 2
|
3月前
|
前端开发 JavaScript UED
深入理解JavaScript中的事件循环机制
JavaScript中的事件循环机制是其异步编程的核心,深入理解该机制对于开发高效、流畅的前端应用至关重要。本文将介绍事件循环的工作原理、常见的事件循环模型,以及如何利用这些知识解决前端开发中的常见问题。
|
3月前
|
Web App开发 JavaScript 前端开发
浏览器与Node.js事件循环:异同点及工作原理
浏览器与Node.js事件循环:异同点及工作原理
|
20天前
|
JavaScript API 调度
深入理解Node.js事件循环及其在后端开发中的应用
【7月更文挑战第30天】本文旨在通过深入浅出的方式,解析Node.js事件循环机制的工作原理及其在后端开发中的实际应用。我们将从事件循环的基本概念出发,逐步探讨其与异步I/O操作的关系,以及如何利用事件循环优化后端性能和处理高并发请求。文章将结合实际案例,为读者提供清晰的认识和应用策略。
|
2月前
|
存储 前端开发 JavaScript
JavaScript 事件循环的详细描述
【6月更文挑战第15天】JavaScript事件循环是单线程非阻塞I/O的关键,通过调用栈跟踪同步函数,任务队列存储异步任务,事件循环在调用栈空时从队列取任务执行。当遇到异步操作,回调函数进入队列,同步代码执行完后开始事件循环,检查并执行任务。微任务如Promise回调在每个宏任务结束时执行,确保不阻塞主线程,优化用户体验。
32 6
|
1月前
|
JavaScript Java 测试技术
基于springboot+vue.js+uniapp的云的学习笔记系统附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的云的学习笔记系统附带文章源码部署视频讲解等
26 0
|
1月前
|
JavaScript
js【详解】event loop(事件循环/事件轮询)
js【详解】event loop(事件循环/事件轮询)
29 0
|
3月前
|
开发框架 JavaScript 前端开发
JavaScript的事件循环机制是其非阻塞I/O的关键
【5月更文挑战第13天】JavaScript的事件循环机制是其非阻塞I/O的关键,由调用栈、事件队列和Web APIs构成。当异步操作完成,回调函数进入事件队列,待调用栈空时,事件循环取队列中的任务执行。在游戏开发中,事件循环驱动游戏循环更新,包括输入处理、游戏逻辑更新和渲染。示例代码展示了如何模拟游戏循环,实际开发中则常使用游戏框架进行抽象处理。
60 4
|
3月前
|
前端开发 JavaScript UED
JavaScript 的事件循环机制是其非阻塞 I/O 模型的核心
【5月更文挑战第9天】JavaScript的事件循环机制是其非阻塞I/O的关键,通过单线程的调用栈和任务队列处理异步任务。当调用栈空时,事件循环从任务队列取出一个任务执行,形成循环。异步操作完成后,回调函数进入任务队列,等待被事件循环处理。微任务如Promise回调在每个宏任务结束后执行。此机制确保JavaScript能高效处理异步操作,不阻塞主线程,提供流畅的用户体验。
37 2
|
3月前
|
消息中间件 存储 前端开发
理解JavaScript事件循环机制
理解JavaScript事件循环机制
27 1