9种常见的for循环优化方案

本文介绍了Java中for循环的多种优化方法,包括提取数组长度、使用迭代器、foreach遍历以及异常处理等,旨在提高代码执行效率和可读性。通过实例展示了不同优化方式的优缺点,适用于Java开发者提升代码性能。
摘要由CSDN通过智能技术生成

前言

我们都经常使用一些循环耗时计算的操作,特别是for循环,它是一种重复计算的操作,如果处理不好,耗时就比较大,如果处理书写得当将大大提高效率,下面总结几条for循环的常见优化方式。

首先,我们初始化一个集合 list,如下:

List<String> list = new ArrayList<String>();  

方法一:最常规的不加思考的写法

for (int i = 0; i < list.size(); i++) {  
 System.out.println(list.get(i));  
}  

较常见,易于理解

方法二:数组长度提取出来

int m = list.size();  
for (int i = 0; i < m; i++) {  
      System.out.println(list.get(i));  
}  
  • 优点:不必每次都计算

  • 缺点:

    • m的作用域不够小,违反了最小作用域原则

    • 不能在for循环中操作list的大小,比如除去或新加一个元素

方法三:数组长度提取出来

for (int i = 0, n = list.size(); i < n; i++) {  
    System.out.println(list.get(i));  
}  
  • 优点:不必每次都计算 ,变量的作用域遵循最小范围原则

  • 缺点:不能在for循环中操作list的大小,比如除去或新加一个元素

方法四:采用倒序的写法

for (int i = list.size() - 1; i >= 0; i--) {  
System.out.println(list.get(i));  
}  
  • 优点:不必每次都计算 ,变量的作用域遵循最小范围原则

  • 缺点:1、结果的顺序会反 2、看起来不习惯,不易读懂

  • 适用场合:与显示结果顺序无关的地方:比如保存之前数据的校验

方法五:Iterator 遍历

for (Iterator<String> it = list.iterator(); it.hasNext();) {  
      System.out.println(it.next());  
}  
  • 优点:简洁

方法六:jdk1.5后的写法

注:对于集合类的元素使用foreach写法后,会自动转换成Iterator遍历方式。

for (Object o : list) {  
     System.out.println(o);  
}  
  • 优点:简洁结合泛型使用更简洁

  • 缺点:jdk1.4向下不兼容

方法七:循环嵌套外小内大原则

for (int i = 0; i < 10; i++) {  
   for (int j = 0; j < 10000; j++) {  
   }  
}  

原因

图片

方法八:循环嵌套提取不需要循环的逻辑

 //前:  
 int a = 10, b = 11;  
  for (int i = 0; i < 10; i++) {  
               i = i * a * b;  
   }   
   
   
//后:  
 int c = a * b;  
 for (int i = 0; i < 10; i++) {  
         i = i * c;  
  }  

方法九:异常处理写在循环外面

反例(特定场景,需要在循环内处理除外)

for (int i = 0; i < 10; i++) {  
     try {  
   
     } catch (Exception e) {  
   
     }  
}  

正例

try {  
   for (int i = 0; i < 10; i++) {  
   }  
} catch (Exception e) {  
   
}  

转载:9种常见的for循环优化方案 

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
为了优化 for 循环,可以考虑以下几方法: 1. 使用迭代器代替下标循环:在循环中使用迭代器,而不是使用下标来访问列表元素,可以减少下标计算的开销,并且在处理大型列表时可以提高性能。 2. 避免重复计算:如果在循环中需要计算某些值,可以考虑在循环之前计算这些值,并将它们存储在变量中。这样可以避免在每次迭代时重复计算。 3. 合并循环:如果有多个循环迭代相同的列表,可以考虑将它们合并为一个循环,以减少循环的数量和访问列表的次数。 4. 使用并行化技术:如果循环中的计算可以并行执行,可以使用并行化技术,如多线程或多进程,以加速循环的执行。 5. 优化循环体内部的代码:循环体内部的代码也可能是性能瓶颈,可以使用一些优化技术来加速代码的执行,如使用更高效的算法或数据结构,减少内存分配和释放等。 下面是一个 for 循环优化的示例代码: ```python import time # 原始代码 start_time = time.time() sum = 0 for i in range(1000000): sum += i end_time = time.time() print("原始代码执行时间:", end_time - start_time) # 优化后的代码 start_time = time.time() sum = sum(range(1000000)) end_time = time.time() print("优化后的代码执行时间:", end_time - start_time) ``` 在上面的示例代码中,我们使用了内置函数 `sum` 来代替 for 循环来计算 0 到 999999 的和。这方法比 for 循环更快,因为sum函数在 C 语言中实现,比 Python 解释器更快。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值