java数据溢出问题总结

数据的溢出问题:

a) 代码片段:

int max = Integer.MAX_VALUE;

 System.out.println("最大的Int==" + max);

 System.out.println("最大的Int+1==" + (max + 1));

 System.out.println("最大的Int+2==" + (max + 2));

==》运行结果:

        最大的Int==2147483647

最大的Int+1==-2147483648

        最大的Int+2==-2147483647

==》分析:可见当最大的int值再加上1,就会变成最小的int,构成了一个循环,                如果要避免这中情况就要加上大小判断,或者使用较大的表示范围的数据类型。

==》改进:

int max = Integer.MAX_VALUE;

System.out.println("最大的Int==" + max);

System.out.println("最大的Int+1==" + (max + 1L));

System.out.println("最大的Int+2==" + ((long)max + 2));

==》运行结果:

最大的Int==2147483647

最大的Int+1==2147483648

最大的Int+2==2147483649

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值