jsPerf.app is an online JavaScript performance benchmark test runner & jsperf.com mirror. It is a complete rewrite in homage to the once excellent jsperf.com now with hopefully a more modern & maintainable codebase.
jsperf.com URLs are mirrored at the same path, e.g:
https://jsperf.com/negative-modulo/2
Can be accessed at:
https://jsperf.app/negative-modulo/2
Compare native Map implementation vs using an object as a hash map. This revision takes the time to compute a random string out of the loop, which highlights the actual speed difference much better.
<script>
function randomString()
{
var text = "";
var possible = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
for( var i=0; i < 5; i++ )
text += possible.charAt(Math.floor(Math.random() * possible.length));
return text;
}
var preComputedRandomKeys = [];
var preComputedRandomVals = [];
for (var i=0; i < 100000; i++) {
preComputedRandomKeys[i] = randomString();
preComputedRandomVals[i] = randomString();
}
</script>
var map = new Map();
var obj = {};
var map2 = new Map();
var obj2 = {};
for (var i=0; i < 100000; i++) {
map2.set(preComputedRandomKeys[i], preComputedRandomVals[i]);
obj2[preComputedRandomKeys[i]] = preComputedRandomVals[i];
}
for (var i=0; i < 100000; i++) {
map2.set(preComputedRandomKeys[i], map2.get(preComputedRandomKeys[i]));
obj2[preComputedRandomKeys[i]] = obj2[preComputedRandomKeys[i]];
}
Ready to run.
Test | Ops/sec | |
---|---|---|
map.set(key,val) |
| ready |
obj[key] = val; |
| ready |
Iterate Map |
| ready |
Iterate Object |
| ready |
val = map.get(key) |
| ready |
val = obj[key] |
| ready |
You can edit these tests or add more tests to this page by appending /edit to the URL.