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');

你可能感兴趣的:(js运行机制)