通过增删改查对比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 是一个介 ...
随机推荐
- KISSY(JS)炫动导航,缓动应用实例(^_^)
一个基于KISSY的简单的动画导航,效果还不错,有点像flash的效果.鼠标移到每一个连接上,背景滑块会迅速移到该链接下方,同时平滑改变大小,自适应链接尺寸,并伴随来回的轻微波动,动感相当不错,呵呵, ...
- request.post(2种格式)
- Linux课程---1、VMWare安装CentOS虚拟机(安装重要注意)
Linux课程---1.VMWare安装CentOS虚拟机(安装重要注意) 一.总结 一句话总结: 可以先去百度搜一篇对应系统的安装教程:比如 CentOS 7 安装 1.安装VMWare之后,打开w ...
- form 中Enctype=multipart/form-data 的作用
form 中Enctype=multipart/form-data 的作用 ENCTYPE="multipart/form-data"用于表单里有图片上传. <form na ...
- Shiro身份认证---转
目录 1. Shro的概念 2. Shiro的简单身份认证实现 3. Shiro与spring对身份认证的实现 前言: Shiro 可以非常容易的开发出足够好的应用,其不仅可以用在 JavaSE 环境 ...
- CI中site_url和base_url的区别
你若使用site_url("test/php/1");则实际url为 http://domain.com/index.php/test/php/1 若使用base_url(&quo ...
- NOI 模拟赛 #2
得分非常惨惨,半个小时写的纯暴力 70 分竟然拿了 rank 1... 如果 OYJason 和 wxjor 在可能会被爆踩吧 嘤 T1 欧拉子图 给一个无向图,如果一个边集的导出子图是一个欧拉回路, ...
- ACM学习历程—广东工业大学2016校赛决赛-网络赛D 二叉树的中序遍历(数据结构)
题目链接:http://gdutcode.sinaapp.com/problem.php?cid=1031&pid=3 这算是一个胡搞类型的题目.当然肯定是有其数据结构支撑的. 唯一的限制就是 ...
- 使用Visual Studio进行单元测试-Part1
写在开头:Coding ain't done until all the tests run. No unit test no BB. -------------------------------- ...
- Poj_1004_FinancialManagement
一.Description Larry graduated this year and finally has a job. He's making a lot of money, but someh ...