while先判断后执行,条件为假则循环体一次不执行;do-while先执行后判断,循环体至少执行一次,适合需确保至少运行一次的场景如输入验证。

while 是先判断再执行,条件不满足就跳过
当你写 while(condition) { ... } 时,JVM 每次都会先求值 condition。如果一开始就是 false,循环体连一次都不会进。比如:
int a = 5;
while (a < 0) {
System.out.println("这行永远不会打印");
}
这种行为适合「有前提才干活」的场景,比如读取文件直到末尾、等待某个状态变为 true 才继续。
- 常见错误:忘记在循环体内更新变量,导致
condition始终为true→ 死循环 - 典型陷阱:把初始化写在 while 外但没检查边界,比如
int i = 10; while(i > 0) { i--; }看似安全,但若初始值是负数,整个循环直接跳过,后续逻辑可能出错
do while 至少执行一次,适合交互式输入验证
do { ... } while(condition); 的执行顺序是:先跑一遍循环体,再判断 condition 是否成立。哪怕条件第一次就为 false,也已执行过一轮。
int input = -1;
do {
System.out.print("请输入一个正数: ");
input = scanner.nextInt();
} while (input <= 0);
这类结构天然适配「用户必须输一次,然后根据结果决定是否重试」的逻辑。
立即学习“Java免费学习笔记(深入)”;
- 语法上注意结尾的分号 ——
while(condition);必须带,漏掉会编译报错 - 别误以为它比 while “更安全”:如果循环体里有副作用(比如修改了共享变量),多执行一次可能引发意料外的状态变更
- 不能用于需要“零次执行”的场景,比如某些预检失败后应直接退出的流程
选哪个?看逻辑起点是否强制首执
关键不是语法多酷,而是你的真实业务语义:
- 需要「至少一次」:菜单选择、密码重试、初始化配置加载 → 用
do while - 需要「按需触发」:遍历集合前先判空、网络请求前检查连接状态 → 用
while - 想混用?可以,但别硬套:比如用
while(true)+break模拟 do while,可读性差且容易漏 break
Java 并没有提供「可选首次执行」的内置语法,所以这个选择本质是设计决策,不是性能权衡。
for 和 for-each 不是替代品,而是不同抽象层级
有人会想:“既然 for 更紧凑,为啥还要 while/do while?”——因为它们解决的问题维度不同。
for(int i = 0; i :适用于明确次数或索引驱动的迭代-
for(String s : list):适用于容器遍历,隐藏索引和边界细节 -
while/do while:适用于条件驱动、次数未知、依赖外部状态(如 IO、用户输入、异步信号)的循环
强行把用户输入验证改成 for 循环,要么写成 for(;;)(失去语义),要么硬凑计数器(违背本意)。这时候坚持用 while 或 do while 反而是最干净的做法。









