在链接中使用数组方法之前如何避免Javascript迭代器计算

问题描述 投票:0回答:1
  1. 生成器/迭代器允许操作对象序列,而不必首先构建所有序列项。这样可以节省机器的内存空间。

  2. 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 中可以吗?

javascript arrays functional-programming iterator generator
1个回答
0
投票

从 ECMAScript 2025 开始,我们有了那些 迭代器辅助方法,并且可以在不将所有内容收集到数组中的情况下完成此操作:

function* myGen() {
   yield 1;
   yield 2;
   yield 3;
   throw new Error('oups');
}

const y = myGen().find(x => x > 2);
console.log(y); // 3

这里

find
不是一个数组方法,而是一个迭代器辅助方法。同样,我们得到
filter
map
forEach
reduce
作为迭代器辅助方法:

function* myGen() {
   yield 1;
   yield 2;
   yield 3;
   throw new Error('oups');
}

const y = myGen().map(x => x * x)      // Map to square
                 .filter(x => x % 2)   // Filter odd squares
                 .take(2)              // Only get two results
                 .reduce((sum, x) => sum + x); // Add them together
console.log(y); // 10 (1 + 9)

© www.soinside.com 2019 - 2024. All rights reserved.