有没有一种方法可以清空数组,如果可以的话,可以使用.remove()吗?
例如,
A = [1,2,3,4];
我该如何清空?
#1楼
清除现有数组A :
方法1
(这是我对问题的原始回答)
A = [];
此代码会将变量A设置为新的空数组。 如果您在其他任何地方都没有引用原始数组A则这是完美的选择,因为这实际上会创建一个全新的(空)数组。 您应谨慎使用此方法,因为如果您从另一个变量或属性引用了此数组,则原始数组将保持不变。 仅当仅通过其原始变量A引用该数组时,才使用它。
这也是最快的解决方案。
此代码示例显示使用此方法时可能遇到的问题:
var arr1 = ['a','b','c','d','e','f'];
var arr2 = arr1; // Reference arr1 by another variable
arr1 = [];
console.log(arr2); // Output ['a','b','c','d','e','f']
A.length = 0
这将通过将其长度设置为0来清除现有数组。有人认为这可能不适用于JavaScript的所有实现,但事实并非如此。 当在ECMAScript 5中使用“严格模式”时,它也可以工作,因为数组的length属性是读/写属性。
A.splice(0,A.length)
使用.splice()可以完美地工作,但是由于.splice()函数将返回包含所有已删除项目的数组,因此它实际上将返回原始数组的副本。 基准表明,这对性能没有任何影响。
while(A.length > 0) {
A.pop();
}
该解决方案不是很简洁,它也是最慢的解决方案,与原始答案中引用的早期基准相反。
性能
在清除现有数组的所有方法中,方法2和3在性能上非常相似,并且比方法4快得多。请参阅此基准测试 。
正如Diadistis在下面的回答中所指出的那样,用于确定上述四种方法的性能的原始基准存在缺陷。 原始基准测试重复使用了已清除的数组,因此第二次迭代将清除已经为空的数组。
以下基准测试可修复此缺陷: http : //jsben.ch/#/hyj65 。 它清楚地表明方法#2(长度属性)和#3(拼接)是最快的(不计算不会改变原始数组的方法#1)。
这一直是一个热门话题,并且引起了很多争议。 实际上有许多正确答案,并且由于很长一段时间以来该答案都已被标记为可接受答案,因此我将在此处介绍所有方法。 如果您对此答案投赞成票,请同时投票赞成我引用的其他答案。
#2楼
如果您需要保留原始数组,因为还有其他引用也需要更新,则可以通过将其长度设置为零来清除它而无需创建新数组:
A.length = 0;
#3楼
您可以将其添加到JavaScript文件中,以“清除”数组:
Array.prototype.clear = function() {
this.splice(0, this.length);
};
然后,您可以像这样使用它:
var list = [1, 2, 3];
list.clear();
或者,如果您想确保自己不破坏某些东西:
if (!Array.prototype.clear) {
Array.prototype.clear = function() {
this.splice(0, this.length);
};
}
很多人认为您不应该修改本机对象(例如Array),我倾向于同意。 请谨慎决定如何处理此问题。
#4楼
Array.prototype.clear = function() {
this.length = 0;
};
并称之为: array.clear();
#5楼
这里是最快的实现,同时保留了相同的数组 (“可变”):
function clearArray(array) {
while (array.length) {
array.pop();
}
}
仅供参考,它不能简化为while (array.pop()) :测试将失败。
FYI Map和Set定义clear() ,对于Array也具有clear()似乎是合乎逻辑的。
TypeScript版本:
function clearArray(array: T[]) {
while (array.length) {
array.pop();
}
}
相应的测试:
describe('clearArray()', () => {
test('clear regular array', () => {
const array = [1, 2, 3, 4, 5];
clearArray(array);
expect(array.length).toEqual(0);
expect(array[0]).toEqual(undefined);
expect(array[4]).toEqual(undefined);
});
test('clear array that contains undefined and null', () => {
const array = [1, undefined, 3, null, 5];
clearArray(array);
expect(array.length).toEqual(0);
expect(array[0]).toEqual(undefined);
expect(array[4]).toEqual(undefined);
});
});
这里是更新的jsPerf: : //jsperf.com/array-destroy/32 http://jsperf.com/array-destroy/152