Toggle navigation
MeasureThat.net
Create a benchmark
Tools
Feedback
FAQ
Register
Log In
Run results for:
Array.find vs. Map.get on large datasets
Test the performance of Array.find vs. Map.get, with various array sizes, and with/without conversion from array to map
Go to the benchmark
Embed
Embed Benchmark Result
Run details:
User agent:
Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/605.1.15 (KHTML, like Gecko) Version/18.4 Safari/605.1.15
Browser:
Safari 18
Operating system:
Mac OS X 10.15.7
Device Platform:
Desktop
Date tested:
one year ago
Test name
Executions per second
Array.find, 1 000 000 elements
2034.9 Ops/sec
Map.get, 1 000 000 elements
403354560.0 Ops/sec
Array to Map + Map.get, 5000 lookups
17.2 Ops/sec
Array.find, 5000 lookups
40.5 Ops/sec
Script Preparation code:
function getRandomElement(id) { return { id, a: Math.random(), b: Math.random(), c: Math.random(), } } function getArray(length) { const result = []; for (let i = 0; i < length; i++) { result.push(getRandomElement(i)) } return result; } function arrayToMap(array) { return new Map(array.map(el => [el.id, el])); } function getRandomInt(max) { return Math.floor(Math.random() * max); } array_small = getArray(10000); array_large = getArray(1000000); map_small = arrayToMap(array_small); map_large = arrayToMap(array_large);
Tests:
Array.find, 1 000 000 elements
const target = getRandomInt(999999); array_large.find(el => el.id === target);
Map.get, 1 000 000 elements
const target = getRandomInt(999999); map_large.get(target)
Array to Map + Map.get, 5000 lookups
const map = arrayToMap(array_large); for (let i = 0; i < 5000; i++) { const target = getRandomInt(9999); map.get(target); }
Array.find, 5000 lookups
for (let i = 0; i < 5000; i++) { const target = getRandomInt(9999); array_large.find(el => el.id === target) }