停止在JavaScript中将对象用作哈希映射

 Map是日常编程中比较常用的数据结构之一。它保留了可以很容易地通过其键来访问的键值对。在Java中,使用HashMap来实现这个目的是很明显的。然而,在JavaScript中,使用一个普通的对象来实现这个目标是非常方便的。

专注于为中小企业提供成都网站设计、做网站服务,电脑端+手机端+微信端的三站合一,更高效的管理,为中小企业鄄城免费做网站提供优质的服务。我们立足成都,凝聚了一批互联网行业人才,有力地推动了成百上千家企业的稳健成长,帮助中小企业通过网站建设实现规模扩充和转变。

 
 
  1. const map = {}; 
  2.  
  3. // 插入键值对 
  4. map['key1'] = 'value1'; 
  5. map['key2'] = 'value2'; 
  6. map['key3'] = 'value3'; 
  7.  
  8. // 检查map包含的键 
  9. if (map.hasOwnProperty('key1')) { 
  10.   console.log('Map contains key1'); 
  11.  
  12. // 通过特定的键获得值 
  13. console.log(map['key1']); 

但是JavaScript中有一个专门用于此目的的内置数据结构:Map。让我给你一些理由,让你喜欢Map而不是普通的对象。

1.更多键类型

对象只能有符号(symbols)或字符串。Map可以将任何类型的值作为键:对象,函数或基元(primitives)。

 
 
  1. const map = new Map(); 
  2. const myFunction = () => console.log('I am a useful function.'); 
  3. const myNumber = 666; 
  4. const myObject = { 
  5.   name: 'plainObjectValue', 
  6.   otherKey: 'otherValue' 
  7. }; 
  8. map.set(myFunction, 'function as a key'); 
  9. map.set(myNumber, 'number as a key'); 
  10. map.set(myObject, 'object as a key'); 
  11.  
  12. console.log(map.get(myFunction)); // function as a key 
  13. console.log(map.get(myNumber)); // number as a key 
  14. console.log(map.get(myObject)); // object as a key 

2.更好地确定大小

Map提供了一个size属性,但一个普通对象的大小却必须通过艰难的方式来确定。确定Map的大小可以在O(1)时间内完成,而确定一个普通对象的大小则需要O(n)步。

 
 
  1. const map = new Map(); 
  2. map.set('someKey1', 1); 
  3. map.set('someKey2', 1); 
  4. ... 
  5. map.set('someKey100', 1); 
  6.  
  7. console.log(map.size) // 100, Runtime: O(1) 
  8.  
  9. const plainObjMap = {}; 
  10. plainObjMap['someKey1'] = 1; 
  11. plainObjMap['someKey2'] = 1; 
  12. ... 
  13. plainObjMap['someKey100'] = 1; 
  14.  
  15. console.log(Object.keys(plainObjMap).length) // 100, Runtime: O(n) 

3.更好的性能

对Map进行了优化,以便频繁地添加和删除条目。

此外,Map的条目数可以在恒定的时间内被检索,而一个普通对象的条目数必须被计算,这需要O(n)时间。

以我的Macbook Pro为例,这是一张有1000万个条目的Map的平均大小确定时间。

  • 普通JS对象: ~1.6 s
  • Map: < 1 ms

此外,它不需要将任何键转换为字符串,这可以节省很多时间。

4.直接迭代

对象必须通过获取键并对其进行迭代。另一方面,Map是可迭代的,这意味着它可以直接迭代。

 
 
  1. const map = new Map(); 
  2. map.set('someKey1', 1); 
  3. map.set('someKey2', 2); 
  4. map.set('someKey3', 3); 
  5.  
  6. for (let [key, value] of map) { 
  7.   console.log(`${key} = ${value}`); 
  8. // someKey1 = 1 
  9. // someKey2 = 2 
  10. // someKey3 = 3 
  11.  
  12. const plainObjMap = {}; 
  13. plainObjMap['someKey1'] = 1; 
  14. plainObjMap['someKey2'] = 2; 
  15. plainObjMap['someKey3'] = 3; 
  16.  
  17. for (let key of Object.keys(plainObjMap)) { 
  18.   const value = plainObjMap[key]; 
  19.   console.log(`${key} = ${value}`); 
  20. // someKey1 = 1 
  21. // someKey2 = 2 
  22. // someKey3 = 3 

5.key顺序

在ECMAScript 2015之前,一个对象的键不保证以任何特定的顺序出现。在Map上迭代保证键按插入顺序出现。

6.无键覆盖

一个普通对象由于其原型已经包含了一些键,你的键和对象已经包含的键之间可能会有冲突。Map在创建时不包含任何键。

注意:自ECMAScript 2015年起,你可以通过使用 Object.create(null) 来创建你的普通对象图来避免意外的键覆盖。

 
 
  1. const map = new Map(); 
  2. map.set('someKey1', 1); 
  3. map.set('someKey2', 2); 
  4. map.set('toString', 3); // No problem for Map 
  5.  
  6. const plainObjMap = new Map(); 
  7. plainObjMap['someKey1'] = 1; 
  8. plainObjMap['someKey2'] = 2; 
  9. plainObjMap['toString'] = 3; // Oops, native property 

当前题目:停止在JavaScript中将对象用作哈希映射
转载源于:http://www.csdahua.cn/qtweb/news39/203439.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网