1.Array 和 Map 对比

{ // array and map 增 查 改 删
let map = new Map();
let arr = []; // 增
map.set('a', 1);
arr.push({'a': 1});
console.log('add', map, arr); // add Map(1) {"a" => 1} [{a: 1}] // 查
let map_exist = map.has('a');
let arr_exist = arr.find(item => item.a);
console.log('exist', map_exist, arr_exist); // exist true {a: 1} // 改
map.set('a', 2);
arr.forEach(item => item.a ? item.a = 2 : '');
console.log('mod', map, arr); // mod Map(1) {"a" => 2} [{a: 2}] // 删除
map.delete('a');
let index = arr.findIndex(item=>item.a);
arr.splice(index, 1);
console.log('del', map, arr); // del Map(0) {} []
}

2.Set 和 Array 对比

{ // Set and array
let set = new Set();
let arr = [];
let o = {a: 1}; // 增
set.add(o);
arr.push(o);
console.info('add', set, arr); // add Set(1) {{a: 1}} [{a: 1}] // 查
let set_exist = set.has(o);
let arr_exist = arr.find(item => item.a);
console.log('exist', set_exist, arr_exist); // exist true {a: 1} // 改 Set存储对象的时候存储的是引用,所以修改时直接修改数据元素
set.forEach(item=>item.a? item.a =2:'');
arr.forEach(item => item.a ? item.a = 2 : '');
console.info('mod', set, arr); // mod Set(1) {{a: 2}} [{a: 2}] // 删
set.forEach(item=>item.a? set.delete(item):'');
let index = arr.findIndex(item => item.a);
arr.splice(index, 1);
console.log('del', set, arr); // del Set(0) {} []
}

3. Map 和 Set 和 Object 对比

{ // map set object 注意对比使用成本和实现方式
let item = {a: 1};
let map = new Map();
let set = new Set();
let obj = {}; // 增
map.set('a', 1);
set.add(item);
obj['a'] = 1;
console.log('add', map, set, obj); // add Map(1) {"a" => 1} Set(1) {{a: 1}} {a: 1} // 查
console.log({
map_exist: map.has('a'),
set_exist: set.has(item),
obj_exist: 'a' in obj
}); // {map_exist: true, set_exist: true, obj_exist: true} // 改
map.set('a', 2);
item.a = 2; // set不参与,因为对象存储的是个引用,直接修改元素,没有存储数据元素item可使用forEach遍历修改
obj.a = 2;
console.log('mod', map, set, obj); // mod Map(1) {"a" => 2} Set(1) {{a: 2}} {a: 2} // 删
map.delete('a');
set.delete(item);
delete obj.a;
console.log('del', map, set, obj); // del Map(0){} Set(0){} {}
}

4.总结(基于es6):

从语义上map最好,set需要依赖一个数据元素item语义上和map差不多,使用成本上map优先。
综上所述:在开发过程中涉及数据结构时能使用map不使用数组,考虑数据唯一性时使用set,放弃使用数组和object作为数据存储。

