JavaScript运行时

  |  
 阅读次数

Promise Async/await 运行时机制

故事要从一道今日头条的笔试题说起~

题目来源:半年工作经验今日头条和美团面试题面经分享!!!!!

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
async function async1(){

console.log('async1 start')

await async2()

console.log('async1 end')

}

async function async2(){

console.log('async2')

}

console.log('script start')

setTimeout(function(){

console.log('setTimeout')

},0)

async1();

new Promise(function(resolve){

console.log('promise1')

resolve();

}).then(function(){

console.log('promise2')

})

console.log('script end')

求打印结果?

题目考 js 事件循环和回调队列~ 假设看客已经了解 setTimeout宏任务会在最后执行的前提(因为它不是今天要讨论的重点),主要讨论 promiseasyncawait 之间的关系。

个人思路:

1
2
3
4
5
6
1. console.log('script start')
2. console.log('async1 start')
async2 开始执行
console.log('async1 end') 等待 async2
3.
4.


JS 执行机制异步回调( setTimeout / setInterval / Promise )

javascript执行机制 代码执行顺序 函数生命周期加载等类似问题 都与javascript执行机制相关。

  1. 关于javascript
    javascript是一门单线程语言,在最新的HTML5中提出了Web-Worker,但javascript是单线程这一核心仍未改变。所以一切javascript版的"多线程"都是用单线程模拟出来的,一切javascript多线程都是纸老虎
  2. javascript事件循环
    既然js是单线程,排队 办理业务, js任务也要一个一个顺序执行。如 任务耗时过长,后一个任务必须等着。浏览新闻 超清图片加载慢 需要异步加载 任务分为两类:
  • 同步任务
  • 异步任务
    打开网站,网页渲染 过程 就是 同步任务,比如 页面骨架页面元素渲染。而 加载 图片 音乐之类占用资源大耗时久的任务,就是异步任务。关于这部分有严格的文字定义,但本文的目的是用最小的学习成本彻底弄懂执行机制,所以我们用导图来说明:
    js事件循环机制
    导图要表达的内容用文字来表述的话:

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

上述过程会不断重复,也就是常说的Event Loop(事件循环)。

我们不禁要问了,那怎么知道主线程执行栈为空啊?js引擎存在monitoring process进程,会持续不断检查主线程执行栈是否为空,一旦为空,就会去Event Queue那里检查是否有等待被调用的函数
说了这么多文字,不如直接一段代码更直白:略

  1. 又爱又恨的setTimeout

(https://juejin.im/post/59e85eebf265da430d571f89)

(https://blog.csdn.net/haoaiqian/article/details/78622651)


Async/Await替代 Promise 的6个理由

阅读原文