vlambda博客
学习文章列表

H5 一文摸透EventLoop机制


我们在面试时,会高频率听到一些js的底层词汇,例如:EventLoop,宏任务,微任务,那么他们三个到底是什么?接下来,咱们就以最通俗易懂的方式, 一文摸透EventLoop及宏任务,微任务。


H5 一文摸透EventLoop机制


首先,先看看EventLoop:

Event Loop 是一个很重要的概念,指的是计算机系统的一种运行机制。JavaScript语言就采用这种机制,来解决单线程运行带来的一些问题。

想要理解Event Loop,就要从程序的运行模式讲起。一个程序运行起来后(比如一个js程序),就叫做"进程"(process),一般情况下,一个进程一次只能执行一个任务。


好,现在问题来了,如果遇到多个任务要执行,我们可以怎么办呢?

最常用的不外乎两种方法:

(1)排队。因为一个进程一次只能执行一个任务,只好等前面的任务执行完了,再执行后面的任务。

(2)新建进程。为每一个任务在多建立一个单独的进程,多个进程同时可执行多任务。

而咱们JavaScript,它是一种单线程语言,所有任务都在一个线程上完成,即采用上面的第一种方法。但,这种排队的方式肯定会有问题,一旦遇到大量任务或者遇到一个耗时的任务,网页就会出现"时常假死",因为JavaScript只有一个线程,没有额外线程来做其他任务。

详见下图:

        

H5 一文摸透EventLoop机制


JavaScript语言的设计者意识到,这时主线程完全可以不管IO等需要大量等待的任务,先运行排在后面的任务。等到IO等任务返回了结果,再回过头,把挂起的任务继续执行下去。


于是,所有任务可以分成两种,一种是同步任务(synchronous),另一种是异步任务(asynchronous)。同步任务指的是,在主线程上排队执行的任务,只有前一个任务执行完毕,才能执行后一个任务;异步任务指的是,不进入主线程、而进入"任务队列"(task queue)的任务,只有"任务队列"通知主线程,某个异步任务可以执行了,该任务才会进入主线程执行。

具体来说,异步执行的运行机制如下。(同步执行也是如此,因为它可以被视为没有异步任务的异步执行。)


(1)所有同步任务都在主线程上执行,形成一个执行栈(execution context stack)。


(2)主线程之外,还存在一个"任务队列"(task queue)。只要异步任务有了运行结果,就在"任务队列"之中放置一个事件。


(3)一旦"执行栈"中的所有同步任务执行完毕,系统就会读取"任务队列",看看里面有哪些事件。那些对应的异步任务,于是结束等待状态,进入执行栈,开始执行。


(4)主线程不断重复上面的第三步。


主线程执行完所有同步任务,从"任务队列"中读取事件,这个过程是循环不断的,所以整个的这种运行机制又称为Event Loop(事件循环)

一句话小结JavaScript的EventLoop:JS会把所有同步代码放主线程执行,除主线程外还有一个异步任务队列,所有异步均被放入异步队列。主线程先执行完所有同步代码,就会不断循环读取异步任务队列,发现有完成的异步任务,则开始执行。

H5 一文摸透EventLoop机制




H5 一文摸透EventLoop机制
源码时代,专注于IT职业教育
让每一位学员高薪就业
想要学习IT课程?
为你们附上:
 最新开班时间 
H5 一文摸透EventLoop机制H5 一文摸透EventLoop机制

点击阅读原文既可免费预约14天试听课资格!