javascript稀疏数组(sparse array)和密集数组用法分析


Posted in Javascript onDecember 28, 2016

本文实例讲述了javascript稀疏数组(sparse array)和密集数组用法。分享给大家供大家参考,具体如下:

学习underscore.js数组相关API的时候,遇到了sparse array这个东西,以前没有接触过。

这里学习下什么是稀疏数组和密集数组。

什么是密集数组呢?在Java和C语言中,数组是一片连续的存储空间,有着固定的长度。加入数组其实位置是address,长度为n,那么占用的存储空间是address[0],address[1],address[2].......address[n-1]。即数组元素之间是紧密相连的,不存在空隙。如下的js代码创建的就是一个密集数组

var data = [3,1,6,9,2];

什么是稀疏数组呢?与密集数组相反,javascript并不强制要求数组元素是紧密相连的,即允许间隙的存在。如下的js代码是合法的:

var sparse = new Array();
sparse[0] = 0;
sparse[3] = 3;
alert(sparse[0]);//输出0
alert(sparse[1]);//输出undefined

1、创建稀疏数组

如下代码创建了一个固定长度的稀疏数组

var a = new Array(3);
a[2] = 1;
alert(a[0]);//undefined
alert(a[2]);//1

说白了js中建立稀疏数组很容易,只要你故意让数组元素之间存在间隙即可。如

var arr = [];
arr[0] = 0;
arr[200] = 200;

2、创建密集数组

可以看到js中的数组一般都是稀疏的,一般来说稀疏数组的遍历比较麻烦。

var dense = Array.apply(null, Array(3));

这行代码等同于var  dense = Array(undefined, undefined, undefined) ;呵呵是不是觉得很奇怪,这种方式跟稀疏数组没有什么差别。看代码:

//稀疏数组
var array = new Array(3);
array[2] = "name";
for(var a in array)
{
  console.log("index=" + a + ",value=" + array[a]);
}
// 密集数组
var dense = Array.apply(null, Array(3));
dense[2] = "name";
for(var a in dense)
{
  console.log("index=" + a + ",value=" + dense[a]);
}

用F12观察控制台输出结果是:

javascript稀疏数组(sparse array)和密集数组用法分析

可以看到确实是有差别的:稀疏数组只遍历了一次(因为只有一个元素),密集数组遍历了3次。

3、总结

JavaScript中的数组并不像我们在C或java等语言中遇到的常规数组,在js中数组并不是起始地址+长度构成的一片连续的地址空间。

javascript中数组其实就是个对象,只不过会自动管理一些"数字"属性和length属性罢了。

说的更直接一点,JavaScript中的数组根本没有索引,因为索引应该是数字,而JavaScript中数组的索引其实是字符串。

arr[1]其实就是arr["1"],给arr["1000"] = 1,arr.length也会自动变为1001。

这些表现的根本原因就是:JavaScript中的对象就是字符串到任意值的键值对。

虽然稀疏数组和密集数组差别不大,javascript也没有语法强制数组是稀疏的还是密集的,这不过是概念上的区分。

最佳实践是:就把js数组当成是java或C中的数组,由我们程序员来负责让js的数组元素是连续的。

var array = [1,2,3,4];

如:

var array = new Array();array[0]=0;array[1]=1;

这样创建的js数组,就符合我们熟悉的数组了。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
客户端脚本中常常出现的一些问题和调试技巧
Jan 09 Javascript
自己写了一个展开和收起的多更能型的js效果
Mar 05 Javascript
jQuery实现复选框全选/取消全选/反选及获得选择的值
Jun 12 Javascript
JavaScript和CSS交互的方法汇总
Dec 02 Javascript
javascript操作select元素实例分析
Mar 27 Javascript
AngularJS基础 ng-switch 指令简单示例
Aug 03 Javascript
JS如何设置cookie有效期为当天24点并弹出欢迎登陆界面
Aug 04 Javascript
jQuery按需加载轮播图(web前端性能优化)
Feb 17 Javascript
深入解析Vue 组件命名那些事
Jul 18 Javascript
CryptoJS中AES实现前后端通用加解密技术
Dec 18 Javascript
JS实现的全选、全不选及反选功能【案例】
Feb 19 Javascript
nestjs中异常过滤器Exceptionfilter的具体使用
Feb 07 Javascript
JS中闭包的经典用法小结(2则示例)
Dec 28 #Javascript
AngularJS实现网站换肤实例
Feb 19 #Javascript
详解js树形控件—zTree使用总结
Dec 28 #Javascript
js 轮播效果实例分享
Dec 28 #Javascript
JS正则RegExp.test()使用注意事项(不具有重复性)
Dec 28 #Javascript
Bootstrap 模态框实例插件案例分析
Dec 28 #Javascript
Angular使用ng-messages与PHP进行表单数据验证
Dec 28 #Javascript
You might like
PHP 中魔术常量的实例详解
2017/10/26 PHP
php处理抢购类功能的高并发请求
2018/02/08 PHP
php设计模式之策略模式实例分析【星际争霸游戏案例】
2020/03/26 PHP
用tip解决Ext列宽度不够的问题
2008/12/13 Javascript
js 代码集(学习js的朋友可以看下)
2009/07/22 Javascript
JQuery中each()的使用方法说明
2010/08/19 Javascript
Jquery命名冲突解决的五种方案分享
2012/03/16 Javascript
DOM事件阶段以及事件捕获与事件冒泡先后执行顺序(图文详解)
2015/08/18 Javascript
jQuery ui实现动感的圆角渐变网站导航菜单效果代码
2015/08/26 Javascript
Bootstrap学习笔记之js组件(4)
2016/06/12 Javascript
利用bootstrapValidator验证UEditor
2016/09/14 Javascript
Vue.js实现分页查询功能
2020/11/15 Javascript
使用Angular CLI进行Build(构建)和Serve详解
2018/03/24 Javascript
JavaScript canvas实现雪花随机动态飘落
2020/02/08 Javascript
js简单实现自动生成表格功能示例
2020/06/02 Javascript
关于Node.js中频繁修改代码重启服务器的问题
2020/10/15 Javascript
解决vue项目中出现Invalid Host header的问题
2020/11/17 Javascript
[01:11:21]DOTA2-DPC中国联赛 正赛 Phoenix vs CDEC BO3 第三场 3月7日
2021/03/11 DOTA
Python selenium文件上传方法汇总
2020/11/19 Python
Python多进程并发与多线程并发编程实例总结
2018/02/08 Python
python3之模块psutil系统性能信息使用
2018/05/30 Python
tensorflow: variable的值与variable.read_value()的值区别详解
2018/07/30 Python
浅谈Python批处理文件夹中的txt文件
2019/03/11 Python
执行Django数据迁移时报 1091错误及解决方法
2019/10/14 Python
python实现KNN分类算法
2019/10/16 Python
Pytorch中的自动求梯度机制和Variable类实例
2020/02/29 Python
基于python实现复制文件并重命名
2020/09/16 Python
python爬虫今日热榜数据到txt文件的源码
2021/02/23 Python
2013的个人自我评价
2013/12/26 职场文书
目标责任书范本
2014/04/16 职场文书
什么是就业协议书
2014/04/17 职场文书
应届毕业生自荐书
2014/06/18 职场文书
Python列表删除重复元素与图像相似度判断及删除实例代码
2021/05/07 Python
MySQL中B树索引和B+树索引的区别详解
2022/03/03 MySQL
阿里云服务器Ubuntu 20.04上安装Odoo 15
2022/05/20 Servers
python如何将mat文件转为png
2022/07/15 Python