About arrays, collections, and efficiency in JavaScript-Javascript tutorial

Source: Internet
Author: User
JavaScript: About arrays, collections, and efficiency in JavaScript. Javascript tutorial

An array is an internal object provided by JavaScript. It is a standard set. We can add (push), delete (shift) elements, we can also traverse the elements in the for loop, so can we have other sets in addition to arrays in JavaScript?

Because of the language features of JavaScript, We can dynamically add and delete attributes to common objects. Therefore, objects can also be seen as a special set of JS. The following compares the features of Array and Object:

Array:

  • New: var ary = new Array (); or var ary = [];
  • Added: ary. push (value );
  • Delete: delete ary [n];
  • Traversal: for (var I = 0; I <ary. length; ++ I) ary [I];

Object:

  • New: var obj = new Object (); or var obj = {};
  • Added: obj [key] = value; (key is string)
  • Delete: delete obj [key];
  • Traversal: for (var key in obj) obj [key];

From the above comparison, we can see that the Object can be used as a set. in the use of the Popup window to create an infinitely webpage menu (3), I introduced the _ MenuCache __implemented by Eric __, it is also a simulated set object.

If we want to retrieve a specified value in Array, We need to traverse the entire Array:

Var keyword =;
For (var I = 0; I <ary. length; ++ I)
{
If (ary [I] = keyword)
{
// Todo
}
}

However, to retrieve a specified key entry in an Object, you only need to use:

Var key = '';
Var value = obj [key];
// Todo

This feature of the Object can be used to efficiently retrieve the string set of Unique. The time complexity of traversing the Array is O (n), and the time complexity of traversing the Object is O (1 ). Although the for search cost for 10000 sets is dozens of ms, if it is 1000*1000 queries or more, the advantages of using objects are shown. Before that, I made a mapping to map 100 Unique characters to 1000 string arrays, which took 25-30 s! Later, I changed the for traversal to the member reference of the Object simulation set. The same data volume mapping takes only 1.7-2 s !!!

For the collection traversal efficiency (from high to low): var value = obj [key];> for (;)> for (in ). The worst efficiency is for (in). If the set is too large, do not use for (in) traversal.

Related Article

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.