JS 的运行机制

JS 是一种具有函数优先的轻量级,解释型或及时编译型的脚本语言,它的最大特点就是单线程,即同一时间只能做一件事。

为什么JavaScript是单线程

JS 的单线程,与它的用途有关作为浏览器脚本语言,JS 的主要用途是与用户交互,以及操作DOM。这决定了它只能是单线程,否则会带来比较复杂的同步问题。举个栗子:假设JS 同时有两个线程,一个线程在某个DOM节点上添加内容,另一个线程在删除这个节点,这时浏览器就懵了,“我到底该做什么”,所以,为了避免这种复杂性,JS 设计为单线程,上一行代码未执行完毕,不会执行后面的代码,这已经成为了这门语言的核心特征。


任务队列
  • 单线程就意味着,所有任务需要排队,前一个任务结束后,才会执行后一个任务。如果前一个任务消耗的时间很长,后一个任务就不得不一直等着。这样很多时候CPU 都是空闲着的,因为 IO(输入输出设备)很慢,不得不等待当前任务结束后,再往下执行。
  • 开发者意识到,这时主线程完全可以不管 IO 设备,挂起处于等待中的任务,先运行排在后面的任务。等到 IO 设备返回了结果,再把这个任务继续执行下去。
  • 所以,所有任务可以分成两种,一种是同步任务,另一种是异步任务。同步任务是指,在主线程上排队执行的任务,只有前一个任务执行完毕后,才会执行后一个任务;异步任务是指,不进入主线程而进入“任务队列”的任务,只有“任务队列”通知主线程,“我准备好了,我可以继续执行了”,该任务才会进入主线程执行。

Event Loop(事件循环)
  • 1.所有任务都在主线程上执行,形成一个执行栈
  • 2.主线程之外吗,还会存在一个任务队列。把异步任务放在里面。
  • 3.一旦执行栈中所有同步任务执行完毕,系统就会读取任务队列,看看里面有哪些时间。那些对应的异步任务,会结束等待状态,进入执行栈,开始执行。
  • 4.主线程不断重复上面的第三步。

主线程从任务队列中读取事件,这个过程是循环不断的,所以整个运行机制又称为 Event Loop

Ajax请求、定时器和延时器就是典型的异步任务

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值