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()进行精度的指定和舍入方式的设置。


目录
相关文章
|
6月前
|
存储 算法 安全
Java集合框架:理解类型多样性与限制
总之,在 Java 题材中正确地应对多样化与约束条件要求开发人员深入理解面向对象原则、范式编程思想以及JVM工作机理等核心知识点。通过精心设计与周密规划能够有效地利用 Java 高级特征打造出既健壮又灵活易维护系统软件产品。
182 7
|
7月前
|
Java 开发者
Java 函数式编程全解析:静态方法引用、实例方法引用、特定类型方法引用与构造器引用实战教程
本文介绍Java 8函数式编程中的四种方法引用:静态、实例、特定类型及构造器引用,通过简洁示例演示其用法,帮助开发者提升代码可读性与简洁性。
|
8月前
|
安全 算法 Java
Java泛型编程:类型安全与擦除机制
Java泛型详解:从基础语法到类型擦除机制,深入解析通配符与PECS原则,探讨运行时类型获取技巧及最佳实践,助你掌握泛型精髓,写出更安全、灵活的代码。
|
8月前
|
安全 IDE Java
Java记录类型(Record):简化数据载体类
Java记录类型(Record):简化数据载体类
613 143
|
8月前
|
Java 测试技术
Java浮点类型详解:使用与区别
Java中的浮点类型主要包括float和double,它们在内存占用、精度范围和使用场景上有显著差异。float占用4字节,提供约6-7位有效数字;double占用8字节,提供约15-16位有效数字。float适合内存敏感或精度要求不高的场景,而double精度更高,是Java默认的浮点类型,推荐在大多数情况下使用。两者都存在精度限制,不能用于需要精确计算的金融领域。比较浮点数时应使用误差范围或BigDecimal类。科学计算和工程计算通常使用double,而金融计算应使用BigDecimal。
3215 102
|
Java API
Java中BigDecimal详解及应用
BigDecimal用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数,但在实际应用中,可能需要对更大或者更小的数进行运算和处理。一般情况下,对于那些不需要准确计算精度的数字,我们可以直接使用Float和Double处理,但是Double.valueOf(String) 和Float.valueOf(String)会丢失精度。所以在开发中,如果你所做的业务跟财务相关需要精确计算的结果,那必须使用BigDecimal类来操作啦!
627 2
Java中BigDecimal详解及应用
|
6月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
340 1
|
6月前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
339 1
|
7月前
|
数据采集 存储 弹性计算
高并发Java爬虫的瓶颈分析与动态线程优化方案
高并发Java爬虫的瓶颈分析与动态线程优化方案
Java 数据库 Spring
322 0