JavaScript的几种循环使用方式及性能解析
循环的类型
一:for
var arr = [1, 2, 3, 4, 5, 6]; for (var i = 0, len = arr.length; i < len; i++) { console.log(arr[i]); }
在for循环中定义的新变量相当于在循环体外定义的变量,所以可以写成如下格式。
var i = 0, len = arr.length; for (; i < len; i++) { console.log(arr[i]); }
每次循环执行结束都会对i进行增量操作(增量可以为负数),所以可以将增量操作写到代码块最后执行。
i++只是其中常用写法,也可以是i = i +2其他方式。
var i = 0, len = arr.length; for (; i < len;) { console.log(arr[i]); i++; }
二:for-in 一般用于遍历对象
var obj = {a: 1, b: 2, c: 3 }; for (var key in obj) { console.log(key + ": " + obj[key]); //a: 1 b:2 c:3 }
三:for-of ES6新增! 允许遍历数组、字符串、Map等可迭代的数据结构!
var arr = [1, 2, 3, 4, 5]; for (var v of arr) { console.log( v); //1 2 3 4 5 } var str = "abcdefg"; for (var v of str) { console.log(v); //a b c d e f g }
四:while
var i = 0; while(i < 5) { console.log(i); //0 1 2 3 4 i++; }
五:do-while
var i = 0; do { console.log("do: " + i); //0 1 2 3 4 i++; } while(i < 5)
do-while循环是while的一个变形,先执行在判断,所以它至少会执行一次。
var i = 10; do { console.log("do: " + i); //10 i++; } while(i < 5)
循环的性能!!!
for-in的循环性能是明显慢与其他几种循环,它的每次迭代操作的同时都是会去搜索原型或者原型属性,产生额外开销,所以
避免使用for-in循环!云服务器Window Server 2012R系统安装MySQL的详细教程
不要用for-in来迭代数组!
性能优化!!!
1:减少迭代的工作量,减少对象成员及数组项的查找次数
2:倒序循环,会略微提升性能
var arr = [1, 2, 3, 4, 5]; for (var i = arr.length; i--;) { //将控制条件简单的与零比较,任何非零数自动转为true,而零值则为false。 console.log(i); //从两次迭代比较(迭代数小于总数吗?他是否为true?)减为一次(它是true吗?) }
1+2优化可以提升运行速度比原始版本快50%~60%。
PS:基于函数的迭代forEach()被原生支持,但是他的速度慢于基于循环的迭代,因为它对每个数组项都调用外部方法所带来的开销比较大,这是速度慢的主要原因,基于循环的迭代是基于函数迭代速度快八倍,所以forEach()一般不作于循环的选择。
JavaScript的几种循环使用方式及性能解析的更多相关文章
- ArrayList和LinkedList的几种循环遍历方式及性能对比分析
最新最准确内容建议直接访问原文:ArrayList和LinkedList的几种循环遍历方式及性能对比分析 主要介绍ArrayList和LinkedList这两种list的五种循环遍历方式,各种方式的性 ...
- Java 集合 ArrayList和LinkedList的几种循环遍历方式及性能对比分析 [ 转载 ]
Java 集合 ArrayList和LinkedList的几种循环遍历方式及性能对比分析 @author Trinea 原文链接:http://www.trinea.cn/android/arrayl ...
- ArrayList和LinkedList的几种循环遍历方式及性能对比分析(转)
主要介绍ArrayList和LinkedList这两种list的五种循环遍历方式,各种方式的性能测试对比,根据ArrayList和LinkedList的源码实现分析性能结果,总结结论. 通过本文你可以 ...
- ArrayList和LinkedList的几种循环遍历方式及性能对比分析(转载)
原文地址: http://www.trinea.cn/android/arraylist-linkedlist-loop-performance/ 原文地址: http://www.trinea.cn ...
- 【转】ArrayList和LinkedList的几种循环遍历方式及性能对比分析
原文网址:http://www.trinea.cn/android/arraylist-linkedlist-loop-performance/ 主要介绍ArrayList和LinkedList这两种 ...
- (转)ArrayList和LinkedList的几种循环遍历方式及性能对比分析
主要介绍ArrayList和LinkedList这两种list的五种循环遍历方式,各种方式的性能测试对比,根据ArrayList和LinkedList的源码实现分析性能结果,总结结论. 通过本文你可以 ...
- JavaScript中三种字符串连接方式及其性能比较
参考地址: https://www.cnblogs.com/programs/p/5554742.html 工作中经常会碰到要把2个或多个字符串连接成一个字符串的问题,在JS中处理这类问题一般有三种方 ...
- HashMap循环遍历方式及其性能对比(zhuan)
http://www.trinea.cn/android/hashmap-loop-performance/ ********************************************* ...
- HashMap循环遍历方式及其性能对比
主要介绍HashMap的四种循环遍历方式,各种方式的性能测试对比,根据HashMap的源码实现分析性能结果,总结结论. 1. Map的四种遍历方式 下面只是简单介绍各种遍历示例(以HashMap为 ...
随机推荐
- 线性模型-线性回归、Logistic分类
线性模型是机器学习中最简单的,最基础的模型结果,常常被应用于分类.回归等学习任务中. 回归和分类区别: 回归:预测值是一个连续的实数: 分类:预测值是离散的类别数据. 1. 线性模型做回归任务 ...
- vs2015中将复制过来的文件夹显示目录文件
先将文件夹和文件复制到VS程序所在的位置,点击解决方案资源管理器上的“显示所有文件”按纽,展开这个文件夹,这样你就可以看到这个文件或者文件夹了,这时,这个文件或者文件夹是虚线构成的.你右击这个文件或者 ...
- MySQL -1- 简介及安装
第一章 MySQL 大纲介绍 1.官方定义的MySQL DBA工作内容 (1)运维DBA 初级:各版本.各平台安装搭建.升级 中级:体系结构原理.基础管理(启动关闭.初始化配置文件管理.多实例管理.用 ...
- 最长不下降/不上升子序列&&最长上升/下降子序列
最长不下降/不上升子序列&&最长上升/下降子序列 struct cmp1{bool operator()(int a,int b){return a>b;}}; int main ...
- 2017.9.23 C组比赛总结
今天又回到了C组,感觉爽歪歪~分数终于是个三位数了,yes! 第一题,赛车.水!只用一个贪心就可以AC了. first,以速度为关键字小到大qsort一下... scond,枚举每一个赛车,看看它可以 ...
- opencv学习之显示图像-imshow函数
序 上一篇opencv学习之读取图像-imread函数介绍完opencv读取图片函数imread,这次来介绍与它对应的图像显示函数imshow. imshow函数 imshow函数功能 imshow的 ...
- py3.7安装Scrapy及安装时的 Running setup.py install for Twisted ... error 和安装后的 Unhandled error in Deferred:
1.首先,win+r 进入cmd,打开命令提示符,输入 pip install scrapy 等待自动安装: 2.到了后半段会出现 Running setup.py install for Tw ...
- 089、初探ELK (2019-05-13 周一)
参考https://www.cnblogs.com/CloudMan6/p/7770916.html 在开源的日志管理方案中,最出名的莫过于ELK了.ELK是三个软件的合称: Elasticsea ...
- 运维ipvsadm配置负载均衡2
一.什么是lvs1.lvs的定义LVS是Linux Virtual Server的简写,意即Linux虚拟服务器,是一个虚拟的服务器集群系统.是由章文嵩博士开发的一款开源软件,1998年5月发布,是中 ...
- JavaSE基础:泛型
泛型 1.引入 情景模式描述,假设完成一个学生的成绩的情况: 整数: math=80,english=70 小数: math=85.6,englisth=77.8 字符串: math="66 ...