fs项目---->async/await的学习(一)
2018-07-11号,我来到了fs项目组担任后端开发的角色。这是我来thoughtworks以来首个的正式项目,不管是在技术还是在敏捷的实践中都是受益匪浅。来感受tw特殊的文化的同时,我希望自己能够学到更多的东西。不忘初心,坚持总结。这篇博客主要记载的是async/await在Array中使用遇到的一些问题。
一、async/await在Array.forEach中不work
我们想在forEach中执行操作再执行下面的操作,但是运行并没有生效。下面看一下forEach的事例
const waitFor = (ms) => new Promise(r => setTimeout(r, ms));
const start = async () => {
const array = [, , ];
array.forEach(async (item) => {
await waitFor(item);
console.log(item);
});
console.log('done');
}
start();
在nodejs(v10.6.0)中运行,可以看到如下的结果
done
原因的分析可以参考一下forEach的实现,这里暂时不做说明:https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach#Polyfill。下面提供两种提供的方案
- 不使用forEach,使用fori的循环,同步执行
const start = async () => {
const array = [, , ];
for (let i = ; i < array.length; i++) {
await waitFor(array[i]);
console.log(array[i]);
}
console.log('done');
}
- 使用Promise.all和map的实现,异步执行
const start = async () => {
const array = [, , ];
await Promise.all(array.map(async num => {
await waitFor(num);
console.log(num);
}));
console.log('done');
}
最终得到我们想要的运行结果
done
二、async/await在Array.filter中不work
我们写一个js的例子,nodejs的版本是v10.6.0。代码如下
const filterOperate = (ms) => new Promise(resolve => setTimeout(resolve, ms));
const start = async () => {
let array = [, , ];
array = array.filter(async (item) => {
await filterOperate(item);
return item === ;
});
console.log(array);
console.log('done');
}
start();
运行的结果并不是我们想要的,如下:
[ , , ]
done
我们需要改进filter,用我们定义的asyncFilter方法。定义如下:
const filterOperate = (ms) => new Promise(resolve => setTimeout(resolve, ms));
const asyncFilter = async (arr, callback) => {
const fail = Symbol();
return (await Promise.all(arr.map(async item => (await callback(item)) ? item : fail))).filter(i => i !== fail);
};
const start = async () => {
let array = [, , ];
array = await asyncFilter(array, async (item) => {
await filterOperate(item);
return item == ;
})
console.log(array);
console.log('done');
}
start();
打印的结果如下:
[ ]
done
三、async/await在Array.map中不work
我们写一个js的例子,代码如下:
const promise = (ms) => new Promise(resolve => setTimeout(resolve, ms));
const start = async () => {
let array = [, , ];
array = await array.map(async (item) => {
await promise(item);
return item * ;
})
console.log(array);
console.log('done');
}
start();
运行的结果如下:
[ Promise { <pending> },
Promise { <pending> },
Promise { <pending> } ]
done
我们改进代码,使它返回正确的结果。只要在外面包含一层Promise.all就可以。如下
const promise = (ms) => new Promise(resolve => setTimeout(resolve, ms));
const start = async () => {
let array = [, , ];
array = await Promise.all(array.map(async item => {
await promise(item);
return item * ;
}));
console.log(array);
console.log('done');
}
start();
运行的结果如下:
[ , , ]
done
友情链接
fs项目---->async/await的学习(一)的更多相关文章
- fs项目---->cron框架的学习(一)
Cron是一种允许您按计划执行某些内容的工具.这通常使用cron语法来完成.我们允许您在计划作业触发时执行函数.我们还允许您使用子进程执行javascript进程外部的作业.此外,这个库超出了基本的c ...
- javascript异步编程 Async/await
Async/await Async/await 在学习他之前应当补充一定的 promise 知识 它是一种与 promise 相配合的特殊语法,目前被认为是异步编程的终级解决方案 值得我们每一个人学习 ...
- vue项目进行时,script标签中,methods事件中函数使用的async/await
用 async/await 来处理异步 await关键字只能放到async函数里面,通过await得到就是Promise返回的内容:当然也能通过then()去获取,若通过then()获取了则就无Pro ...
- C# async await 学习笔记2
C# async await 学习笔记1(http://www.cnblogs.com/siso/p/3691059.html) 提到了ThreadId是一样的,突然想到在WinForm中,非UI线程 ...
- .NET异步操作学习之一:Async/Await中异常的处理
以前的异常处理,习惯了过程式的把出现的异常全部捕捉一遍,然后再进行处理.Async/Await关键字出来之后的确简化了异步编程,但也带来了一些问题.接下来自己将对这对关键字进行学习.然后把研究结果放在 ...
- (译文)学习ES6非常棒的特性——Async / Await函数
try/catch 在使用Async/Await前,我们可能这样写: const main = (paramsA, paramsB, paramsC, done) => { funcA(para ...
- 已配置好的vue全家桶项目router,vuex,api,axios,vue-ls,async/await,less下载即使用
github 地址: https://github.com/liangfengbo/vue-cli-project 点击进入 vue-cli-project 已构建配置好的vuejs全家桶项目,统一管 ...
- Async/Await 学习与示例
参考:Async/await学习 es 7 提供了对 promise 对象的更好的操作,省去了很多丧心病狂的链式异步请求,promise 是回调地狱的福音,而 Async/Await 则是 promi ...
- JavaScript基础——深入学习async/await
本文由云+社区发表 本篇文章,小编将和大家一起学习异步编程的未来--async/await,它会打破你对上篇文章Promise的认知,竟然异步代码还能这么写! 但是别太得意,你需要深入理解Promis ...
随机推荐
- JavaScript数组所有API全解密
全文共13k+字,系统讲解了JavaScript数组的各种特性和API. 数组是一种非常重要的数据类型,它语法简单.灵活.高效. 在多数编程语言中,数组都充当着至关重要的角色,以至于很难想象没有数组的 ...
- PLSQL连接Oracle 数据库配置详解
1. 下载instantclient-basic-win32-11.2.0.1.0 (oracle官网下载地址:http://www.oracle.com/technetwork/topics/win ...
- WordPress主题开发实例:获取当前分类的文章列表
思路: 如果使用默认的wordpress的方法,调出来的数据就会被后台的显示个数所限制,而我们需要的是自由控制文章数和翻页,所以我使用WP_Query 获取当前分类的方法可以通过 get_query_ ...
- 独热编码和dummy编码的作用
参考这篇文章: https://www.cnblogs.com/lianyingteng/p/7792693.html 总结:我们使用one-hot编码时,通常我们的模型不加bias项 或者 加上bi ...
- Java在Service层异常封装
dao层不需要抛出异常,应该在service层抛出异常,可以是自定义的异常,也可以包装异常,然后在controller中定义exception handler统一处理或者单独处理. 参考: https ...
- Git tag 标签操作
列表 # 列出已有的标签 $ git tag # 为了能及时看到远程上新增的标签, 在上面的命令之前可以fetch一下 git fetch --all --tags --prune # 列出匹配的部分 ...
- sublime 3插件推荐
新建文件以及快速注释 1. SublimeTmpl 快速生成文件模板 一直都很奇怪为什么sublime text 3没有新建文件模板的功能,像html头部的DTD声明每次都要复制粘贴.用Subli ...
- 这可能由 CredSSP 加密 oracle 修正引起的。
某天在与服务器进行远程连接时,遇到了以下错误: 发生了身份验证错误. 不支持请求的函数. 远程计算机: <主机名> 这可能由 CredSSP 加密 oracle 修正引起的. 有关更多信息 ...
- 【iCore4 双核心板_ARM】例程八:定时器PWM实验——呼吸灯
实验原理: STM32的定时器有PWM功能,iCore4的蓝色LED连接在定时器的输出接口上, 可以通过定时器的PWM输出控制LED的亮度,从而实验呼吸灯的功能. 核心代码: int main(voi ...
- 【iCore4 双核心板_ARM】例程十四:FATFS实验——文件操作
实验现象: 核心代码: int main(void) { int i,j; FIL file; FATFS fatfs; static FRESULT res; unsigned ]; unsigne ...