为什么计算一个月的毫秒数30*24*3600*1000为负数

最近在项目中犯了一个低级错误,计算一个月之前的毫秒数只差,却得到了负数:

/**
 * @Author: chuxia0811
 * @Date: 2021/3/12 21:04
 * @Description :
 */
public class LongTest {
    public static void main(String[] args) {
        long diffTimes = 30 * 24 * 60 * 60 * 1000;
        System.out.println(diffTimes);
    }
}

运行结果如下:

-1702967296

原因很简单,因为没有加L ,所有当成是int类型计算的,内存溢出了,应该为:

/**
 * @Author: chuxia0811
 * @Date: 2021/3/12 21:04
 * @Description :
 */
public class LongTest {
    public static void main(String[] args) {
        long diffTimes = 30 * 24 * 60 * 60 * 1000L;
        System.out.println(diffTimes);
    }
}

运行结果如下:

2592000000

其实每一个基本类型的取值都是有范围的,超过了范围就会出现意想不到的结果哦。

java基本类型的取值范围:

byte的取值范围为-128~127,占用1个字节(-2的7次方到2的7次方-1)
short的取值范围为-32768~32767,占用2个字节(-2的15次方到2的15次方-1)
int的取值范围为(-2147483648~2147483647),占用4个字节(-2的31次方到2的31次方-1)
long的取值范围为(-9223372036854774808~9223372036854774807),占用8个字节(-2的63次方到2的63次方-1)
float 3.402823e+38 ~ 1.401298e-45(e+38表示是乘以10的38次方,同样,e-45表示乘以10的负45次方)占用4个字节
double 1.797693e+308~ 4.9000000e-324 占用8个字节

上一篇:JavaScript-常用日期对象


下一篇:STM32F103的DAC功能完成波形输出,用示波器观察波形,并用蜂鸣器或手机耳机收听输出声音效果、感受歌曲的音质差异。