JAVA循环陷阱-数据溢出

本文探讨了数据溢出导致的死循环问题,通过具体的byte循环示例,讲解了如何避免从最小值到最大值循环时的数据溢出,并提出了两种解决方案,一种是在循环条件中检查数值是否为正,另一种是使用预变量比较当前值与前一值。

数据溢出带来的死循环

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+256);
System.out.println(b);

显而易见b会等于127.

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

转载于:https://www.cnblogs.com/dev-lluo/p/10231566.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值