使用生成器的非递归异步实现
non recursive async implementation with generators
我正在研究 javascript 生成器,我发现这个实现使用递归函数模拟 async-await 的效果。我想知道我们是否可以实现类似但非递归的东西?我努力了很长时间,但无法找到可行的解决方案。
function sum(...args) {
let total = 0;
return new Promise(function (resolve, reject) {
setTimeout(function () {
for (const arg of args) {
if (typeof arg !== 'number') {
reject(`Invalid argument: ${arg}`);
}
total += arg;
}
resolve(total);
}, 500);
});
}
function recursiveAsync(gen, result) {
const obj = gen.next(result);
if (obj.done) return;
obj.value.then(function (result) {
recursiveAsync(gen, result);
});
}
function async(genFn) {
const gen = genFn();
recursiveAsync(gen);
}
async(function* () {
const a = yield sum(1, 3, 5);
console.log(a);
const b = yield sum(2, 4);
console.log(b);
const result = yield sum(a, b);
console.log(result);
});
不,你不能迭代地做到这一点。
请注意,“递归”调用实际上并不是递归的,而是异步 .then()
回调再次调用该函数 - 回调不是由函数直接调用的,它是由 promise 调度的。调用堆栈没有增长。
我正在研究 javascript 生成器,我发现这个实现使用递归函数模拟 async-await 的效果。我想知道我们是否可以实现类似但非递归的东西?我努力了很长时间,但无法找到可行的解决方案。
function sum(...args) {
let total = 0;
return new Promise(function (resolve, reject) {
setTimeout(function () {
for (const arg of args) {
if (typeof arg !== 'number') {
reject(`Invalid argument: ${arg}`);
}
total += arg;
}
resolve(total);
}, 500);
});
}
function recursiveAsync(gen, result) {
const obj = gen.next(result);
if (obj.done) return;
obj.value.then(function (result) {
recursiveAsync(gen, result);
});
}
function async(genFn) {
const gen = genFn();
recursiveAsync(gen);
}
async(function* () {
const a = yield sum(1, 3, 5);
console.log(a);
const b = yield sum(2, 4);
console.log(b);
const result = yield sum(a, b);
console.log(result);
});
不,你不能迭代地做到这一点。
请注意,“递归”调用实际上并不是递归的,而是异步 .then()
回调再次调用该函数 - 回调不是由函数直接调用的,它是由 promise 调度的。调用堆栈没有增长。