028-86922220

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

JavaScript中怎么创建和填充任意长度的数组-创新互联

这篇文章主要介绍了JavaScript中怎么创建和填充任意长度的数组,具有一定借鉴价值,需要的朋友可以参考下。希望大家阅读完这篇文章后大有收获。下面让小编带着大家一起了解一下。

成都网站建设公司更懂你!创新互联公司只做搜索引擎喜欢的网站!成都网站制作前台采用搜索引擎认可的DIV+CSS架构,全站HTML静态,H5页面制作+CSS3网站,提供:网站建设,微信开发,成都小程序开发,商城网站建设成都app软件开发公司,空间域名,服务器租售,网站代托管运营,微信公众号代托管运营。

创建数组的最佳方法是通过字面方式:

const arr = [0,0,0];

不过这并不是长久之计,比如当我们需要创建大型数组时。这篇博文探讨了在这种情况下应该怎么做。

没有空洞的数组往往表现得更好

在大多数编程语言中,数组是连续的值序列。在 JavaScript 中,Array 是一个将索引映射到元素的字典。它可以存在空洞(holes)—— 零和数组长度之间的索引没有映射到元素(“缺失索引”)。例如,下面的 Array 在索引 1 处有一个空洞:

> Object.keys(['a',, 'c'])
[ '0', '2' ]

没有空洞的数组也称为dense packed。密集数组往往表现更好,因为它们可以连续存储(内部)。一旦出现了空洞,内部表示就必须改变。我们有两种选择:

不管是哪种情况,如果引擎遇到一个空洞,它不能只返回undefined,它必须遍历原型链并搜索一个名称为“空洞索引”的属性,这需要花费更多时间。

在某些引擎中,例如V8,如果切换到性能较低的数据结构,这种改变将会是永久性的。即使所有空洞都被填补,它们也不会再切换回来了。

关于 V8 是如何表示数组的,请参阅Mathias Bynens的文章“V8中的元素类型”。

创建数组Array构造函数

如果要创建具有给定长度的 Array,常用的方法是使用Array构造函数 :

const LEN = 3;
const arr = new Array(LEN);
assert.equal(arr.length, LEN);
// arr only has holes in it
assert.deepEqual(Object.keys(arr), []);

这种方法很方便,但是有两个缺点:

Array构造函数后面加上.fill()方法

.fill()方法会更改当前的 Array 并使用指定的值去填充它。这有助于在用new Array()创建数组后对其进行初始化:

const LEN = 3;
const arr = new Array(LEN).fill(0);
assert.deepEqual(arr, [0, 0, 0]);

警告:如果你用对象作为参数去.fill()一个数组,所有元素都会引用同一个实例(也就是这个对象没有被克隆多份):

const LEN = 3;
const obj = {};

const arr = new Array(LEN).fill(obj);
assert.deepEqual(arr, [{}, {}, {}]);

obj.prop = true;
assert.deepEqual(arr,
  [ {prop:true}, {prop:true}, {prop:true} ]);

稍后我们会遇到的一种填充方法(Array.from())则没有这个问题。

.push()方法
const LEN = 3;
const arr = [];
for (let i=0; i < LEN; i++) {
  arr.push(0);
}
assert.deepEqual(arr, [0, 0, 0]);

这一次,我们创建并填充了一个数组,同时里面没有出现漏洞。所以操作这个数组时应该比用构造函数创建的更快。不过创建数组的速度比较慢,因为引擎可能需要随着数组的增长多次重新分配连续的内存。

使用undefined填充数组

Array.from()将 iterables 和类似数组的值转换为 Arrays ,它将空洞视为undefined元素。这样可以用它将每个空洞都转换为undefined

> Array.from({length: 3})
[ undefined, undefined, undefined ]

参数{length:3}是一个长度为 3 的类似 Array 的对象,其中只包含空洞。也可以使用new Array(3),但这样一般会创建更大的对象。
下面这种方式仅适用于可迭代的值,并且与Array.from()具有类似的效果:

> [...new Array(3)]
[ undefined, undefined, undefined ]

不过Array.from()通过new Array()创建它的结果,所以你得到的仍然是一个稀疏数组。

使用  Array.from() 进行映射

如果提供映射函数作为其第二个参数,则可以使用Array.from()进行映射。

用值填充数组按照数值范围进行创建

另一种创建升序整数数组的方法是用.keys(),它也将空洞看作是undefined元素:

> [...new Array(3).keys()]
[ 0, 1, 2 ]

.keys()返回一个可迭代的序列。我们将其展开并转换为数组。

备忘速查:创建数组

用空洞或undefined填充:

填充任意值:

用整数范围填充:

推荐的模式

我更喜欢下面的方法。我的侧重点是可读性,而不是性能。

如果你正在处理整数或浮点数的数组,请考虑Typed Arrays—— 它就是为这个目的而设计的。它们不能存在空洞,并且总是用零进行初始化。

提示:一般来说数组的性能无关紧要

感谢你能够认真阅读完这篇文章,希望小编分享JavaScript中怎么创建和填充任意长度的数组内容对大家有帮助,同时也希望大家多多支持创新互联建站,关注创新互联网站制作公司行业资讯频道,遇到问题就找创新互联建站,详细的解决方法等着你来学习!


新闻名称:JavaScript中怎么创建和填充任意长度的数组-创新互联
本文网址:http://www.tsicrk.com/article/ehoos.html

其他资讯

让你的专属顾问为你服务

1.1606s