标签:
数据溢出带来的死循环
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这等不可思议的事情就出来了。
这里之所把这个单独拿出来讲;是因为要记住不要单纯的以为数据溢出后一定会变成负数。
标签:
来源: https://www.cnblogs.com/dev-lluo/p/10231566.html