BigDecimal与BigInteger用法(Java)

发布时间:2024年01月07日

BigDecimal与BigInteger用法

1. BigDecimal(处理高精度小数运算的类)

BigDecimal 是 Java 中用于处理高精度小数运算的类,它可以处理任意位数的小数,避免了浮点数运算中可能出现的精度误差问题。在 Java 应用程序中,如果需要进行高精度小数运算,就可以使用 BigDecimal 类。

下面是 BigDecimal 类的常用方法:

  1. 创建 BigDecimal 对象

可以使用以下方式创建 BigDecimal 对象:

// 使用字符串来创建 BigDecimal 对象
BigDecimal num1 = new BigDecimal("123.45");
BigDecimal num2 = new BigDecimal("67.89");

// 使用 double 或 float 类型来创建 BigDecimal 对象
BigDecimal num3 = new BigDecimal(123.45);
BigDecimal num4 = new BigDecimal(67.89f);

// 使用 long 或 int 类型来创建 BigDecimal 对象
BigDecimal num5 = new BigDecimal(12345);
BigDecimal num6 = new BigDecimal(6789L);
  1. 进行加、减、乘、除运算

可以使用以下方法进行加、减、乘、除等运算:

BigDecimal sum = num1.add(num2); // 加法运算
BigDecimal diff = num1.subtract(num2); // 减法运算
BigDecimal product = num1.multiply(num2); // 乘法运算
BigDecimal quotient = num1.divide(num2, 2, RoundingMode.HALF_UP); // 除法运算,结果保留两位小数,四舍五入

需要注意的是,除法运算时,如果除不尽会抛出异常。因此,在进行除法运算时,需要指定小数位数和舍入方式。

  1. 比较大小

可以使用以下方法比较两个 BigDecimal 对象的大小:

int cmp = num1.compareTo(num2); // 比较大小,返回值为 -1、0、1 分别表示小于、等于、大于
boolean b1 = num1.equals(num2); // 判断是否相等
boolean b2 = num1.compareTo(num2) > 0; // 判断大小关系
  1. 转换为其他数据类型

可以使用以下方法将 BigDecimal 对象转换为其他数据类型:

double d = num1.doubleValue(); // 转换为 double 类型
float f = num1.floatValue(); // 转换为 float 类型
long l = num1.longValue(); // 转换为 long 类型
int i = num1.intValue(); // 转换为 int 类型
String s = num1.toString(); // 转换为字符串类型

需要注意的是,在将 BigDecimal 对象转换为基本数据类型时,可能会丢失精度,因此需要谨慎处理。


2.BigInteger(处理高精度整数运算的类)

BigInteger 是 Java 中用于处理高精度整数运算的类,它可以处理任意位数的整数,避免了整数溢出的问题。在 Java 应用程序中,如果需要进行高精度整数运算,就可以使用 BigInteger 类。

下面是 BigInteger 类的常用方法:

  1. 创建 BigInteger 对象

可以使用以下方式创建 BigInteger 对象:

// 使用字符串来创建 BigInteger 对象
BigInteger num1 = new BigInteger("12345678901234567890");
BigInteger num2 = new BigInteger("-12345678901234567890");

// 使用 long 或 int 类型来创建 BigInteger 对象
BigInteger num3 = BigInteger.valueOf(1234567890L);
BigInteger num4 = BigInteger.valueOf(-1234567890);

需要注意的是,使用 long 或 int 类型来创建 BigInteger 对象时,可能会发生溢出,因此需要谨慎处理。

  1. 进行加、减、乘、除运算

可以使用以下方法进行加、减、乘、除等运算:

BigInteger sum = num1.add(num2); // 加法运算
BigInteger diff = num1.subtract(num2); // 减法运算
BigInteger product = num1.multiply(num2); // 乘法运算
BigInteger quotient = num1.divide(num2); // 除法运算
BigInteger remainder = num1.remainder(num2); // 取余运算

需要注意的是,在进行除法运算时,如果除不尽会抛出异常。因此,在进行除法运算时,需要谨慎处理。

  1. 比较大小

可以使用以下方法比较两个 BigInteger 对象的大小:

int cmp = num1.compareTo(num2); // 比较大小,返回值为 -1、0、1 分别表示小于、等于、大于
boolean b1 = num1.equals(num2); // 判断是否相等
boolean b2 = num1.compareTo(num2) > 0; // 判断大小关系
  1. 转换为其他数据类型

可以使用以下方法将 BigInteger 对象转换为其他数据类型:

long l = num1.longValue(); // 转换为 long 类型
int i = num1.intValue(); // 转换为 int 类型
String s = num1.toString(); // 转换为字符串类型

需要注意的是,在将 BigInteger 对象转换为基本数据类型时,可能会发生溢出,因此需要谨慎处理。

文章来源:https://blog.csdn.net/weixin_48935611/article/details/135436891
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。