for循环执行顺序为:①初始化表达式仅执行一次;②每次迭代先判断条件表达式;③条件为真则执行循环体;④再执行更新表达式,之后重复②。

for循环的三部分如何按顺序执行
Java中for循环不是一次性把三个表达式全跑完再进循环体,而是有严格分步、可预测的执行节奏。每次迭代都按「判断 → 执行循环体 → 执行更新表达式」顺序走,**初始化表达式只在最开始执行一次**。
常见误解是以为for (int i = 0; i 里的i++在进入循环体前就执行——其实它是在本轮循环体执行完后、下一轮判断前才执行。
for (int i = 0; i 输出是0、1、2,不是1、2、3- 如果在循环体内修改了循环变量(比如
i = i + 2),下次判断前仍会执行i++,可能导致跳过或死循环 - 初始化部分可以声明多个变量,但类型必须一致:
for (int i = 0, j = 10; i
for循环中break和continue对流程的影响
break直接跳出整个for结构,后续判断和更新表达式都不再执行;continue则跳过本次循环剩余语句,**立即执行更新表达式,然后进入下一轮判断**。
容易踩的坑是误以为continue之后就直接重判条件——它一定会先跑一遍更新表达式,哪怕你没写显式的自增操作。
立即学习“Java免费学习笔记(深入)”;
for (int i = 0; i 输出013(i从2变成3后继续判断)- 如果更新表达式为空(
for (int i = 0; i ),又在continue前没手动改i,就会陷入死循环 -
break不会触发finally块(除非for在try内),这点和return不同
增强for循环(for-each)底层是怎么跑的
Java的for (String s : list)本质是编译器帮你展开成迭代器调用,等价于手动写Iterator遍历。它**不暴露索引,也不允许在遍历时结构化修改集合**(否则抛ConcurrentModificationException)。
性能上,对ArrayList这类随机访问集合,增强for和传统for差别不大;但对LinkedList,增强for比get(i)方式快得多——因为后者每次都要从头遍历节点。
- 不能用增强
for给数组元素重新赋值(如for (int x : arr) x = 5;不影响原数组) - 想边遍历边删元素,必须用
Iterator.remove(),不能用list.remove() - 泛型擦除后,编译器生成的字节码里实际是
hasNext()和next()调用
for循环的边界与空集合行为
当循环条件第一次就不成立(比如for (int i = 0; i ),循环体**一次都不执行**,连初始化也已完成,只是判断失败就退出。空集合、空数组在增强for中同理——不报错,直接跳过。
真正容易出问题的是循环变量溢出或条件写反,比如用!=代替来控制递增循环,一旦中间跳过目标值,就变成死循环。
-
for (int i = 10; i != 0; i--) {...}看似安全,但如果某次i被意外设为负数,可能永远不等于0 - 浮点数做循环变量极不可靠:
for (double d = 0.1; d != 1.0; d += 0.1)实际会卡在0.999999...,永远不等于1.0 - 循环变量作用域仅限
for括号内,外面访问会编译报错:i在for (int i = 0; ...)外不可见








