浏览器事件循环与node事件循环

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了浏览器事件循环与node事件循环相关的知识,希望对你有一定的参考价值。

参考技术A

当上面的线程发生了某些事请,如果该线程发现,这件事情有处理程序,它会将该处理程序加入事件队列。当JS引擎发现,执行栈中已经 没有了任何内容 后,会将事件队列中的第一个函数加入到执行栈中执行。

事件队列在不同的宿主环境中有所差异,大部分宿主环境会将事件队列进行细分。在浏览器中,事件队列分为两种:

举例:

node环境,有很多队列,主要有以下三个,事件循环时,会挨个检查。

举例:

主程序执行,打印"main",然后开始事件循环。
检查timers队列,没有回调,进入下一阶段
检查poll队列,没有回调,别的队列有回调,进入下一阶段
检查check队列,输出"check"
第二圈:
检查timers队列,没有回调,进入下一阶段
检查poll队列,没有回调,等其他队列出现回调。3s时间到,timers队列出现回调函数,进入下一阶段。
检查check队列,没有回调
第三圈:
检查timers队列,输出"timers"
检查poll队列,没有回调,并且没有任何值得等待的东西了(没有监听用户请求,没有计时器等等),进入下一阶段
检查check队列,没有回调
事件循环结束!

除了上面过程,再补充两点

扩展:实际上timers不是一个队列,而是一个计时器一个计时器的查看它时间到没到(有运算,所以运行会慢),时间到了就把回调拉过来。而check可以当成一个数组,里面的回调直接运行。所以 setImmediate 运行效率比 setTimeout高 (当然开定时器的过程也会有一定的时间消耗)。

下面程序可以对比setTimeout 和 setImmediate 运行效率

浏览器和Node的事件循环

事件循环

事件循环解析

进程:操作系统管理程序的一种方式。

线程:操作系统能够进行调度的最小单位。

JavaScript代码的执行是单线程执行的,但是为什么碰到异步函数却不会阻塞后续代码的继续执行呢?这就用到了事件循环

定义:事件循环是JavaScript代码和浏览器或者Node之间的桥梁。

浏览器是多进程多线程的,在JavaScript代码执行时,知道在内存内维护着执行上下文栈(函数调用栈),碰到异步代码之所以不会阻塞后续代码的执行,是因为异步函数回调交给了浏览器或者Node的另一个线程,到达一定的时间会将对应

以上是关于浏览器事件循环与node事件循环的主要内容,如果未能解决你的问题,请参考以下文章

js 事件循环消息队列和微任务宏任务

浏览器和Node的事件循环

浏览器和Node的事件循环

在nodejs中事件循环分析

浏览器和Node的事件循环

浏览器和Node的事件循环