什么是事件循环(eventloop)?

Js是单线程

  • js是单线程的。也就是说,同一时间只能做一件事。(有些任务是耗时的,会阻塞代码的执行)
  • 作为浏览器脚本语言,与它的用途有关。
  • js的主要用途是和用户互动,以及操作DOM。这决定了它只能是单线程。

同步、异步

可以把代码分为同步代码(同步任务)和异步代码(异步任务)

重点

  • 同步代码:立即放入js引擎(js主线程)执行,并原地等待结果。
  • 异步代码:先放入宿主环境(浏览器/Node),不必原地等待结果,并不阻塞主线程继续往下执行,异步结果在将来执行。比如setTimeout、setInterval、Ajax/Fetch、事件绑定等。

执行过程

代码依次执行,同步代码放在执行栈中立即执行,并且原地等待结果,异步代码会交给宿主环境,然后继续执行同步代码,直到执行栈中的同步代码执行完;宿主环境里边的异步代码等待正确的时机,时机到了之后,会把里边的异步代码推送给任务队列,然后执行栈会在任务队列里找有没有异步任务执行,如果有,就将异步任务推送给执行栈执行,反复循环,直到任务队列里的异步任务全部执行完。从执行栈到任务队列里反复查找的过程就叫做事件循环

 总结

  1. Js是单线程,防止代码阻塞,把代码(任务)分为:同步和异步
  2. 同步代码给js引擎执行,异步代码交给宿主环境
  3. 同步代码放入执行栈中,异步代码等待时机成熟送入任务队列排队
  4. 执行栈执行完毕,会去任务队列看是否有异步任务,有就送到执行栈执行,反复循环查看执行,这个过程就是事件循环(eventloop)
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值