Java中两个long类型进行相加运算,值溢出的解决方法

博主在项目中遇到了这个需求,开始用的int类型进行运算,字段是存的字节,然后后台进行相应的逻辑运算返回给前台,前台来转化成GB。大家都知道1GB=1024MB,1MB=1024KB,1KB=1024Byte,所以1GB=1024*1024*1024=1073741824Byte。

所以问题来了,1GB的数据我后台就要存1073741824Byte,然后两个int类型进行相加直接溢出。


我们先来回顾下java的8种基本数据类型,Java语言有8种基本数据类型, 分别用于存储整数、浮点数、字符数据和布尔类型数据。

Java中两个long类型进行相加运算,值溢出的解决方法_第1张图片
从上图中可以看出, 基本数据类型主要分为4大类 (整数类型、浮点类型、char、boolean), 整数类型又分为了4小类(byte、short、int、long), 浮点类型也分了2小类(float、double),这些数据类型的区别是怎样的?通过下图展示了这8种数据类型的存储空间及使用场景:

类型名称 字节空间 使用场景
byte 1字节(8位) 存储字节数据(较常用)
short 2字节(16位) 兼容性考虑(很少使用)
int 4字节(32位) 存储普通整数(常用)
long 8字节(64位) 存储长整数(常用)
float 4字节(32位) 存储浮点数(不常用)
double 8字节(64位) 存储双精度浮点数(常用)
char 2字节(16位) 存储一个字符(常用)
boolean 1字节(8位) 存储逻辑变量(true、false)(常用)

ok,回顾完了,我们来看下int类型的数据范围-2的31次方 ~ 2的31次方-1(这个符号不好打出来,反正你懂得哈哈),即-2147483648 ~2147483647,大约正负21个亿多些。

我1GB都十几亿了,也就是说,我int类型只能运算2GB的数据,对于存储文件信息显然是不行的。

然后我想到了long型,long类型的数据范围-2的63次方 ~ 2的63次方-1,即 -9223372036854775808 ~ 9223372036854775807,也就是比int类型多了大约10的10次方,也就是2*10^10GB,可以满足需求,所以我就开干了。。。


我们来看下demo:

package com.test;

import java.math.BigDecimal;

/**
 * @author riemann
 * @date 2019/08/21 20:47
 */
public class TwoLongAddTest {

    public static void main(String[] args) {
        Long a = 2147483648L;
        Long b = 2147483648L;
        BigDecimal add = new BigDecimal(a).add(new BigDecimal(b));
        System.out.println(add.longValue());
    }

}

输出结果:

4294967296

这里两个long类型是不能直接进行相加的运算的,所以这里用BigDecimal 封装下进行相加运算。

直接输出add也可以得到求和的数据,但博主项目中返回给前台是long类型,所以进行了下类型转换add.longValue()

ok了,希望对你有帮助。

你可能感兴趣的:(Java)