【javaScript】js运行机制

单线程

同步任务要先于异步任务执行

执行顺序

  • 同步

  • process.nextTick

  • 异步

  • setImmediate(第一次事件循环完毕之后就会执行)

下面可以看个例子:

输出的顺序为:

原因如下:

如果此时在零秒定时器前面添加一个for循环同步代码,让这个for循环的运行时间大于0毫秒,那会如何执行呢?

执行结果如下

2000次1的输出运行时间显然大于0毫秒,但是定时器内的代码并没有在for循环运行中执行,而是等待for循环走完之后再执行。这就是所谓的JS定时器不准时。

这就是因为JS是单线程的,只有上一个任务完成后,才会执行下一个任务。

事件循环

js运行时会有运行栈任务队列

同步的代码会放入运行栈中执行

异步代码会放入任务队列中,等待同步代码执行完后放入运行栈中执行

所谓事件循环就是在运行栈代码执行完后JS会不断地查询任务队列中是否还存在任务

计时器就是到点后插入到任务队列中

宏任务和微任务

异步任务又分为宏任务微任务所有的微任务都要先于宏任务执行

执行顺序

  • 同步

  • process.nextTIck

  • 微任务:promise的then方法内的函数

  • 宏任务:计时器、ajax、文件读写、DOM事件

  • setImmediate(第一次事件循环完毕之后就会执行) 

输出结果:

如果promise的then里面写的是函数的话,就是异步的,写的不是函数就是同步的

异步

同步

promise对象和async

promise中resolve的传递参数是then方法中接收的参数

async函数本质本质上就是一个promise对象,它的返回值会是一个promise对象

等价形式

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值