问题描述
-
生成器/迭代器允许操作对象序列,而无需先构建所有序列项。从而可以节省机器的内存空间。
-
像
map
、reduce
、find
、forEach
等数组方法在函数式编程中是必不可少的,因为它允许将代码编写为一系列纯函数,更容易测试等
我想要一个公平的解决方案,让我可以使用生成器/迭代器和数组函数。
让我们看看这段代码:
function* myGen() {
yield 1;
yield 2;
yield 3;
throw new Error('oups');
}
const y = [...myGen()].find(x => x > 2);
assert.deepStrictEqual(y,3);
这将不起作用因为首先发生传播,占用所有内存空间,并且生成器函数将一直运行到结束并抛出异常。
在这个例子中,我希望 Javascript 先执行 find
函数的代码,在每个下一个迭代器计算之前 foreach 元素。
我想要一个允许我使用数组方法的解决方案,而无需先构建完整的数组。可以在 Javascript 中使用吗?
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)