IDC

JavaScript 中哪一种循环最快呢?

作者:admin 2021-04-07 我要评论

究竟哪一种循环更快? 答案其实是:for(倒序) 最让我感到惊讶的事情是,当我在本地计算机上进行测试之后,我不得不接受 for(倒序)是所有 for 循环中最快的这一事...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

究竟哪一种循环更快?

答案其实是:for(倒序)

最让我感到惊讶的事情是,当我在本地计算机上进行测试之后,我不得不接受 for(倒序)是所有 for 循环中最快的这一事实。下面我会举个对一个包含超过一百万项元素的数组执行一次循环遍历的例子。

声明:console.time() 结果的准确度在很大程度上取决于我们运行测试的系统配置。你可以在此处对准确度作进一步了解。

  1. const million = 1000000;  
  2. const arr = Array(million); 
  3. console.time('⏳'); 
  4. for (let i = arr.length; i > 0; i--) {} // for(倒序)  :- 1.5ms 
  5. for (let i = 0; i < arr.length; i++) {} // for          :- 1.6ms 
  6. arr.forEach(v => v)                     // foreach      :- 2.1ms 
  7. for (const v of arr) {}                 // for...of     :- 11.7ms 
  8. console.timeEnd('⏳'); 

造成这样结果的原因很简单,在代码中,正序和倒序的 for 循环几乎花费一样的时间,仅仅相差了 0.1 毫秒。原因是,for(倒序)只需要计算一次起始变量 let i = arr.length,而在正序的 for 循环中,它在每次变量增加后都会检查条件 i

而 forEach 是 Array 原型的一个方法,与普通的 for 循环相比,forEach 和 for…of 需要花费更多的时间进行数组迭代。(译者注:但值得注意的是,for…of 和 forEach 都从对象中获取了数据,而原型并没有,因此没有可比性。)

循环的类型,以及我们应该在何处使用它们

1. For 循环(正序和倒序)

我想,也许大家都应该对这个基础循环非常熟悉了。我们可以在任何我们需要的地方使用 for 循环,按照核定的次数运行一段代码。最基础的 for 循环运行最迅速的,那我们每一次都应该使用它,对吗?并不然,性能不仅仅只是唯一尺度,代码可读性往往更加重要,就让我们选择适合我们应用程序的变形即可。

2. forEach

这个方法需要接受一个回调函数作为输入参数,遍历数组的每一个元素,并执行我们的回调函数(以元素本身和它的索引(可选参数)作为参数赋予给回调函数)。forEach 还允许在回调函数中使用一个可选参数 this。

  1. const things = ['have', 'fun', 'coding']; 
  2. const callbackFun = (item, idex) => { 
  3.     console.log(`${item} - ${index}`); 
  4. things.foreach(callbackFun);  
  5. /* 输出   
  6. have - 0 
  7. fun - 1 
  8. coding - 2  
  9. */ 

3. for…of

for…of 是在 ES6(ECMAScript 6)中实现标准化的。它会对一个可迭代的对象(例如 array、map、set、string 等)创建一个循环,并且有一个突出的优点,即优秀的可读性。

  1. const arr = [3, 5, 7]; 
  2. const str = 'hello'
  3. for (let i of arr) { 
  4.    console.log(i); // 输出 3, 5, 7 
  5. for (let i of str) { 
  6.    console.log(i); // 输出 'h', 'e', 'l', 'l', 'o' 

需要注意的是,请不要在生成器中使用 for……of,即便 for……of 循环提前终止。在退出循环后,生成器被关闭,并尝试再次迭代,不会产生任何进一步的结果。

4. for in

for…in 会在对象的所有可枚举属性上迭代指定的变量。对于每个不同的属性,for…in 语句除返回数字索引外,还将返回用户定义的属性的名称。因此,在遍历数组时最好使用带有数字索引的传统 for 循环。因为 for…in 语句还会迭代除数组元素之外的用户定义属性,就算我们修改了数组对象(例如添加自定义属性或方法),依然如此。

  1. const details = {firstName: 'john', lastName: 'Doe'}; 
  2. let fullName = ''
  3. for (let i in details) { 
  4.     fullName += details[i] + ' '; // fullName: john doe 

for…of 和 for…in

for…of 和 for…in 之间的主要区别是它们迭代的内容。for…in 循环遍历对象的属性,而 for…of 循环遍历可迭代对象的值。

  1. let arr= [4, 5, 6]; 
  2. for (let i in arr) { 
  3.    console.log(i); // '0', '1', '2' 
  4. for (let i of arr) { 
  5.    console.log(i); // '4', '5', '6' 

结论

  • for 最快,但可读性比较差
  • foreach 比较快,能够控制内容
  • for...of 比较慢,但香
  • for...in 比较慢,没那么方便
【责任编辑:赵宁宁 TEL:(010)68476606】
本文转载自网络,原文链接:http://mp.weixin.qq.com/s?__biz=Mzg2NDAzMjE5NQ==&mid=2247488620&idx=1&sn=9e1ae7feafe2654467215c00a3a370ed&chksm=ce6ed0c0f91959d6f0cb8654f351d3a4e950ca2631069beba86967fdfdf2cb8ea2742d44c25b&mpshare=1&s

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • 太棒了!Python和Excel过了这么久终于

    太棒了!Python和Excel过了这么久终于

  • Java编程内功-数据结构与算法「线索化

    Java编程内功-数据结构与算法「线索化

  • 在Java中使用异步编程

    在Java中使用异步编程

  • Kafka性能篇:为何Kafka这么&quot;

    Kafka性能篇:为何Kafka这么&quot;