Loop vs map vs forEach (v17)

Revision 17 of this benchmark created by Fredrik Borgström on


Setup

var range = [];
  
  for (var i = 0; i < 10000; i++) {
    range.push({
      name: "Hello",
      value: 5
    });
  }

Test runner

Ready to run.

Testing in
TestOps/sec
forEach
var result = new Array(range.length);

range.forEach(function(item, idx) {
  item.name = 'hi';
  item.value = 6;
  result[idx] = item;
});
ready
map
var result = range.map(function(item) {
  item.name = 'hi';
  item.value = 6;
  return item;
});
ready
while
var item,
  ln = range.length,
  result = new Array(ln);

while (--ln > -1) {
  item = range[ln];
   item.name = 'hi';
  item.value = 6;
  result[ln] = item;
}
ready
forEach es6
const res = new Array(range.length);

range.forEach((item, idx) => {
  item.name = 'hi';
  item.value = 6;
  result[idx] = item;
});
ready
Loop
var i,
  item,
  ln = range.length,
  result = new Array(ln);

for (i = 0; i < ln; i++) {
  item = range[i];
  item.name = 'hi';
  item.value = 6;
}
ready
forEach using push
var result = [];

range.forEach(function(item) {
  item.name = 'hi';
  item.value = 6;
  result.push(item);
});
ready

Revisions

You can edit these tests or add more tests to this page by appending /edit to the URL.