Java循环结构是遍历数组与集合数据最直接、最常用的方式。选择合适的循环类型、明确边界条件、规避常见陷阱,能显著提升代码的执行效率与稳定性。下面逐一拆解这几类核心循环的适用场景与实战要点。

for循环:适用于确定长度或需要下标访问的场景
当你明确知道循环次数,或需要借助下标进行操作——例如修改数组中某个位置的值、比较相邻元素、构建新数组——传统for循环最为稳妥。
- 遍历数组求和:
for(int i = 0; i < array.length; i++) sum += array[i]; - 反向遍历:
for(int i = list.size() - 1; i >= 0; i--) - 嵌套处理二维数组或生成矩阵时,结构清晰、控制力强
核心要点:掌握索引,便能灵活控制位置。只要需要精确操作下标,就别犹豫。
增强for循环(for-each):专注于“依次读取每个元素”的简洁写法
如果目标只是逐个访问数组或集合中的值,既不依赖下标,也不修改原结构,增强for循环是首选。它自动处理边界,从根本上避免ArrayIndexOutOfBoundsException。
- 遍历List打印:
for(String s : names) System.out.println(s); - 遍历Map键值对:
for(Map.Entrye : map.entrySet()) - 必须牢记的坑:循环体内不能调用
list.remove()或add(),否则会抛出ConcurrentModificationException。需要删除元素?请改用Iterator方案。
while循环:适合条件驱动、次数不确定的遍历
当遍历逻辑取决于动态状态——例如文件读取、网络响应、用户输入结束——而非固定长度时,while更加自然。
- 配合Iterator安全删除的经典写法:
Iteratorit = list.iterator(); while(it.hasNext()) { String s = it.next(); if(s.isEmpty()) it.remove(); } - 处理链表或自定义迭代器时,while比for更易于表达“走到哪算哪”的语义
- 死循环警告:务必手动更新控制变量,否则程序可能永远运行下去
do-while循环:确保至少执行一次的特殊需求
适用于必须先执行一次操作再判断是否继续的场景——菜单交互、初始化校验、重试机制就是最典型的例子。
- 用户输入验证:
do { input = scanner.nextLine(); } while(input == null || input.trim().isEmpty()); - 数据库连接重试:
int attempts = 0; do { connect(); } while(!connected && ++attempts < maxRetries); - 条件写在末尾,循环体一定至少执行一次——这一点与while存在本质区别
实际项目中,最稳妥的选型思路:纯遍历优先使用增强for;需要索引或修改时切回传统for;动态条件用while;必须首次执行用do-while。组合使用并适时break,往往比硬套一种写法更高效、更易读。记住,没有万能方案,只有适合场景的循环。
