谈JS 异步任务,微任务,宏任务

JS异步任务、微任务、宏任务

前言

关于Js的异步处理以及宏任务、微任务。
首先我们要先明白JS为什么是单线程的执行机制?Js是用于跟Client交互的一种浏览器端脚本语言,首先肯定要操作dom结构,如果是多线程的话,会发生什么? A线程想要操作这个DOM变红色,然后呢B线程来了,他想要将这个DOM变为蓝色。浏览器就二丈和尚摸不着头脑了。
所以这也是单线程的原因。当然,现在也支持多线程,我们不过多深究。

一、异步任务是什么?

由于Js执行机制是单线程的,就是同一时间只能做一件事吗,举个例子,我能一遍洗澡,一边煮水。水煮好了,我洗澡也洗完了。但是JS不行,他会等水煮好了,再去洗澡,又由于单线程原因,所以异步任务出来了。
异步任务使得JS更好的处理异步,当我们去请求一个接口的时候,我们可以把他放到异步队列,当期请求完成后,我们再去对其操作。

二、宏任务、微任务

1、什么是宏任务?

要明确一点宏任务和微任务都属于异步任务。
常见的宏任务有(scriptsetTimeoutsetInterval、postMessage、MessageChannel、setImmediate(Node.js 环境),其中粗体对于搬砖已经够用。

console.log('start')
setTimeout(function(){
    console.log('我是第二个宏任务');
});	
console.log('end');
//输出结果:start、end、我是第二个宏任务

解释:上面我们提到过 script、setTimeout 是宏任务,JS一上来首先执行宏任务,也就是我们最熟悉的Script 标签内容,所以输出 start、遇到setTimeout 是第二个宏任务,先放到异步队列。继续执console.log(‘end’);
也就是输出 end 当第一个宏任务执行完成后,再去执行settimeout(当然应该先判断存不存在微任务,此处暂且不讨论。下面会引出)

2.什么是微任务?

常见的微任务有(微任务:Promise.then、Object.observe、MutationObserver、process.nextTick(Node.js 环境))
我们来讨论Promise
Promise传送门

console.log('start');
setTimeout(function(){
    console.log('我是第二个宏任务');
});
new Promise(function(resolve){		    
    console.log('我是promise');
    resolve();
}).then(function(){		    
    console.log('我是promise里的第一个then');
})		
console.log('end');
// 输出结果:1、start 2、我是Promise23、4、end
//5、我是Promise里的第一个then 6、我是第二个宏任务

运行解释: 当JS执行时,碰到的第一个宏任务是Script,执行,输出里面的start、 settimeout是第二个宏任务。放到异步队列,不执行, 输出第一个值 1、start
碰到promise主函数里面的是直接输出,即输出 2、我是promise, then里面的是微任务,放到微任务队列。往下运行,遇到输出end。输出 end,主执行栈(也就是第一个宏任务执行完毕)不要着急,宏任务执行完了不是要执行第二个宏任务,要看看有没有微任务,一看,微任务里还有个 ‘ console.log(‘我是promise里的第一个then’);’等待执行,那肯定要运行这句代码啊。所以 输出 我是promise里的第一个then 一看微任务没了,主执行栈也没东西了,就去问。宏任务有没有等待执行的,问了一下, 结果 ‘console.log(‘我是第二个宏任务’);‘说话了,我还没有输出,既输出我是第二个宏任务

3.为什么有了宏任务还要有微任务?

是为了给紧急任务一个插队执行的机会,举个例子。 我正在排队做核酸检测,做完后忽然我忘了领取核酸检测完成贴。那按照宏任务的思维,我们只能排队到最后重新领取,那这样是不是很不友好,所以微任务出来了,给了我们一个紧急插队执行的机会,宏任务(做核酸),微任务(做完核酸忘记领取贴纸,还要运行我的事情)。
第一次写,不对的地方请指正。


总结

提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文仅仅简单介绍了pandas的使用,而pandas提供了大量能使我们快速便捷地处理数据的函数和方法。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值