通过增删改查对比Array,Map,Set,Object的使用成本和实现方式
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的使用成本和实现方式的更多相关文章
- PHP程序中使用PDO对象实现对数据库的增删改查操作的示例代码
PHP程序中使用PDO对象实现对数据库的增删改查操作(PHP+smarty) dbconn.php <?php //------------------------使用PDO方式连接数据库文件- ...
- bootstrap+Ajax+SSM(maven搭建)实现增删改查
https://www.jianshu.com/p/d76316b48e3e 源码: https://github.com/Ching-Lee/crud 功能点: 分页 数据校验 ajax Rest风 ...
- mybatis中的增删改查操作
在这一个部分,主要进行增删改查的示例书写. 增删改查可以基于xml的,也可以基于注解的方式. 一:对单条数据的查询 1.目录结构 这个使得目录更加清晰 2.User.java 这个使用以前的user表 ...
- Django-ORM增删改查
ORM对单表进行增删改查 一,增加记录 #第一种方式 b=Book(name="Linux",price=66,author="kelvin",pub_date ...
- 元组,列表的增删改查, for,range 循环
1. list(增删改查) 列表可以装大量的数据. 不限制数据类型. 表示方式:[] 方括号中的每一项用逗号隔开 列表和字符串一样.也有索引和切片 常用的功能: 1. 增: append() 2. 删 ...
- 1、list 的一些相关操作 2、增删改查 3、tuple 的操作 4、range
1. list(增删改查) 列表可以装大量的数据. 不限制数据类型. 表示方式:[] 方括号中的每一项用逗号隔开 列表和字符串一样.也有索引和切片 # lst = [1, "周杰伦" ...
- Android-SQLiteOpenHelper里增删改查
为什么要写一篇,Android-SQLiteOpenHelper里增删改查,的文章呢: 因为之前的方式是:MySQLiteOpenHelper(只负责 生成打开据库/生成打开表/升级表),在其他端:完 ...
- winform 窗体实现增删改查(CRUD)共用模式
转载:http://www.csframework.com/archive/2/arc-2-20110617-1632.htm 高度封装的编辑窗体 http://www.cnblogs.com/wuh ...
- python 全栈开发,Day124(MongoDB初识,增删改查操作,数据类型,$关键字以及$修改器,"$"的奇妙用法,Array Object 的特殊操作,选取跳过排序,客户端操作)
一.MongoDB初识 什么是MongoDB MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介 ...
随机推荐
- vmware workstation pro 安装ubantu虚拟机
参考:https://ywnz.com/linuxaz/3904.html https://www.zhihu.com/search?type=content&q=vmware%20works ...
- node.js redis对事务的控制
redis对事务的支持还是比较差的,就是把所有的执行命令方到队列中一个一个执行 multi开启一个事务,exec执行事务集合中的命令 代码: var redisClient; redisClient. ...
- 经过一年时间的沉淀 再次回首 TCP Socket服务器编程 (二)
------------------ 前言 ------------------ 发了第一篇文章后,有不少同志留言,看来socket编程仍然是软件系统里面一个比较难的部分. 第一篇文章主要介绍了传输协 ...
- Poj 1125 Stockbroker Grapevine(Floyd算法求结点对的最短路径问题)
一.Description Stockbrokers are known to overreact to rumours. You have been contracted to develop a ...
- C++STL库中map容器常用应用
#include<iostream> #include<cstdio> #include<map> //按键值大小构成二叉搜索树 using namespace s ...
- HDOJ2141(map在二分搜索中的应用)
#include<iostream> #include<cstdio> #include<map> #include<algorithm> using ...
- 【jQuery】praseFloat()方法的用法及注意事项
[jQuery]praseFloat()方法的用法及注意事项 praseFloat(): 用于解析一个字符串,并返回一个浮点数 语法: praseFloat(strin ...
- js数组中的reverse()方法
reverse方法是将数组中的元素的顺序进行反转,在原数组上操作,然后返回原数组.由于本人是学习js的新人,对reverse函数进行了几个小实验,以下实验均在Chrome浏览器上运行 实验一:reve ...
- [413D][搜索]D - Field expansion
http://codeforces.com/contest/799/problem/D 解题关键:因为3^11>100000,所以若只把2单独拿出,最多只需要暴力2^11次,故只需要dfs一下即 ...
- 浏览器默认标签样式总结及css初始化程序
html中的大部分的标签都有一些糟糕的样式,有的是标签天然自带的,有的是浏览器默认设置的,我们在写网页时,这些默认的样式就会时不时的跳出来捣一下乱,搞得我们很是无奈.所以成手在写css样式时,一般都会 ...