JS执行机制

2019-05-21  本文已影响0人  1024k纯金

首先我们来看几个问题:

1.JS是单线程的么?
2.JS有异步么?
3.JS单线程怎么实现的的异步

1.JS是单线程的么?
这个问题毫无悬念,肯定是单线程的。js刚开始就是作为浏览器脚本语言推出的,试想如果是多线程:

那么一个线程在某个DOM节点上添加内容,另一个线程删除了这个节点,这时浏览器应该以哪个线程为准?
这样就复杂化了,HTML5提出Web Worker标准,允许JavaScript脚本创建多个线程,但是子线程完全受主线程控制,且不得操作DOM。也就是说始终是单线程,而且单线程的含义是js只能在一个线程上运行,也就是说,js同时只能执行一个js任务,其它的任务则会排队等待执行。

2.JS有异步么?
JS使用ajax获取后台数据就是一个异步的过程,promise等

3.JS单线程怎么实现的的异步?
看了很多资料,说一下我的理解:
js引擎不只一个线程,执行js代码的是js主线程,还有GUI渲染线程,浏览器事件触发线程等。js主线程执行的时候遇到同步任务时按照后入先出的顺序同步执行,碰到异步任务的时候,将这个任务的回调加入到消息队列,当主线程执行完同步任务时,会去获取队列中的回调,然后放到主线程顺序执行,如下图:

bg2014100802.png

转引自Philip Roberts的演讲《Help, I'm stuck in an event-loop》

参考自:
1.浏览器JS运行机制(线程)——一只dororo
2.JavaScript 运行机制详解——阮一峰

上一篇下一篇

猜你喜欢

热点阅读