通过增删改查对比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 是一个介 ...
随机推荐
- python ddt 重写
对此方法重写 def mk_test_name(name, value, index=0): 重写前 index = "{0:0{1}}".format(index + 1, in ...
- Linux下重命名文件或文件夹(mv命令与rename命令)
在Linux下重命名文件或目录,可以使用mv命令或rename命令 mv ———————————— mv命令既可以重命名,又可以移动文件或文件夹. 例子:将目录A重命名为B mv A B 例子:将/a ...
- Python习题-统计日志中访问次数超过限制的IP
#1.1分钟之内ip访问次数超过200次的,就给他的ip加入黑名单#需求分析: #1.读日志,1分钟读一次 #2.获取这1分钟之内所有访问的ip #3.判断ip出现的次数,如果出现200次,那么就加入 ...
- codeforces 617E E. XOR and Favorite Number(莫队算法)
题目链接: E. XOR and Favorite Number time limit per test 4 seconds memory limit per test 256 megabytes i ...
- php各种验证类
<?php /** * 验证类 * */ class VerifyAction{ /** * 是否为空值 */ public static func ...
- mysql调优参考笔记
之前一位童鞋发的: 5版邮件,在用户量很大的情况下,如果做了分布式,如果在后端mysql上执行: mysql> show global status like 'Thread%'; Th ...
- bzoj 4537: [Hnoi2016]最小公倍数 分块+并查集
题目大意: 给定一张n个点m条边的无向图,每条边有两种权.每次询问某两个点之间是否存在一条路径上的边的两种权的最大值分别等于给定值. n,q <= 50000. m <= 100000 题 ...
- pytorch 调用forward 的具体流程
forward方法的具体流程: 以一个Module为例:1. 调用module的call方法2. module的call里面调用module的forward方法3. forward里面如果碰到Modu ...
- bzoj 2597 剪刀石头布 —— 拆边费用流
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2597 不合法的三个人之间的关系就是一个人赢了两次: 记 \( deg[i] \) 表示第 \ ...
- java.util Properties使用记录
转:http://www.2cto.com/px/201006/47834.html 在java.util 包下面有一个类 Properties,该类主要用于读取以项目的配置文件(以.properti ...