Java中BigDecimal 类的创建对象方法,介绍,常用方法以及8种舍入模式

简介: Java中BigDecimal 类的创建对象方法,介绍,常用方法以及8种舍入模式

一、BigDecimal 类的介绍

      * 因为计算机无法精确表示浮点数,所以在进行数字运算时,如果有double或float类型的浮点数
        参与计算,容易出现计算不准确的情况。

      * 在一些对精度要求很高的系统中,需要使用 "BigDecimal" 类来进行精确运行。

二、创建BigDecimal对象的方式

1.使用构造方法创建对象

     (1)BigDecimal(String val) :使用 String类型的数字 作为参数

            BigDecimal b1=new BigDecimal("0.1");
            System.out.println(b1);    //0.1

     (2)BigDecimal(double val) :使用 double类型的数字 作为参数。(不推荐,容易丢精度)

         BigDecimal b2=new BigDecimal(0.1); 
         System.out.println(b2);   //0.1000000000000000055511151231257827021181583404541015625

2.使用静态方法创建对象

     (1)BigDecimal.valueOf(double val)

            double  d=0.1;
            BigDecimal d1=BigDecimal.valueOf(d);
            System.out.println(d1);

在这里插入图片描述


三、BigDecimal 类的常用方法

     (1)public BigDecimal add(另一个BigDecimal对象) :加法

            BigDecimal  a=new BigDecimal("0.1");
            BigDecimal  b=new BigDecimal("0.2");
            BigDecimal c=a.add(b);              //0.3

     (2)public BigDecimal subtract (另一个BigDecimal对象) : 减法

            BigDecimal  a=new BigDecimal("0.1");
            BigDecimal  b=new BigDecimal("0.2");
            BigDecimal c1=a.subtract(b);          //-0.1

     (3)public BigDecimal multiply (另一个BigDecimal对象) : 乘法

            BigDecimal  a=new BigDecimal("0.1");
            BigDecimal  b=new BigDecimal("0.2");
            BigDecimal c2=a.multiply(b);           //0.02

     (4)public BigDecimal divide (另一个BigDecimal对象) :除法

            BigDecimal  a=new BigDecimal("0.1");
            BigDecimal  b=new BigDecimal("0.2");
            BigDecimal c3=a.divide(b);             //0.5

----------------------------------------------------------------------------------------------
    
//如果除不尽,使用另外重载的方法
    
            BigDecimal  adivide=new BigDecimal("10");
            BigDecimal  bdivide=new BigDecimal("3");

                                          //除数   保留多少位小数    舍入模式
            BigDecimal sum=adivide.divide(bdivide,3, RoundingMode.HALF_UP);  
            System.out.println(sum);    //3.333


//RoundingMode.HALF_UP 表四舍五入

在这里插入图片描述

在这里插入图片描述


     (5) BigDecimal remainder( BigDecimal b ) : 对两个BigDecimal进行取余

           BigDecimal   b1=new BigDecimal("5");
           BigDecimal   b2=new BigDecimal("2");
           System.out.println(b1.remainder(b2));   // 1

     (6)BigDecimal negate(BigDecimal b) : 求BigDecimal类型数据的相反数

            BigDecimal n1=new BigDecimal("5");
            BigDecimal n2=n1.negate();
            System.out.println(n2);    //-5

