浏览器的事件循环:
- 从上到下执行同步代码
- 执行过程中将宏任务和微任务添加至对应的队列中
- 同步代码执行完后执行微任务的回调
- 微任务执行完后,执行所有满足条件的宏任务的回调
- 注意:每执行完一个宏任务之后,立即检查微任务队列
- 循环时间操作
浏览器与nodejs的事件循环机制的区别:
1.任务队列数不同
浏览器只有2个任务队列,nodejs有6个事件队列
2. 微任务执行时机不同(后面的版本已经相同)
二者都是在同步代码执行完毕之后执行微任务队列,浏览器平台下,每当一个宏任务执行完毕后就清空微任务。nodejs平台在事件队列切换时会去清空微任务(后续版本已经和浏览器保存一致)
3.微任务优先级
浏览器事件循环中,微任务存放于事件队列,先进先出,nodejs中process.nextTick优先与promise.then
setTimeOut与setImmediate
两者是随机的,因为setTimeOut有一个时间延时不固定,如果放到io的回调当中,这时候是先执行setImmediate再执行setTimeOut,因为io回调在poll事件队列中,执行完poll接着就执行check事件队列,setImmediate在check事件队列中