for vs forEach

JavaScript performance comparison

Revision 608 of this test case created by Andrii Muzalevskyi

Preparation code

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js">
</script>
      
<script>
Benchmark.prototype.setup = function() {
  var map = new Map([['foo', 3], ['bar', {}], ['baz', undefined]]);

};

Benchmark.prototype.teardown = function() {
  map = undefined;

};
</script>

Test runner

Warning! For accurate results, please disable Firebug before running the tests. (Why?)

Java applet disabled.

Testing in CCBot 2.0.0 / Other 0.0.0
Test Ops/sec
$.each
$.each(values, function(key, value) {
    sum += value;
});
pending…
for loop, cached length, callback
length = values.length;
for (i = 0; i < length; i++) {
    add(values[i], i, values);
}
pending…
for loop, over ent
ent = map.entities();
for (i = 0; i < ent.length; i++) {
    sum += ent[i][1];
}
pending…
for ... in
for (i in values) {
    sum += values[i];
}
pending…
for loop, assignment condition, callback.call
for (i = 0; (value = values[i]) !== undefined; i++) {
    add.call(context, value, i, values);
}
pending…
for loop, cached length, callback.call
length = values.length;
for (i = 0; i < length; i++) {
    add.call(context, values[i], i, values);
}
pending…
for loop, assignment condition
for (i = 0; (value = values[i]) !== undefined; i++) {
    sum += value;
}
pending…
for loop, reverse, pre-decrement
for (i = values.length - 1; i >= 0; --i) {
    sum += values[i];
}
pending…
for loop, reverse, decrement condition
for (i = values.length; i--;) {
    sum += values[i];
}
pending…
for loop, cached length
length = values.length;
for (i = 0; i < length; i++) {
    sum += values[i];
}
pending…
forEach
var d = 0;
map.forEach((x) => {
    d += x;
});
pending…
for loop, reverse
for (i = values.length - 1; i >= 0; i--) {
    sum += values[i];
}
pending…
forEach2
values.forEach(add);
pending…
for loop, assignment condition, reversed
for (i = values.length - 1; (value = values[i]) !== undefined; i--) {
    sum += value;
}
pending…
for loop, assignment condition, callback
for (i = 0; (value = values[i]) !== undefined; i++) {
    add(value, i, values);
}
pending…

Compare results of other browsers

Revisions

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

0 Comments