Java 大数字运算之 BigDecimal 类

在 Java 中提供了用于大数字运算的类,即 java.math.BigInteger 类和 java.math.BigDecimal 类。这两个类用于高精度计算,其中 BigInteger 类是针对整型大数字的处理类,而 BigDecimal 类是针对大小数的处理类。今天主要讲一下 BigDecimal 类

BigDecimal 类

        BigInteger 和 BigDecimal 都能实现大数字的运算,不同的是 BigDecimal 加入了小数的概念。一般的 float 和 double 类型数据只能用来做科学计算或工程计算,但由于在商业计算中要求数字精度比较高,所以要用到 BigDecimal 类。BigDecimal 类支持任何精度的浮点数,可以用来精确计算货币值。

BigDecimal 常用的构造方法如下。

BigDecimal(double val):实例化时将双精度型转换为 BigDecimal 类型。

BigDecimal(String val):实例化时将字符串形式转换为 BigDecimal 类型。

        BigDecimal 类的方法可以用来做超大浮点数的运算,像加、减、乘和除等。在所有运算中,除法运算是最复杂的,因为在除不尽的情况下,末位小数的处理方式是需要考虑的。

        下面列出了 BigDecimal 类用于实现加、减、乘和除运算的方法。

BigDecimal add(BigDecimal augend) // 加法操作

BigDecimal subtract(BigDecimal subtrahend) // 减法操作

BigDecimal multiply(BigDecimal multiplieand) // 乘法操作

BigDecimal divide(BigDecimal divisor,int scale,int roundingMode ) // 除法操作

        其中,divide() 方法的 3 个参数分别表示除数、商的小数点后的位数和近似值处理模式。

        下表列出了 roundingMode 参数支持的处理模式。

例:

        编写一个 Java 程序,演示如何使用 BigDecimal 类提供的方法对数字执行运算,并输出结果。具体实现代码如下:

import java.math.BigDecimal;

import java.util.Scanner;

public class Test10 {

    public static void main(String[] args) {

        Scanner input = new Scanner(System.in);

        System.out.println("请输入一个数字:");

        // 保存用户输入的数字

        double num = input.nextDouble();

        // 使用输入的数字创建 BigDecimal 对象

        BigDecimal bd = new BigDecimal(num);

        // 计算大数字加上 99.154 的结果

        System.out.println("加法操作结果:" + bd.add(new BigDecimal(99.154)));

        // 计算大数字减去-25.157904 的结果

        System.out.println("减法操作结果:" + bd.subtract(new BigDecimal(-25.157904)));

        // 计算大数字乘以 3.5 的结果

        System.out.println("乘法操作结果:" + bd.multiply(new BigDecimal(3.5)));

        // 计算大数字除以 3.14 的结果,并保留小数后 2 位

        System.out.println("除法操作结果(保留 2 位小数):" + bd.divide(new BigDecimal(3.14), 2, BigDecimal.ROUND_CEILING));

        // 计算大数字除以 3.14 的结果,并保留小数后 5 位

        System.out.println("除法操作结果(保留 5 位小数):" + bd.divide(new BigDecimal(3.14), 5, BigDecimal.ROUND_CEILING));

    }

}

        上述代码将用户输入的数字保存到 num 变量中,然后调用“newBigDecimal(num)”方法来创建 BigDecimal 对象。接下来的代码演示了如何调用 BigDecimal 类提供的运算方法,运行效果如下所示。

请输入一个数字:

100

加法操作结果:199.15399999999999636202119290828704833984375

减法操作结果:125.157903999999998490011421381495893001556396484375

乘法操作结果:350.0

除法操作结果(保留 2 位小数):31.85

除法操作结果(保留 5 位小数):31.84714

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
BigDecimalJava中一个用来处理高精度数字,可以实现精确的浮点数计算,避免了传统的double和float型在计算时的精度丢失问题。BigDecimal提供了基本的加、减、乘、除等运算方法,还可以进行舍入、比较、求幂等高级运算。 下面是BigDecimal运算的一些示例: 1. 加法运算 ```java BigDecimal num1 = new BigDecimal("2.5"); BigDecimal num2 = new BigDecimal("3.7"); BigDecimal sum = num1.add(num2); System.out.println(sum); // 输出6.2 ``` 2. 减法运算 ```java BigDecimal num1 = new BigDecimal("5.8"); BigDecimal num2 = new BigDecimal("2.5"); BigDecimal diff = num1.subtract(num2); System.out.println(diff); // 输出3.3 ``` 3. 乘法运算 ```java BigDecimal num1 = new BigDecimal("2.5"); BigDecimal num2 = new BigDecimal("3.7"); BigDecimal product = num1.multiply(num2); System.out.println(product); // 输出9.25 ``` 4. 除法运算 ```java BigDecimal num1 = new BigDecimal("8.5"); BigDecimal num2 = new BigDecimal("2"); BigDecimal quotient = num1.divide(num2); System.out.println(quotient); // 输出4.25 ``` 5. 取余运算 ```java BigDecimal num1 = new BigDecimal("9.5"); BigDecimal num2 = new BigDecimal("2"); BigDecimal remainder = num1.remainder(num2); System.out.println(remainder); // 输出1.5 ``` 6. 比较运算 ```java BigDecimal num1 = new BigDecimal("5.8"); BigDecimal num2 = new BigDecimal("2.5"); int result = num1.compareTo(num2); if(result > 0) { System.out.println("num1大于num2"); } else if(result < 0) { System.out.println("num1小于num2"); } else { System.out.println("num1等于num2"); } ``` 7. 舍入运算 ```java BigDecimal num1 = new BigDecimal("3.1415926"); BigDecimal round = num1.setScale(3, RoundingMode.HALF_UP); System.out.println(round); // 输出3.142 ``` 在进行BigDecimal运算时,需要注意以下几点: 1. 应该使用字符串作为BigDecimal的构造参数,而不是使用double或float型,因为这样可以避免精度丢失问题。 2. 进行除法运算时,应该指定除法运算的精度和舍入规则。 3. 在进行比较运算时,应该使用compareTo()方法,而不是使用equals()方法,因为equals()方法只能判断两个BigDecimal对象是否相等,而compareTo()方法可以判断两个BigDecimal对象的大小关系。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值