四、RoundingMode的8种舍入模式介绍

   (1) RoundingMode UP : 舍入模式从零开始;始终在非零丢弃分数之前增加数字  (正数"变大",负数"变小")
                 如:  5.5 -> 6.0    -5.5 -> -6
                     
   (2) RoundingMode DOWN : 舍入模式向零舍入; 不要在丢弃的分数之前递增数字(即截断)    (正数"变小",负数"变大")
                 如:  5.5 -> 5    -5.5 -> -5   
                     
   (3) RoundingMode CEILING : 圆形模式向正无穷大转弯; 
            如果结果为正,则表现为RoundingMode.UP ; 如果为负,表现为RoundingMode.DOWN   ("全部变大")
                      
                 如: 5.5 -> 6          -5.5 -> -5
                     
   (4) RoundingMode FLOOR :舍入模式向负无穷大转弯;
            如果结果为正,则表现为RoundingMode.DOWN ; 如果为负,表现为RoundingMode.UP   ("全部变小")
                
                如:  5.5 -> 5          -5.5 -> -6
                    
   (5) RoundingMode HALF_UP : 四舍五入模式向"最近邻居"转弯,除非两个邻居都是等距的,在这种情况下是圆括弧的 
           如果丢弃的分数为RoundingMode.UP则表示为RoundingMode.UP ; 否则,表现为RoundingMode.DOWN    ("四舍五入")                                       
                如: 5.5 -> 6           -2.5 -> -3
    
   (6) RoundingMode HALF_DOWN : 四舍五入模式向"最近邻居"转弯,除非这两个邻居都是等距离的,在这种情况下,这是倒圆的 
           如果丢弃的分数> 0.5,则表示为RoundingMode.UP ; 否则,表现为RoundingMode.DOWN       ("五舍六入")
               
                如: 5.5 -> 5           -5.5  -> -5
                    
   (7) RoundingMode HALF_EVEN : "银行家四舍五入"
                     (目标是偶数,可以使用四舍五入,也可以适用五舍六入,具体看哪边更接近一个偶数)      
                    
                如:  5.5 -> 6         -2.5 -> -2    -5.5 -> -6
                    
   (8) RoundingMode UNNECESSARY :舍入模式来确定所请求的操作具有精确的结果,因此不需要舍入 
               如果在产生不精确结果的操作上指定了舍入模式,则抛出ArithmeticException          
               
         (需要舍掉的位数不是0,就报异常 "ArithmeticException" ; 如果需要舍掉的位数是0,就返回已结舍掉的正常结果)

作者:KJ.JK

本文仅用于交流学习,未经作者允许,禁止转载,更勿做其他用途,违者必究。
文章对你有所帮助的话,欢迎给个赞或者 star ,你的支持是对作者最大的鼓励,不足之处可以在评论区多多指正,交流学习呀

目录
相关文章
|
6月前
|
存储 Java 索引
用Java语言实现一个自定义的ArrayList类
自定义MyArrayList类模拟Java ArrayList核心功能,支持泛型、动态扩容(1.5倍)、增删改查及越界检查,底层用Object数组实现,适合学习动态数组原理。
268 4
|
6月前
|
Java
Java语言实现字母大小写转换的方法
Java提供了多种灵活的方法来处理字符串中的字母大小写转换。根据具体需求,可以选择适合的方法来实现。在大多数情况下,使用 String类或 Character类的方法已经足够。但是,在需要更复杂的逻辑或处理非常规字符集时,可以通过字符流或手动遍历字符串来实现更精细的控制。
426 18
|
6月前
|
IDE JavaScript Java
在Java 11中,如何处理被弃用的类或接口?
在Java 11中,如何处理被弃用的类或接口?
322 5
|
6月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
326 1
|
6月前
|
Java Go 开发工具
【Java】(8)正则表达式的使用与常用类分享
正则表达式定义了字符串的模式。正则表达式并不仅限于某一种语言,但是在每种语言中有细微的差别。
456 1
|
6月前
|
存储 Java 程序员
【Java】(6)全方面带你了解Java里的日期与时间内容,介绍 Calendar、GregorianCalendar、Date类
java.util 包提供了 Date 类来封装当前的日期和时间。Date 类提供两个构造函数来实例化 Date 对象。第一个构造函数使用当前日期和时间来初始化对象。Date( )第二个构造函数接收一个参数,该参数是从1970年1月1日起的毫秒数。
296 0
|
6月前
|
Java 编译器 Go
【Java】(5)方法的概念、方法的调用、方法重载、构造方法的创建
Java方法是语句的集合,它们在一起执行一个功能。方法是解决一类问题的步骤的有序组合方法包含于类或对象中方法在程序中被创建,在其他地方被引用方法的优点使程序变得更简短而清晰。有利于程序维护。可以提高程序开发的效率。提高了代码的重用性。方法的名字的第一个单词应以小写字母作为开头,后面的单词则用大写字母开头写,不使用连接符。例如:addPerson。这种就属于驼峰写法下划线可能出现在 JUnit 测试方法名称中用以分隔名称的逻辑组件。
297 4
|
6月前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
326 1
|
6月前
|
编解码 Java 开发者
Java String类的关键方法总结
以上总结了Java `String` 类最常见和重要功能性方法。每种操作都对应着日常编程任务,并且理解每种操作如何影响及处理 `Strings` 对于任何使用 Java 的开发者来说都至关重要。
394 5
|
Java
《Java创建对象类型数组的三种方式》
《Java创建对象类型数组的三种方式》
268 0
下一篇
开通oss服务