- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
js中哪种删除数组首元素的方式性能更好?
假设我们有这个数组:
let fruits = ['Apple', 'Orange', 'Banana', 'Lemon'];
<强>1。转移方式
let a = fruits.shift();
<强>2。拼接方式
let [b] = fruits.splice(0, 1);
<强>3。切片方法
let c;
[c, fruits] = [...fruits.slice(0, 1), fruits.slice(1)]
<强>4。解构方法
let d;
[d, ...fruits] = fruits;
请说明其中一种方法比另一种方法更快的原因。
我在 jsbench.me 做了一些测试& perf.link但我多次运行完全相同的测试,每次我都得到 180 度相反的结果。
我知道这在不同的环境和引擎之间是不同的,所以我想知道在 Chrome V8 引擎中哪个更好。
最佳答案
根据我的经验,.shift() 方法是最容易使用的。但是如果您想知道确切的代码速度,我用 performance.now()
测试了每个方法。
大多数情况下,.shift()
方法是最快的。你可能会问为什么?好吧,它不会重新声明任何变量,因为其他变量已重新定义。您只有 on 变量,它会在调用 shift()
方法时自动返回。特别是最后两个例子是最慢的。他们正在重新定义两个变量,一个被赋值两次(c, d)。一次,只是用 let,另一次是在声明时。
这是我用于测试的代码,请随意编辑它。
function speedTest(times) {
let shiftAvg = 0;
let spliceAvg = 0;
let sliceAvg = 0;
let destructuringAvg = 0;
let t0, t1;
let fruits = Array(10000).fill('test');
for (var i = 0; i < times; i++) {
t0 = performance.now();
let a = fruits.shift();
t1 = performance.now();
shiftAvg += t1 - t0;
resetFruits();
t0 = performance.now();
let [b] = fruits.splice(0, 1);
t1 = performance.now();
spliceAvg += t1 - t0;
resetFruits();
t0 = performance.now();
let c;
[c, fruits] = [...fruits.slice(0, 1), fruits.slice(1)];
t1 = performance.now();
sliceAvg += t1 - t0;
resetFruits();
t0 = performance.now();
let d;
[d, ...fruits] = fruits;
t1 = performance.now();
destructuringAvg += t1 - t0;
resetFruits();
}
shiftAvg = shiftAvg / times;
spliceAvg = spliceAvg / times;
sliceAvg = sliceAvg / times;
destructuringAvg = destructuringAvg / times;
return [
{"avg": destructuringAvg, "approach": 'destructuring'},
{"avg": spliceAvg, "approach": 'splice'},
{"avg": sliceAvg, "approach": 'slice'},
{"avg": shiftAvg, "approach": 'shift'}
];
function resetFruits() {
fruits = Array(10000).fill('test');
}
}
let result = speedTest(20000).sort((a, b) => (a.avg > b.avg) ? 1 : -1);
result.map((item, index, self) => {
if(index === 0) {
console.log(index + 1, item.approach, item.avg, `fastest`);
}
else {
console.log(index + 1, item.approach, item.avg, `${parseInt(item.avg / self[0].avg * 100 - 100)}% slower`);
}
});
此外,不仅代码执行速度快,而且输入 array.slice() 比输入整个解构代码更快。
希望我能帮到你 :)
关于javascript - JS 数组移位 vs 拼接 vs 切片 vs 解构,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/73051325/
我想将这个无符号数:1479636484000 向右移动 7 位。这在 JavaScript 中可能吗? 两者 1479636484000 >> 7 和 1479636484000 >>> 7 返回错
鉴于以下代码: import matplotlib.pyplot as plt import numpy as np x = [1.0, 1.1, 2.0, 5.7] y = np.arange(le
我有一个低级键盘钩子(Hook),目前允许我从任何应用程序(包括游戏)中控制媒体播放器。 它通过查看捕获的特定击键来工作。 我想扩展它以查找键的组合。我可以对一些逻辑进行硬编码,但我觉得必须有一种更合
我需要一些帮助来理解这段C代码。我不知道这里的“L”和“\”是什么?请也说明一点:) #define l2n(l,c) (*((c)++)=(unsigned char)(((l)>>2
我正在查看一段代码: int result = 0 ; char byte = foo[j] for (i = 7 ; i>0 ; i--) { byte = (byte & ~0x1)>>1
我们有一个项目要求我们编写一个程序,允许用户输入一系列数字“将数字读入数组以进行进一步处理,用户通过输入负数表示他们已完成(负数不用于计算),在读取所有数字后执行以下操作,总结输入的#,计算输入的#,
锁定。有disputes about this question’s content正在解决中。它目前不接受新的答案或互动。 def menu(): choice = input("Pres
为什么如果 int x = -1 // binary: 11111111111111111111111111111111 x = x >>> 31; 我们有 000000000000000000000
我的问题其实应该很简单:我有一个玩家对象数组。(玩家[])我想要一个函数来旋转这个数组直到一个索引: public void rotateArray(Object[] array, int index
我有一个编码为 boost 动态位集的数字列表。我根据此列表中的任何数字可以采用的最大值动态选择此位集的大小。所以假设我有从 0 到 7 的数字,我只需要三位,我的字符串 0,2,7 将被编码为000
我能想到一些令人讨厌的低效方法来完成这项任务,但我想知道最好的方法是什么。 例如,我想复制一个字节中从第 3 位开始的 10 个字节,并像往常一样复制到一个指针。 有没有比一次复制一个移位字节更好的方
我正在尝试为该问题添加更多规则,并且该规则一直给我带来这种转变/减少冲突的能力,我不知道为什么会这样做,并且在过去的24小时内我一直在尝试解决问题 FuncDecl : RetTyp
This question already has answers here: Why does it make a difference if left and right shift are us
我在 Perl 中遇到这个问题已经有几天了,在搜索了无数的手册页、perldocs 和谷歌搜索了太多的搜索词之后,希望这里有人能帮助我。 我得到两个表示十六进制值的字符串,即“FFFF”,而不是 Pe
我有一个主 div,两个 div 水平并排放置在这个父 div 中。 .parent{ height: 360px; margin-top: 0px; bo
我想 float 我的元素列表并从第二个元素创建一个移动效果。 如何避免第二个 .item 之后的“清除”行为? .shift { float: right; width: 50%;
我正在使用 SSE3 优化我的代码。代码中有一点迫使我将 vector 中的所有元素移动一个元素 v[0] = 0 //v is some char* and N = v.size() for(i
.file "calcnew.c" .text .globl calcnew .type calcnew, @function calcnew:
我有一个点对象: class Point { final int x,y; ... } 因为这些点将在我的代码中到处使用/创建,所以我想开始使用 guavas 缓存。不幸的是
x = "Foo 890 bar *()" 如何将包括 "*()" 在内的小写字母“未移位”返回到 890?期望的结果: foo 890 bar 890 不需要的: x.lower() => "foo
我是一名优秀的程序员,十分优秀!