首先,JavaScript是一门单线程的语言,意味着同一时间内只能做一件事,但是这并不意味着单线程就是阻塞,而实现单线程非阻塞的方法就是事件循环
在JavaScript中,所有的任务都可以分为
流程图
可以看到,同步
任务进入主线程
,即主执行栈,异步
任务进入任务队列
,主线程内的任务执行完毕为空,会去任务队列读取对应的任务,推入主线程执行。上述过程的不断重复就事件循环
如果将任务划分为同步任务和异步任务并不是那么的准确,举个例子:
console.log(1)
setTimeout(()=>{
console.log(2)
},0)
new Promise(()=>{
console.log('new Promise')
resolve()
}).then(()=>{
console.log('then')
})
console.log(3)
执行步骤:
所以按照分析,它的结果应该是 1 => ‘new Promise’ => 3 => 2 => ‘then’
但是实际结果是:1=>‘new Promise’=> 3 => ‘then’ => 2
出现分歧的原因在于异步任务执行顺序
,事件队列其实是一个“先进先出”
的数据结构,排在前面的事件会优先被主线程读取
例子中 setTimeout回调事件是先进入队列中的,按理说应该先于 .then 中的执行,但是结果却偏偏相反
原因在于异步任务还可以细分为微任务
与宏任务
一个需要异步执行的函数,执行时机是在主函数执行结束之后、当前宏任务结束之前
常见的微任务有:
宏任务
宏任务的时间粒度比较大
,执行的时间间隔是不能精确控制
的,对一些高实时性的需求就不太符合
// 遇到 同步任务 console.log(1),直接打印1
// 遇到定时器,属于新的宏任务,留着后面执行
//遇到 new Promise,这个是直接执行的,打印 ‘new Promise'
// .then 属于微任务,放入微任务队列,后面再执行
// 遇到 console.log(3) 直接打印 3
// 本轮宏任务执行完毕,微任务列表查看是否有微任务,发现 .then的回调,执行它,打印’then‘
//当一次宏任务执行完,再去执行新的宏任务,这里就剩一个定时器的宏任务了,执行它,打印 2
是用来声明一个异步方法,而 await是用来等待异步方法执行
async函数返回一个promise对象,下面两种方法是等效的
function f(){
return Promise.resolve('TEST');
}
async function asyncF(){
return 'TEST';
}
正常情况下,await命令后面是一个 Promise对象,返回该对象的结果。如果不是 Promise对象,就直接返回对应的值
async function f(){
return await 000
}
f().then(v =>console.log(v))//000
不管await后面跟着的是什么,await都会阻塞后面的代码
async function fn1(){
console.log(1)
await fn2()
console.log(2)
}
async function fn2(){
console.log('fn2')
}
fn1()
console.log(3)
上面的例子中,await 会阻塞下面的代码(即加入微任务队列),先执行 async外面的同步代码,同步代码执行完,再回到 async 函数中,再执行之前阻塞的代码
所以上述输出结果为:1,fn2,3,2
async function async1() {
console.log('async1 start')
await async2()
console.log('async1 end')
}
async function async2() {
console.log('async2')
}
console.log('script start')
setTimeout(function () {
console.log('settimeout')
})
async1()
new Promise(function (resolve) {
console.log('promise1')
resolve()
}).then(function () {
console.log('promise2')
})
console.log('script end')
过程:
console.log('script start')
console.log('async1 start')
console.log('async2')
console.log('promise1')
console.log('script end')
console.log('async1 end')
console.log('promise2')
console.log('settimeout')
提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文仅仅简单介绍了pandas的使用,而pandas提供了大量能使我们快速便捷地处理数据的函数和方法。