console.log(f1.toString());
console.log(f2.toString());
};
可以发现,async
函数就是将Generator
函数的星号(*
)替换成async
,将 yield
替换成 await
,仅此而已。
async
函数是基于 Generator
的改进,体现在以下4点
- 内置执行器。
Generator
函数的执行必须靠执行器。所以才有了Thunk
函数和co
模块,而async
函数自带执行器。async
函数的执行和普通函数一样。
asyncReadFile();
-
更好的语义。
async
和await
,比起星号和yield
,语义更清楚了。async
表示函数里有异步操作,await
表示紧跟在后面的表达式需要等待结果。 -
更广的适应性。即使
Generator
函数可以借助co
模块自动执行,但是co
模块后面只能是Thunk
函数或Promise
对象,而async
函数的await
命令后面,可以是 Promise对象和原始类型的值(数值、字符串和布尔值,但这是会自动转成立即resolved
的Promise对象
) -
返回值是
Promise
。aysnc函数返回值为Promise
,这比Generator
函数的返回值是Iterator
对象方便多了。
async
函数完全可以看作多个异步操作,包装成的一个Promise
对象,而await命令就是内部then
命令的语法糖。
总是就是
Generator
函数虽然是JS借鉴其他语言,根据JS本身单线程的特点实现的协程,但是使用起来会麻烦很多,而async
函数就是为了解决这些重复的事情而生的。其实async
函数就是将Generaor
函数和自动执行器包装了在了一起,然后润色了一下。
async函数的实现原理
就是将Generator函数和自动执行器,包装在一个函数里。
async function fn(args) {
// …
}
function fn(args) {
return spawn(function* () {
// …
})
}
所有的 async
函数都可以写成上面的第二种形式,其中 spawn 函数就是自动执行器。
function spawn(genF) {
return new Promise(function(resolve, reject) {
const gen = genF();
function step(nextF) {
let next;
try {
next = nextF();
} catch(e) {
return reject(e);
}
if(next.done) {
return resolve(next.value);
}
Promise.resolve(next.value).then(function(v) {
step(function() { return gen.next(v); });
}, function(e) {
step(function() { return gen.throw(e); });
});
}
step(function() { return gen.next(undefined); });
});
}
常见的关于async
的笔试题
-
实现一个
sleep
-
实现一个红绿灯:红灯2秒,黄灯1秒,绿灯3秒
-
使用
async
实现Promise.all()
的效果
实现一个 sleep
每隔1秒输出 1, 2, 3, 4, 5
function sleep(interval) {
return new Promise(resolve => {
setTimeout(resolve, interval);
})
}
// 用法
async function one2FiveInAsync() {
for (let i = 1; i <= 5; i++) {
console.log(i);
await sleep(1000);
}
}
one2FiveInAsync();
实现一个红绿灯
红灯2秒,黄灯1秒,绿灯3秒
function sleep(duration) {
return new Promise(resolve => {
setTimeout(resolve, duration);
})
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以扫码获取(备注前端)
最后
在面试前我花了三个月时间刷了很多大厂面试题,最近做了一个整理并分类,主要内容包括html,css,JavaScript,ES6,计算机网络,浏览器,工程化,模块化,Node.js,框架,数据结构,性能优化,项目等等。
包含了腾讯、字节跳动、小米、阿里、滴滴、美团、58、拼多多、360、新浪、搜狐等一线互联网公司面试被问到的题目,涵盖了初中级前端技术点。
-
HTML5新特性,语义化
-
浏览器的标准模式和怪异模式
-
xhtml和html的区别
-
使用data-的好处
-
meta标签
-
canvas
-
HTML废弃的标签
-
IE6 bug,和一些定位写法
-
css js放置位置和原因
-
什么是渐进式渲染
-
html模板语言
-
meta viewport原理
nvas
-
HTML废弃的标签
-
IE6 bug,和一些定位写法
-
css js放置位置和原因
-
什么是渐进式渲染
-
html模板语言
-
meta viewport原理