数据溢出带来的死循环

for(byte i = -128;i<128;i++){
    System.out.println(i);
}

这是循环的本意是枚举所有的byte;当127被打印后;本应退出循环;但是由于数据溢出问题;byte[127]+1;于是就变成了循环起始变量byte[-128];于是乎一个死循环就诞生了。

从0开始的循环怎么避免数据溢出带来的死循环

不过通常我们的循环是从0开始;不会从一个数字类型的最小值跑到最大值;此时我们的关键点就在0上;这时问题很好解决

for(byte i = 0;i<128&&i>=0;i++){
    System.out.println(i);
}

i++数据溢出之后;i自然而然变成了负数;此时大于等于0就不成立了;就规避了数据溢出问题;请注意这里说得是i++的情况;

包含数据类型最大最小值的循环怎么避免数据溢出带来的死循环

for(byte i,pre = i = -128;i<128&&i>=pre;pre = i,i++){
    System.out.println(i);
}

这里我们引入了一个变量pre;理论上来说每次都是i++;所以这次的i一定大于上次的i;如果i小于上次的i那就证明数据溢出了,请注意这里说得是i++的情况;

数据溢出

留意我们刚刚说的;i++的情况下;这次的i一定大于上次的i;如果i小于上次的i那就证明数据溢出了;那么什么情况下;i+x溢出后不会小于i

byte a = 127;
byte b = (byte)(a+a);
System.out.println(a);

显而易见a还会等于127;于是乎a+a=a这等不可思议的事情就出来了。

这里之所把这个单独拿出来讲;是因为要记住不要单纯的以为数据溢出后一定会变成负数。

版权声明:本文为dev-lluo原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/dev-lluo/p/10231566.html