- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我尝试使函数与 Array.prototype.reduce 方法相同。
function a(collection, iterator, accumulator) {
for (i of Object.keys(collection)){
if (i===0 && accumulator === undefined){
accumulator = collection[i]
continue
}
accumulator = iterator(accumulator, collection[i])
}
return accumulator;
};
a([1,2,3],function(acc,cur){return acc += cur}, 0) // this works fine. returns 6
a([1,2,3],function(acc,cur){return acc += cur}) // expected 6 but returns NaN
a([1,2,3], function(memo){return memo}); // expected 1 but returns undefined
我不知道为什么 accumulator
没有设置为 collection[i]
并在初始值(函数a)的第三个参数未传递。
最佳答案
Object.keys
始终返回一个字符串数组,因此 i
是一个字符串,因此 i === 0
始终为 false。
另请注意,您需要声明i
。现在,您的代码正在成为 The Horror of Implicit Globals 的牺牲品。 (我建议使用严格模式,这样它们就应该是错误。)
FWIW,这是解决这两个问题的最低更新(但也请参见下文):
"use strict";
function a(collection, iterator, accumulator) {
let first = true; // ***
for (const i of Object.keys(collection)){
// ^^^^^−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−− *** declare `i`
if (first && accumulator === undefined){
// ^^^^^−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−− *** first pass?
first = false; // ***
accumulator = collection[i]
continue
}
first = false; // ***
accumulator = iterator(accumulator, collection[i])
}
return accumulator;
};
console.log(a([1,2,3],function(acc,cur){return acc += cur}, 0));
console.log(a([1,2,3],function(acc,cur){return acc += cur}));
console.log(a([1,2,3], function(memo){return memo}));
FWIW,我不知道您的意思是否是与 reduce
完全匹配,但如果是这样,您的函数的逻辑与 Array 的逻辑不同。原型(prototype).reduce
。请参阅the specification有关详细信息,但 reduce
检查它获得了多少个参数,它不会检查累加器是否未定义
。如果您明确为累加器指定值undefined
,它将使用该值(而不是使用第一个数组元素的值):
console.log("`undefined` for accumulator:");
["a", "b", "c"].reduce((acc, value) => { console.log(acc, value); return value; }, undefined);
console.log("No accumulator:");
["a", "b", "c"].reduce((acc, value) => { console.log(acc, value); return value; })
.as-console-wrapper {
max-height: 100% !important;
}
在归约过程中,累加器也可能变得未定义
。如果没有给定累加器,则使用第一个看到的值(不一定位于稀疏数组中的索引 0 处!)。 (我对上面累加器的修复实际上修复了这个副产品。)您的代码还使用 Object.keys
而 reduce
仅使用 for
循环。我没有仔细阅读,可能还有其他差异。
"use strict";
function a(collection, iterator, ...optional) { // ***
let haveAccumulator = optional.length > 0; // *** Default acc correctly
let [accumulator] = optional; // ***
for (const i of Object.keys(collection)){
// ^^^^^−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−−− *** declare `i`
if (!haveAccumulator) { // ***
haveAccumulator = true; // ***
accumulator = collection[i]
continue;
}
accumulator = iterator(accumulator, collection[i])
}
return accumulator;
};
console.log(a([1,2,3],function(acc,cur){return acc += cur}, 0));
console.log(a([1,2,3],function(acc,cur){return acc += cur}));
console.log(a([1,2,3], function(memo){return memo}));
关于javascript - 累加器在 make `reduce` 方法中返回未定义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63376645/
我想用 c 编写基本计算器:我有累加器的问题(带有“+”和“-”运算符) int main(void) { float num1,num2,res; char operator;
我已经解决了 4clojure.com 上的 45 个问题,并且在尝试使用递归和累加器解决一些问题的方式中,我注意到一个反复出现的问题。 我会尽我所能解释我正在做的事情,以最终得到模糊的解决方案,希望
my_Stream 是我想要累积并分配给变量以供进一步处理的数据。我的问题:一旦流完成,如何将变量 the_string 的内容获取到 console.log? my_Stream.onValue(f
我很好奇,从这个代码片段中得到的平均值是多少?累加器旨在为空。 boost::accumulators::accumulator_set > Accumulator; int Mean = boost
在累积 struct timespec 增量的程序中,我正在执行以下逻辑: struct timespec accu, start, stop; for (...) { // record s
我正在尝试在数组上使用 foldLeft。例如: var x = some array x.foldLeft(new Array[Int](10))((a, c) => a(c) = a(c)+1)
由于没有找到在 C++ 中重置累加器的“boost ”方法,我遇到了一段似乎可以重置 boost 累加器的代码。但是不明白它是如何实现的。代码如下- #include #include #incl
这个问题在这里已经有了答案: Does a sequential stream in Java 8 use the combiner parameter on calling collect? (1
我正在实现一个需要递归调用才能获取所有数据的 API。我已经实现了一个具有 recursive transformer 的 Bloc 组件。但是,转换器似乎一直在递归调用中返回空累加器。 commen
我永远找不到 F# 核心库的源代码。我知道它应该是开放的,但谷歌在帮助我找到它时对我并不友好,如果是这样,我会查找 Seq.fold 的实现 - 但问题就在这里。 有没有人看到以下代码段有任何问题:
最近我学习了很多 Haskell,并想尝试一些它在 Python 中的巧妙技巧。据我了解,Python的reduce会自动将函数中的迭代变量和累加器设置为reduce中给出的列表的前两个值。在 Has
documentation boost 累加器的 error_of 特性说明它通过以下公式计算平均值的误差: 平方(方差/(计数 - 1)), 其中方差的计算方式是: variance = 1/cou
我正在使用 LongAccumulator 来计算我在 Cassandra 中保存的记录数。 object Main extends App { val conf = args(0) val
Spark 有一个有用的 API,用于以线程安全的方式积累数据 https://spark.apache.org/docs/2.3.0/api/scala/index.html#org.apache.
我想从任意长度的列表中选择任意数量的项目。下拉列表 (QComboBox) 不允许选中项目。如果有很多项目,可检查项目的列表会变得笨拙。 我找到了 this question在用户体验 SE 子站点和
是否可以在分组时通过集合收集字符串?这就是它在 Java 8 中的工作方式: Map discountOptions = p.getDiscountOptions().Stream() .
我是一名优秀的程序员,十分优秀!