3 回答
TA贡献1943条经验 获得超7个赞
此代码不是无限循环。
i由于整数溢出,最终将变为负数。它将溢出到Integer.MIN_VALUE,并最终达到-1。
但是,当您包含该打印语句时,需要很长时间才能完成(它必须打印超过 40 亿个 的值i),因此它似乎是无穷无尽的。
当您删除打印语句时,它会变得更快。
也就是说,如果编译器决定循环什么都不做,它甚至可能决定优化整个循环,这会将运行时间减少到 0。
如果您添加一个仅打印少数值的条件,您可以看到即使使用该println语句,循环也会终止,这将使执行速度更快。
例如,每 1 亿个值打印一次:
public static void main(String[] args) {
int i=0;
while(true) {
i++;
if (i%100000000 == 0) System.out.println(i);
if(i==-1){
break;
}
}
}
将输出:
100000000
200000000
300000000
400000000
500000000
600000000
700000000
800000000
900000000
1000000000
1100000000
1200000000
1300000000
1400000000
1500000000
1600000000
1700000000
1800000000
1900000000
2000000000
2100000000
-2100000000
-2000000000
-1900000000
-1800000000
-1700000000
-1600000000
-1500000000
-1400000000
-1300000000
-1200000000
-1100000000
-1000000000
-900000000
-800000000
-700000000
-600000000
-500000000
-400000000
-300000000
-200000000
-100000000
并终止。
TA贡献1772条经验 获得超8个赞
好吧,不完全确定你的意思,但循环不是无穷无尽的。
由于整数溢出,i最终会变成的值,-1循环终止。
打印i与否都没有关系。只是将所有内容写入控制台需要更长的时间。
添加回答
举报
