浏览器事件循环与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事件循环的主要内容,如果未能解决你的问题,请参考以下文章