js运行机制

单线程

js在同一时间只能做一件事

任务

  • 同步任务:在主线程上执行的任务
  • 异步任务:被主线程挂起的任务

运行机制

  • 同步和异步任务分别进入不同的执行"场所",同步的进入主线程,异步的进入Event Table并注册函数。
  • 当指定的事情完成时,Event Table会将这个函数移入Event Queue。
  • 主线程内的任务执行完毕为空,会去Event Queue读取对应的函数,进入主线程执行。


    运行机制1
运行机制2

宏任务/微任务

  • 宏任务:script(全局任务), setTimeout, setInterval, setImmediate, I/O, UI rendering.

  • 微任务:process.nextTick, Promise, Object.observer, MutationObserver.

    js异步有一个机制,就是遇到宏任务,先执行宏任务,将宏任务放入eventqueue,然后再执行微任务,将微任务放入eventqueue,这两个queue不是一个queue。当你往外拿的时候先从微任务里拿这个回调函数,然后再从宏任务的queue上拿宏任务的回调函数

测试题

setTimeout(function(){
    console.log('1')
});

new Promise(function(resolve){
    console.log('2');
}).then(function(){
    console.log('3')
});

console.log('4');

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容