int类型 计算时溢出问题!

本文详细解析了Java中整型数据溢出的现象及原因,通过实例展示了int类型达到极限值时的行为,并介绍了如何避免溢出,包括使用long类型进行强制转换的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在java中

代码  

   //不满一小时舍去  有效期
  int days = (int) ((expiredTime.getTime() - date.getTime()) / (1000 * 3600));

数据的溢出:

当整数的数据大小超出了可以表示的范围,而程序中又没有做数值范围的检查时,

这个整型变量所输出的值将发生紊乱,且不是预期的运行结果。

01 //  整数值如果超出了自己所可以表示范围的最大值,会出现溢出 

//        int a = -2147483648;
//        System.out.println("a-1 = " + (a - 1));
//        System.out.println("a-2 = " + (a - 2));
//
//        int b = 2147483647;
//        System.out.println("b+1 = " + (b + 1));
//        System.out.println("b+2 = " + (b + 2));

输出结果: 
a-1 = 2147483647
a-2 = 2147483646
b+1 = -2147483648
b+2 = -2147483647


     当最大值加上 1 时,结果反而变成表示范围中最小的值;当最大值加上 2 时,结
果变成表示范围中次小的值,这就是数据类型的溢出。读者可以发现,这个情形会出
现一个循环,若是想避免这种情况的发生,在程序中就必须加上数值范围的检查功能,
或者使用较大的表示范围的数据类型,如长整型。

    就像计数器的内容到最大值时会自动归零一样。而在整数中最小值为
-2147483648,所以当整数 x 的值最大时,加上 1 就会变成最小值-2147483648,也就
是产生了溢出。

        为了避免 int 类型的溢出,可以在该表达式中的任一常量后加上大写的“L”,或
是在变量前面加上 long,作为强制类型的转换。


递归计算强转int  溢出的最后值
public static int a(long d) {
    long e = 0;
    if (d > 2147483647) {
        e = -(d - 2147483647);
        a(e);
    } else if (d < -2147483648) {
        e = -(d + 2147483647 + 1);
        a(e);
    }
    return (int) e;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值