通过增删改查对比Array,Map,Set,Object的使用成本和实现方式的更多相关文章

  1. PHP程序中使用PDO对象实现对数据库的增删改查操作的示例代码

    PHP程序中使用PDO对象实现对数据库的增删改查操作(PHP+smarty) dbconn.php <?php //------------------------使用PDO方式连接数据库文件- ...

  2. bootstrap+Ajax+SSM(maven搭建)实现增删改查

    https://www.jianshu.com/p/d76316b48e3e 源码: https://github.com/Ching-Lee/crud 功能点: 分页 数据校验 ajax Rest风 ...

  3. mybatis中的增删改查操作

    在这一个部分,主要进行增删改查的示例书写. 增删改查可以基于xml的,也可以基于注解的方式. 一:对单条数据的查询 1.目录结构 这个使得目录更加清晰 2.User.java 这个使用以前的user表 ...

  4. Django-ORM增删改查

    ORM对单表进行增删改查 一,增加记录 #第一种方式 b=Book(name="Linux",price=66,author="kelvin",pub_date ...

  5. 元组,列表的增删改查, for,range 循环

    1. list(增删改查) 列表可以装大量的数据. 不限制数据类型. 表示方式:[] 方括号中的每一项用逗号隔开 列表和字符串一样.也有索引和切片 常用的功能: 1. 增: append() 2. 删 ...

  6. 1、list 的一些相关操作 2、增删改查 3、tuple 的操作 4、range

    1. list(增删改查) 列表可以装大量的数据. 不限制数据类型. 表示方式:[] 方括号中的每一项用逗号隔开 列表和字符串一样.也有索引和切片 # lst = [1, "周杰伦" ...

  7. Android-SQLiteOpenHelper里增删改查

    为什么要写一篇,Android-SQLiteOpenHelper里增删改查,的文章呢: 因为之前的方式是:MySQLiteOpenHelper(只负责 生成打开据库/生成打开表/升级表),在其他端:完 ...

  8. winform 窗体实现增删改查(CRUD)共用模式

    转载:http://www.csframework.com/archive/2/arc-2-20110617-1632.htm 高度封装的编辑窗体 http://www.cnblogs.com/wuh ...

  9. python 全栈开发,Day124(MongoDB初识,增删改查操作,数据类型,$关键字以及$修改器,"$"的奇妙用法,Array Object 的特殊操作,选取跳过排序,客户端操作)

    一.MongoDB初识 什么是MongoDB MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介 ...

随机推荐

  1. window.onload 添加多个函数绑定

    window.onload = function(){alert(2)} function addEvent (fun) { var old = window.onload; if(typeof ol ...

  2. PyQt5布局管理(1)

    Qt布局管理按简单分可分为绝对位置布局和布局管理器布局 一.绝对位置布局: 组件不放在布局管理器中,通过函数setGeometry(x,y,width,height)来设定组件相对其父窗口的位置.其中 ...

  3. codeforces 627B B. Factory Repairs(线段树)

    B. Factory Repairs time limit per test 4 seconds memory limit per test 256 megabytes input standard ...

  4. 雅礼集训 2017 Day2 水箱 可并堆

    题目描述 给出一个长度为 n 宽度为 1 ,高度无限的水箱,有 n−1  个挡板将其分为 n 个 1 - 1 的小格,然后向每个小格中注水,水如果超过挡板就会溢出到挡板的另一边,这里的水是满足物理定律 ...

  5. 【JVM】java方法区

    java方法区[名词解析]        --->和java堆一样,方法区是一块所有线程共享的内存区域.        --->保存系统的类信息,比如,类的字段,方法,常量池等.      ...

  6. 【Caffe】Ubuntu 安装 Caffe gpu版

    安装环境:Ubuntu 16.04lts 64位, gcc5.4 gpu1050ti,cuda8.0,cudnn5.1.10 1. 安装依赖库 sudo apt-get install libprot ...

  7. 【LeetCode】036. Valid Sudoku

    题目: Determine if a Sudoku is valid, according to: Sudoku Puzzles - The Rules. The Sudoku board could ...

  8. VC6++常用快捷键

    VC6快捷键大全(转载) VC6快捷键大全,记在这里,方便查阅.F1: 帮助Ctrl+O :OpenCtrl+P :PrintCtrl+N :NewCtrl+Shift+F2 :清除所有书签F2 :上 ...

  9. 继承Application以实现全局资源共享

    原文地址:http://www.cnblogs.com/Dentist/p/Mr_Dentist_.html 每个程序运行时会创建一个Application类的对象且仅有一个.在app结束时这个App ...

  10. WPF Visibility属性用法

    WPF Visibility属性用法 Visible 元素在窗体中正常显示 Collaspsed 元素不显示,也不占用空间 Hidden 元素不显示,但是任然为它保留空间