gpt4 book ai didi

javascript - 为什么通过索引访问数组元素比使用 .find() 函数慢?

转载 作者:行者123 更新时间:2023-11-28 17:51:32 24 4
gpt4 key购买 nike

对于下面的特定情况,使用 .find 函数似乎比简单地使用元素索引要快得多。这是为什么?

jsPerf Results

最佳答案

您可以使用不同的方法,即使用随机数来查找对象。

索引:

var i = Math.floor(Math.random() * 10),
o = array[i];

与查找:

var i = Math.floor(Math.random() * 10),
o = array.find(o => o.id === i);

使用共享数据

var array = [{ id: 0 }, { id: 1 }, { id: 2 }, { id: 3 }, { id: 4 }, { id: 5 }, { id: 6 }, { id: 7 }, { id: 8 }, { id: 9 }];

然后你从 jsperf 得到(带边缘):

Index: 31,707,818 ±0.    92% fastest
Find: 5,001,388 ±1.51% 84% slower

结论

索引访问比使用 Array#find 更快.

关于javascript - 为什么通过索引访问数组元素比使用 .find() 函数慢?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45435809/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com