Bootstrap

什么是事件循环?

JavaScript是一种单线程的编程语言,同一时间只能做一件事,所有的任务都需要排队依次完成。

单线程会导致很多任务需要排队,只有一个任务执行完才能执行后一个任务。如果某个执行时间太长,就容易造成阻塞;为了解决这一问题,JavaScript引入了事件循环机制。

什么是事件循环呢?

Javascript单线程任务被分为同步任务异步任务

1. 同步任务:立即执行的任务,在主线程上排队执行,前一个任务执行完毕,才能执行后一个任务;

2. 异步任务:异步执行的任务,不进入主线程, 而是在异步任务有了结果后,将注册的回调函数放入任务队列中。(进入任务队列的任务,只有任务队列通知主线程,某个异步任务可以执行了,该任务才会进入主线程执行)

异步任务又分为宏任务和微任务。所有同步任务都在主线程上执行,形成一个函数调用栈(执行栈),而异步则先放到任务队列里,任务队列又分为宏任务微任务

微任务执行时的时机要比宏任务要早。

宏任务:setTimeout,setInterval,Ajax,DOM事件

微任务:Promise, async/await

描述执行顺序:

1.先执行同步任务。

2.遇到异步宏任务则将异步宏任务放入宏任务队列中。

3.遇到异步微任务则将异步微任务放入微任务队列中。

4.当所有同步代码执行完毕后,再将异步微任务从队列中调入主线程执行。

5.微任务执行完毕后再将异步宏任务从队列中调入主线程执行。

6.一直循环直至所有任务执行完毕。

;