在JavaScript中对数组求和的最快方法是什么?快速搜索一下a few different methods,但如果可能的话,我想要一个本机解决方案。这将在SpiderMonkey下运行。
在我一直使用的盒子里思考:
var count = 0;
for(var i = 0; i < array.length; i++)
{
count = count + array[i];
}
我相信有一种比直接迭代更好的方法。
发布于 2010-09-22 00:58:49
您应该能够使用reduce
。
var sum = array.reduce(function(pv, cv) { return pv + cv; }, 0);
而在ES6中引入了arrow functions,事情就更简单了:
sum = array.reduce((pv, cv) => pv + cv, 0);
发布于 2013-08-06 05:19:36
在寻找数组求和的最佳方法时,我写了一个性能测试。
在Chrome中,"reduce“似乎要优越得多
我希望这能帮到你
// Performance test, sum of an array
var array = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10];
var result = 0;
// Eval
console.time("eval");
for(var i = 0; i < 10000; i++) eval("result = (" + array.join("+") + ")");
console.timeEnd("eval");
// Loop
console.time("loop");
for(var i = 0; i < 10000; i++){
result = 0;
for(var j = 0; j < array.length; j++){
result += parseInt(array[j]);
}
}
console.timeEnd("loop");
// Reduce
console.time("reduce");
for(var i = 0; i < 10000; i++) result = array.reduce(function(pv, cv) { return pv + parseInt(cv); }, 0);
console.timeEnd("reduce");
// While
console.time("while");
for(var i = 0; i < 10000; i++){
j = array.length;
result = 0;
while(j--) result += array[i];
}
console.timeEnd("while");
eval: 5233.000ms
循环时间: 255.000ms
reduce: 70.000ms
而: 214.000ms
发布于 2017-06-15 23:09:02
或者你可以用邪恶的方式来做。
var a = [1,2,3,4,5,6,7,8,9];
sum = eval(a.join("+"));
;)
https://stackoverflow.com/questions/3762589
复制相似问题