在第一个testMultipleLoops2
之后的函数for await
中,
l
将变成GeneratorStatus:<closed>
,
我进行了大量研究,但没有找到重新打开的方法。
const tryRecursive=async function*(i=0){console.count("tryRecursive");yield i++;yield*tryRecursive(i)}
const asyncDelay=(b,delay=1e3)=>new Promise((resolve,reject)=>setTimeout(()=>resolve(b()),delay))
const tryDelayYieldNumbers=async function*(){
for await(const i of tryRecursive()){
const result=await asyncDelay(()=>i)
yield result}}
const testMultipleLoops2=(async()=>{
const l=tryDelayYieldNumbers()
let count=3
for await(const i of l){if(count-->0)console.log(i);else break}
count=4
///But `l` is closed here, can't do future looping
for await(const i of l){if(count-->0)console.log(i);else break}
count=5
for await(const i of l){if(count-->0)console.log(i);else break}
})()
答案 0 :(得分:2)
您要的是不可能的。根据设计(以及根据语言规范),即使您以iterator
尽早终止循环,您的l
变量for .. of
也会在break
的末尾“关闭”。