美文网首页
JS执行机制

JS执行机制

作者: 1024k纯金 | 来源:发表于2019-05-21 19:54 被阅读0次

    首先我们来看几个问题:

    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 运行机制详解——阮一峰

    相关文章

      网友评论

          本文标题:JS执行机制

          本文链接:https://www.haomeiwen.com/subject/upzdzqtx.html