我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何通过循环优化JavaScript 程序

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何通过循环优化JavaScript 程序

这篇文章给大家分享的是有关如何通过循环优化JavaScript 程序的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

前言

对于提高 JavaScript 程序的性能这个问题,最简单同时也是很容易被忽视的方法就是学习如何正确编写高性能循环语句。本文将会帮你解决这个问题。

我们将看到 JavaScript 中主要的循环类型,以及如何针对它们进行高效编码。

现在开始!

循环性能

谈到循环性能,争论的焦点始终会集中到关于应该使用哪种循环,哪个是速度最快、性能最好的?事实上,在 JavaScript 提供的四种循环类型中,只有一种比其他循环慢得多 ——  for-in 循环。 对循环类型的选择应基于你的需求而不是性能问题。

有两个主要因素有助于改善循环性能 —— 每次迭代完成的工作和迭代次数。

在下面的内容中,我们将会看到通过对这两点的优化,可以对循环的整体性能产生积极的影响。

For 循环

在 ECMA-262(定义JavaScript的基本语法和行为的规范)第三版中,定义了四种循环类型。第一个是标准的 for 循环,它与其他类 C 语言的语法相同:

for (var i = 0; i < 10; i++){
//循环体
}

这可能是最常用的 JavaScript 循环结构。要了解应该怎样对其进行优化,需要先进行一些分析。

解析

for 循环由四部分组成:初始化,预测试条件,循环体和后执行。它的工作方式如下:首先,执行初始化代码(var i = 0;)。然后是预测试条件(i <10;)。如果预测试条件的计算结果为 true,则执行循环体。之后运行后执行代码(i ++)。

优化

要优化循环中的工作量,第一步是最小化对象成员和数组项查找的数量。
还可以通过反转顺序来提高循环的性能。在 JavaScript 中,反转循环对循环的性能提升不大,除非你消除了额外的操作。

// 原始循环
for (var i = 0; i < items.length; i++){
process(items[i]);
}
// 最小化属性查找
for (var i = 0, len = items.length; i < len; i++){
process(items[i]);
}
// 最小化属性查找并反序
for (var i = items.length; i--; ){
process(items[i]);
}

While 循环

第二种是 while 循环。下面是一个简单的预测试循环,由预测试条件和循环体组成。

var i = 0;
while(i < 10){
//循环体
i++;
}

解析

如果预测试条件的计算结果为 true,则执行循环体。如果不是 —— 它就会被跳过。每个 while 循环都可以用 for 替换,反之亦然。

优化

// 原始循环
var j = 0;
while (j < items.length){
process(items[j++]);
}
// 最小化属性查找
var j = 0,
count = items.length;
while (j < count){
process(items[j++]);
}
// 最小化属性查找和反序
var j = items.length;
while (j--){
process(items[j]);
}

Do-While 循环

do-while 是第三种循环,它是 JavaScript 中唯一的后测试循环。由循环体和后测试条件组成:

var i = 0;
do {
//循环体
} while (i++ < 10);

解析

在这种类型的循环中,循环体总是至少执行一次。然后评估测试后的条件,如果它是true,则执行另一个循环周期。

优化

// 原始循环
var k = 0;
do {
process(items[k++]);
} while (k < items.length);
// 最小化属性查找
var k = 0,
num = items.length;
do {
process(items[k++]);
} while (k < num);
// 最小化属性查找和反序
var k = items.length - 1;
do {
process(items[k]);
} while (k--);

For-In 循环

最后一种是 for-in 循环。它有一个非常特殊的用途 —— 枚举 JavaScript 对象的命名属性。 它的语法如下:

for (var prop in object){
//loop body
}

解析

它的名称与 for 循环类似。但是工作方式完全不同。而这种差异使它比另外三种循环慢得多,后者具有相同的性能特征,所以争论哪个循环最快是没有用的。

每次循环执行时,变量 prop 会得到 object 的一个属性。它将会不断执行,直到返回所有属性为止。这些是对象自身的以及通过其原型链继承的属性。

注意事项

永远不要用“ for-in ”来迭代数组成员。

这种循环的每次迭代都会在实例或原型上进行属性查找,这使得 for-in 循环比其它循环要慢得多。对于相同次数的迭代,可能会比其它循环慢七倍。

结论

for , while 和 do-while 循环都有类似的性能特征,因此没有哪种类型比其他的更快或更慢。

避免使用 for-in 循环,除非你需要对大量未知对象属性进行迭代。

提高循环性能的最佳方法是减少每次迭代完成的工作量并减少循环迭代次数。

感谢各位的阅读!关于“如何通过循环优化JavaScript 程序”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何通过循环优化JavaScript 程序

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL中如何通过循环实现自定义排序

在MySQL中,可以通过循环实现自定义排序的方法是使用用户定义变量(user-defined variables)来实现。以下是一个简单的示例,假设有一个表格students包含学生的姓名和分数,现在我们想按照分数降序排序,但要求相同分数的
MySQL中如何通过循环实现自定义排序
2024-04-30

如何优化MySQL循环处理

要优化MySQL循环处理,可以考虑以下几个方面:使用批量操作:避免在循环中逐条处理数据,可以将数据批量处理,减少循环次数,提高效率。可以使用INSERT INTO … VALUES(…)语句来一次性插入多条数据,或者使用UPDATE … S
如何优化MySQL循环处理
2024-04-30

如何优化MySQL循环查询

要优化MySQL循环查询,可以采取以下几种方法:使用JOIN操作:尽量避免在循环中进行多次查询,可以通过使用JOIN操作将多个查询合并成一个查询,减少查询次数,提高效率。使用索引:为经常被查询的字段建立索引,可以加快查询速度。同时,尽量避免
如何优化MySQL循环查询
2024-04-29

python如何实现循环优化

这篇文章给大家分享的是有关python如何实现循环优化的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。循环优化# 不推荐写法。代码耗时:6.7秒def computeSum(size: int) -> int:
2023-06-27

python双重for循环太慢如何优化

如果双重for循环太慢,可以尝试以下优化方法:使用NumPy库:NumPy是一个强大的Python科学计算库,它可以对数组进行高效的运算。如果你的循环涉及到大型数组的操作,可以考虑使用NumPy来替代双重for循环。使用并行计算:Pytho
2023-10-24

如何优化MySQL中的循环执行计划

优化MySQL中的循环执行计划可以通过以下几种方式来实现:使用合适的索引:确保数据库表中的字段上有适当的索引。索引能够帮助MySQL更快地定位需要的数据,从而减少循环执行的时间。使用适当的查询语句:编写高效的查询语句可以减少循环执行的次数。
如何优化MySQL中的循环执行计划
2024-04-30

通过Golang的同步机制优化程序性能

在Golang中,可以通过使用同步机制来优化程序的性能。以下是一些常见的同步机制和优化技巧:1. 使用互斥锁:Golang提供了sync包中的Mutex类型,可以用于保护共享资源的访问。在多个goroutine访问共享资源时,可以使用互斥锁
2023-10-08

如何通过循环 JSON 显示 golang 中丢失的键?

编程网今天将给大家带来《如何通过循环 JSON 显示 golang 中丢失的键?》,感兴趣的朋友请继续看下去吧!以下内容将会涉及到等等知识点,如果你是正在学习Golang或者已经是大佬级别了,都非常欢迎也希望大家都能给我建议评论哈~希望能帮
如何通过循环 JSON 显示 golang 中丢失的键?
2024-04-05

编程热搜

目录