Array Performance (v169)

Revision 169 of this benchmark created on


Description

Manual array lookups vs. holey arrays.

Setup

var a1 = [
      {id: 29938, name: 'name1'},
      {id: 32994, name: 'name1'},
      {id: 32995, name: 'name1'},
      {id: 32996, name: 'name1'},
      {id: 32997, name: 'name1'},
      {id: 32998, name: 'name1'},
      {id: 32999, name: 'name1'},
      {id: 33000, name: 'name1'},
      {id: 33001, name: 'name1'},
      {id: 33002, name: 'name1'}
    ];

    var a2 = [];
    a2[29938] = {id: 29938, name: 'name1'};
    a2[32994] = {id: 32994, name: 'name1'};
    a2[32995] = {id: 32995, name: 'name1'};
    a2[32996] = {id: 32996, name: 'name1'};
    a2[32997] = {id: 32997, name: 'name1'};
    a2[32998] = {id: 32998, name: 'name1'};
    a2[32999] = {id: 32999, name: 'name1'};
    a2[33000] = {id: 33000, name: 'name1'};
    a2[33001] = {id: 33001, name: 'name1'};
    a2[33002] = {id: 33002, name: 'name1'};
    var o = {};
    o['29938'] = {id: 29938, name: 'name1'};
    o['32994'] = {id: 32994, name: 'name1'};
    o['32995'] = {id: 32995, name: 'name1'};
    o['32996'] = {id: 32996, name: 'name1'};
    o['32997'] = {id: 32997, name: 'name1'};
    o['32998'] = {id: 32998, name: 'name1'};
    o['32999'] = {id: 32999, name: 'name1'};
    o['33000'] = {id: 33000, name: 'name1'};
    o['33001'] = {id: 33001, name: 'name1'};
    o['33002'] = {id: 33002, name: 'name1'};

Test runner

Ready to run.

Testing in
TestOps/sec
Manual Array Lookup
var id = 33002;
for (var i = 0; i < a1.length; i++) {
  if (a1[i].id === id) result = a1[i];
}
 
ready
Holey Array by Index
var id = 33002;
var result = a2[id];
ready
Object by Key
var id = '33002';
var result = o[id];
 
ready

Revisions

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