javascript中類比hashtable對數組進行快速尋找

來源:互聯網
上載者:User
javascript中類比hashtable對數組進行快速尋找

    面對一個數組,有時候希望能夠直接存取一個特定元素,而不是對整個數組迴圈來尋找該元素。想想C#中的查詢方便的Hashtable,javascript可以類比該技術以實現對數組的快速尋找。
    在javascript中,array被視作一個對象,這樣就可以為其定義屬性(property)而且不會影響數組中的原有資料。屬性可以通過其名稱進行引用。
    實現的關鍵:對一個已存在的數組,我們必須為其每個元素產生一個唯一標識值,這樣才能有效得訪問到所有元素。
    作為樣本,首先建立一個自訂對象employee, 有兩個屬性name和age。

     function employee(name, age)
     {
         this.name = name;
         this.age = age;
     }

    建立數組:

     var employees = new Array();
     employees[employees.length] = new employee("Anders", 25);
     employees[employees.length] = new employee("Andrew", 27);
     employees[employees.length] = new employee("Bill", 45);

   
    類比hashtable:

     for(var i = 0; i < employees.length; i++)
     {
         employees[employees[i].name] = employees[i];
     }

    這裡用employees[i]的name屬性作為hashtable的key,employees[i]作為value,這樣就可以通過name進行快速尋找;
    比如:var BillsAge = employees["Bill"].age;
   
    注意:上面定義的數組中,很難避免會出現兩個name重複的元素,那麼這時就會出現問題,後加的對象會覆蓋掉原來的對象。所以要盡量保證用作hashtable的key的變數值的唯一性,這樣才能保證訪問到每一個元素。如果對象的一個屬性不能保證唯一性,可以考慮多個屬性的合并值。

   

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

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.