如何解决节点承诺不值得等待
因此,我将竭尽全力使节点中的流,promise和async功能得到解决。我似乎从来没有做对。我有两个非常相似的用例(看起来很标准)。像这样:
- 我有一个流可以获取一些数据
- 我需要将其通过管道传递给进程(在这种情况下为fast-csv)
- 完成后,我需要将其发送到下一步(实际上是发送到数据库)
- 在现实世界中,我需要等待数据库更新完成
- 下一步打开下一个文件流
- 过程
- 添加
- 重复...
因此,下面的代码“ SHOULD”就是这样做的,但是诺言不会等待被解决。等待仅在异步函数中起作用(并且流似乎主动忽略使用等待的任何尝试)
import { parseString } from '@fast-csv/parse';
import * as fs from "fs";
async function IHateStreams (){
/** Lets read profiles */
console.log("1: Reading Program " + profileFS);
let fileContent = fs.readFileSync(profileFS,'utf8');
let dataset : Array<any> = []
return new Promise((resolve,reject) => {
parseString(fileContent,{headers: true})
.on('error',error => console.error(error))
.on('data',row => dataset.push(row))
.on('end',() {
console.log("2: Inside Done")
resolve
});
})
}
IHateStreams().then(console.log("3: stream done!"));
console.log("4: code done,so running next command with the data")
代替好的输出:
1: Reading Program ./dbinitdata/ProfileIdName.csv
2: Inside Done
3: stream done!
4: code done
我得到:
1: Reading Program ./dbinitdata/ProfileIdName.csv
3: stream done!
4: code done
2: Inside Done
解决方法
经过所有的忙碌之后,我是如此亲密。上面的代码由于3个原因而失败。 (如果有人在我的旅途中)
兑现承诺似乎可行,上述问题是:
- 忘记
.then()
特定于流的内容 - 错别字不会带你去任何地方,
resolve()
- 出于我所需要的目的(而不是架构师),创建一个
async
控制函数,并通过将流包裹在一个Promise中后逐流踢来假装一切都是顺序的。
也许有更轻松的方法可以做到这一点,但希望这会有所启发。
import { parseString } from '@fast-csv/parse';
import * as fs from "fs";
const profileFS: string = "tsconfig.json"
async function IHateStreams (){
/** Lets read profiles */
console.log("1: Reading Program " + profileFS);
let fileContent = fs.readFileSync(profileFS,'utf8');
let dataset : Array<any> = []
return new Promise((resolve,reject) => {
parseString(fileContent,{headers: true})
.on('error',error => console.error(error))
.on('data',row => dataset.push(row))
.on('end',data => {
console.log("2: Reading Program " + data);
resolve();
}
});
})
}
async function iWait (){
const isThisAPromise = await IHateStreams()
console.log("3: code done,so running next command with the data")
}
iWait();
console.log("1.99: code done,not in chain")
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。