Java中-BigDecimal类型如何进行加减乘除运算?

简介: Java中-BigDecimal类型如何进行加减乘除运算

1:什么是 BigDecimal

        BigDecimal是Java中用于处理精确浮点数计算的类。它可以用于解决两个整数的除法和乘法运算的精确计算和处理浮点数运算中的舍入误差。

2:什么是原因导致误差

        浮点数舍入误差是由于计算机采用二进制存储,而二进制无法精确地表示某些十进制数字,从而导致的误差。例如,小数0.1在二进制中无法精确表示,会被舍入成一个无限接近的二进制数0.0001100110011001100…。当这个二进制数被转换回十进制时,仍然会存在舍入误差,导致得到的结果与实际值不完全相等

3:BigDecimal类的常用方法包括

add(BigDecimal val):将当前BigDecimal对象的值与参数val的值相加并返回结果。
subtract(BigDecimal val):将当前BigDecimal对象的值减去参数val的值并返回结果。
multiply(BigDecimal val):将当前BigDecimal对象的值乘以参数val的值并返回结果。
divide(BigDecimal val):将当前BigDecimal对象的值除以参数val的值并返回结果。
setScale(int newScale, RoundingMode roundingMode):设定小数位数并按指定的模式进行舍入。

例1:

例如,以下是使用BigDecimal类进行数学运算的示例:

import java.math.BigDecimal;
import java.math.RoundingMode;
public class BigDecimalExample {
    public static void main(String[] args) {
        BigDecimal num1 = new BigDecimal("10.5"); // 第一个数
        BigDecimal num2 = new BigDecimal("5.25");  // 第二个数
        // 相加
        BigDecimal sum = num1.add(num2);
        System.out.println("Sum: " + sum); // 输出结果:Sum: 15.75
        // 相减
        BigDecimal difference = num1.subtract(num2);
        System.out.println("Difference: " + difference); // 输出结果:Difference: 5.25
        // 相乘
        BigDecimal product = num1.multiply(num2);
        System.out.println("Product: " + product); // 输出结果:Product: 55.125
        // 相除
        BigDecimal quotient = num1.divide(num2, 2, RoundingMode.HALF_UP);
        System.out.println("Quotient: " + quotient); // 输出结果:Quotient: 2.00
    }
}

在上述示例代码中,我们创建了两个BigDecimal类型的值 num1 和 num2,并使用add(),subtract(),multiply(),divide() 方法对它们进行了加法、减法、乘法、除法的数学运算。其中,在进行除法计算时,我们通过传递2参数和RoundingMode.HALF_UP模式来将结果舍入为小数点后两位,即保留两位小数。

例2:

我们可以通过setScale()方法设置BigDecimal对象的小数位数,并定义舍入方式。例如:

import java.math.BigDecimal;
import java.math.RoundingMode;
public class BigDecimalExample {
    public static void main(String[] args) {
        BigDecimal number = new BigDecimal("10.123456");
        BigDecimal roundedNumber = number.setScale(2, RoundingMode.HALF_UP);
        // 输出结果:Rounded Number: 10.12
        System.out.println("Rounded Number: " + roundedNumber); 
    }
}

在上述示例代码中,我们创建了一个BigDecimal对象number并对其进行了四舍五入。使用setScale()方法,我们将其小数精度设置为2,然后使用HALF_UP这个舍入模式将其舍入为最接近的数字。因此,最终结果roundedNumber为10.12,保留了两位小数。

总之,BigDecimal类提供了一种方便的机制来解决浮点数舍入误差等问题,并可以用于处理和计算高精度数字。可以使用它的不同方法进行加减乘除,并使用setScale()进行精度的指定和舍入方式的设置。


目录
相关文章
|
3天前
|
Java
深入了解Java中的BigDecimal类及其方法
深入了解Java中的BigDecimal类及其方法
9 1
|
7天前
|
Java 数据处理 Apache
探讨Java中判断String类型为空和null的方法
探讨Java中判断String类型为空和null的方法
11 1
|
3天前
|
存储 安全 Java
JAVA泛型:类型安全,从编译时开始!
【6月更文挑战第28天】Java泛型是JDK 5引入的特性,用于在编译时实现类型安全的集合。它通过类型参数增强代码灵活性和重用性,减少错误。示例展示了泛型列表`List<Integer>`和`List<String>`如何确保元素类型正确,防止编译时类型不符。泛型提升了代码的类型安全、可读性和维护性。
|
3天前
|
安全 Java 编译器
JAVA泛型,编译时类型安全的“秘密武器”
【6月更文挑战第28天】Java泛型是JDK 5引入的特性,用于在编译时增强类型安全和代码复用。它允许类、接口和方法使用类型参数,确保运行时类型匹配,减少了类型转换错误。例如,泛型方法`<T> void printArray(T[] array)`能接受任何类型数组,编译器会检查类型一致性。此外,泛型提升了代码的可读性、可维护性和与容器类的配合效率,优化整体软件质量。
|
3天前
|
安全 Java 开发者
谁说 JAVA 不懂爱?泛型来给你满满的类型安全感!
【6月更文挑战第28天】Java泛型,编程中的类型守护者,提供编译期类型检查,增强代码安全与可读。如`GenericBox<T>`示例,实现类型参数化,避免转换错误。泛型方法如`printArray<T>`,灵活处理不同数据。它简化代码,消除潜在错误,赋予开发者类型保障的爱,让编程之旅更安心。Java的泛型,是对其语言之爱的深刻表达。
|
7天前
|
算法 Java
Java数据结构与算法:位运算之与、或、异或运算
Java数据结构与算法:位运算之与、或、异或运算
|
7天前
|
存储 Java 程序员
在Java中,变量和类型
在Java中,变量和类型
8 0
|
2月前
|
Java
【Java】如果一个集合中类型是String如何使用拉姆达表达式 进行Bigdecimal类型计算?
【Java】如果一个集合中类型是String如何使用拉姆达表达式 进行Bigdecimal类型计算?
41 0
|
2月前
|
存储 Java
你知道Java中的BigInteger类和BigDecimal类吗?
你知道Java中的BigInteger类和BigDecimal类吗?
|
Java
Java开发篇- 从BigDecimal的divide的异常说起
在过去做项目的某一天中,突然有小伙伴说两个BigDecimal的数据相除(divide)报错了,觉得不可能,然后问他是怎么编写的,他说很简单呀,就是new了2个BigDecimal,然后相除的结果赋值给另外一个BigDecimal对象。听起来觉得没有问题,正常来说,2个Integer(int),2个Double(double)都不会报错,然后问是什么异常,说是一个很奇怪的异常
382 0