我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Java精确计算BigDecimal类怎么使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Java精确计算BigDecimal类怎么使用

本篇内容主要讲解“Java精确计算BigDecimal类怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java精确计算BigDecimal类怎么使用”吧!

引言

float和double类型的主要设计目标是为了科学计算和工程计算。他们执行二进制浮点运算,这是为了在广域数值范围上提供较为精确的快速近似计算而精心设计的。然而,它们没有提供完全精确的结果,所以不应该被用于要求精确结果的场合。但是,商业计算往往要求结果精确,这时候BigDecimal就派上大用场啦。

先看下面代码

public static void main(String[] args)    {        System.out.println(0.2 + 0.1);        System.out.println(0.3 - 0.1);        System.out.println(0.2 * 0.1);        System.out.println(0.3 / 0.1);    }

运行结果如下

Java精确计算BigDecimal类怎么使用

你认为你看错了,但结果却是是这样的。问题在哪里呢?原因在于我们的计算机是二进制的。浮点数没有办法是用二进制进行精确表示。我们的CPU表示浮点数由两个部分组成:指数和尾数,这样的表示方法一般都会失去一定的精确度,有些浮点数运算也会产生一定的误差。如:2.4的二进制表示并非就是精确的2.4。反而最为接近的二进制表示是2.3999999999999999。浮点数的值实际上是由一个特定的数学公式计算得到的。

其实java的float只能用来进行科学计算或工程计算,在大多数的商业计算中,一般采用java.math.BigDecimal类来进行精确计算。

BigDecimal构造方法

  • public BigDecimal(double val) 将double表示形式转换为BigDecimal *不建议使用

  • public BigDecimal(int val)  将int表示形式转换成BigDecimal

  • public BigDecimal(String val)  将String表示形式转换成BigDecimal

为什么不建议采用第一种构造方法呢?来看例子

public static void main(String[] args)    {        BigDecimal bigDecimal = new BigDecimal(2);        BigDecimal bDouble = new BigDecimal(2.3);        BigDecimal bString = new BigDecimal("2.3");        System.out.println("bigDecimal=" + bigDecimal);        System.out.println("bDouble=" + bDouble);        System.out.println("bString=" + bString);    }

运行结果如下

Java精确计算BigDecimal类怎么使用

为什么会出现这种情况呢?

JDK的描述:

参数类型为double的构造方法的结果有一定的不可预知性。有人可能认为在Java中写入newBigDecimal(0.1)所创建的BigDecimal正好等于 0.1(非标度值 1,其标度为 1),但是它实际上等于0.1000000000000000055511151231257827021181583404541015625。这是因为0.1无法准确地表示为 double(或者说对于该情况,不能表示为任何有限长度的二进制小数)。这样,传入到构造方法的值不会正好等于 0.1(虽然表面上等于该值)。

另一方面,String 构造方法是完全可预知的:写入 newBigDecimal("0.1") 将创建一个 BigDecimal,它正好等于预期的 0.1。因此,比较而言,通常建议优先使用String构造方法

当double必须用作BigDecimal的源时,请使用Double.toString(double)转成String,然后使用String构造方法,或使用BigDecimal的静态方法valueOf,如下

public static void main(String[] args)    {        BigDecimal bDouble1 = BigDecimal.valueOf(2.3);        BigDecimal bDouble2 = new BigDecimal(Double.toString(2.3));        System.out.println("bDouble1=" + bDouble1);        System.out.println("bDouble2=" + bDouble2);            }

结果如下

Java精确计算BigDecimal类怎么使用

BigDecimal加减乘除运算

对于常用的加,减,乘,除,BigDecimal类提供了相应的成员方法。

public BigDecimal add(BigDecimal value);                        //加法public BigDecimal subtract(BigDecimal value);                   //减法 public BigDecimal multiply(BigDecimal value);                   //乘法public BigDecimal divide(BigDecimal value);                     //除法

大概的用法如下

public static void main(String[] args)    {        BigDecimal a = new BigDecimal("4.5");        BigDecimal b = new BigDecimal("1.5");        System.out.println("a + b =" + a.add(b));        System.out.println("a - b =" + a.subtract(b));        System.out.println("a * b =" + a.multiply(b));        System.out.println("a / b =" + a.divide(b));    }

运行结果

Java精确计算BigDecimal类怎么使用

这里有一点需要注意的是除法运算divide.

BigDecimal除法可能出现不能整除的情况,比如 4.5/1.3,这时会报错java.lang.ArithmeticException: Non-terminating decimal expansion; no exact representable decimal result.

其实divide方法有可以传三个参数

public BigDecimal divide(BigDecimal divisor, int scale, int roundingMode) 

第一参数表示除数, 第二个参数表示小数点后保留位数

第三个参数表示舍入模式,只有在作除法运算或四舍五入时才用到舍入模式,有下面这几种

ROUND_CEILING    //向正无穷方向舍入ROUND_DOWN    //向零方向舍入ROUND_FLOOR    //向负无穷方向舍入ROUND_HALF_DOWN    //向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向下舍入, 例如1.55 保留一位小数结果为1.5ROUND_HALF_EVEN    //向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,如果保留位数是奇数,使用ROUND_HALF_UP,如果是偶数,使用ROUND_HALF_DOWNROUND_HALF_UP    //向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向上舍入, 1.55保留一位小数结果为1.6ROUND_UNNECESSARY    //计算结果是精确的,不需要舍入模式ROUND_UP    //向远离0的方向舍入

按照各自的需要,可传入合适的第三个参数。四舍五入采用ROUND_HALF_UP

需要对BigDecimal进行截断和四舍五入可用setScale方法,例:

public static void main(String[] args)    {        BigDecimal a = new BigDecimal("4.5635");        a = a.setScale(3, RoundingMode.HALF_UP);    //保留3位小数,且四舍五入        System.out.println(a);    }

减乘除其实最终都返回的是一个新的BigDecimal对象,因为BigInteger与BigDecimal都是不可变的(immutable)的,在进行每一步运算时,都会产生一个新的对象 

public static void main(String[] args)    {        BigDecimal a = new BigDecimal("4.5");        BigDecimal b = new BigDecimal("1.5");        a.add(b);        System.out.println(a);  //输出4.5. 加减乘除方法会返回一个新的BigDecimal对象,原来的a不变    }

到此,相信大家对“Java精确计算BigDecimal类怎么使用”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Java精确计算BigDecimal类怎么使用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Java精确计算BigDecimal类怎么使用

本篇内容主要讲解“Java精确计算BigDecimal类怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java精确计算BigDecimal类怎么使用”吧!引言float和double类型
2023-06-25

Java高精度计算BigDecimal类实例分析

这篇文章主要介绍了Java高精度计算BigDecimal类实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java高精度计算BigDecimal类实例分析文章都会有所收获,下面我们一起来看看吧。如果我们编
2023-06-03

Java中的高精度计算怎么利用BigDecimal实现

本篇文章给大家分享的是有关Java中的高精度计算怎么利用BigDecimal实现,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。首先看如下代码示例:System.out.prin
2023-05-31

Java中怎么精确计算浮点数

今天就跟大家聊聊有关Java中怎么精确计算浮点数,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。问题的提出:XML:namespace prefix = o ns = "urn:sch
2023-06-03

Java BigDecimal类怎么用

这篇文章主要介绍了Java BigDecimal类怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、简介Java在java.math包中提供的API类BigDecima
2023-06-25

Java的BigDecimal类怎么用

这篇文章主要介绍“Java的BigDecimal类怎么用”,在日常操作中,相信很多人在Java的BigDecimal类怎么用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java的BigDecimal类怎么用
2023-06-17

怎么用VBS精确计算2的100次方

这篇文章主要介绍了怎么用VBS精确计算2的100次方,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。既然Python可以计算2的100次方,那么我就要用VBS实现。不过这个效率
2023-06-08

BigDecimal怎么在Java中使用

这期内容当中小编将会给大家带来有关BigDecimal怎么在Java中使用,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Java中提供了大数字(超过16位有效位)的操作类,即 java.math.BinI
2023-05-30

怎么使用Java中的BigDecimal

这篇文章主要介绍“怎么使用Java中的BigDecimal”,在日常操作中,相信很多人在怎么使用Java中的BigDecimal问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用Java中的BigDeci
2023-06-16

怎么精确计算微信小程序scrollview高度

这篇文章主要介绍了怎么精确计算微信小程序scrollview高度的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么精确计算微信小程序scrollview高度文章都会有所收获,下面我们一起来看看吧。一、布局分析,
2023-06-26

使用工具类-java精确到小数点后6位

这篇文章主要介绍了使用工具类-java精确到小数点后6位,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-11-13

BigDecimal和double怎么在Java中使用

本篇文章为大家展示了 BigDecimal和double怎么在Java中使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。BigDecimal类对于不需要任何准确计算精度的数字可以直接使用float
2023-05-30

java中BigDecimal怎么用来进行数学运算

这篇文章给大家分享的是有关java中BigDecimal怎么用来进行数学运算的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、BigDecimal在做加、减、乘时,精度不会丢失,但是做除法时,存在无法除尽的情况,
2023-06-15

怎么在java中使用BigDecimal解决异常

本篇文章为大家展示了怎么在java中使用BigDecimal解决异常,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Java的优点是什么1. 简单,只需理解基本的概念,就可以编写适合于各种情况的应用程
2023-06-14

Java中BigDecimal的舍入模式怎么使用

这篇文章主要讲解了“Java中BigDecimal的舍入模式怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java中BigDecimal的舍入模式怎么使用”吧!BigDecimal的
2023-07-02

java内部类修饰符怎么正确使用

Java内部类的修饰符可以使用以下几种方式:1. private:只有外部类可以访问内部类,其他类无法访问。2. protected:只有外部类及其子类可以访问内部类,其他类无法访问。3. public:任何类都可以访问内部类。4. sta
2023-10-12

java中怎么计算cpu使用率

本篇文章给大家分享的是有关java中怎么计算cpu使用率,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。/proc/stat 文件内容:[root@Shentar ~]# cat
2023-06-17

使用java怎么对BigDecimal进行格式化

使用java怎么对BigDecimal进行格式化?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Java的优点是什么1. 简单,只需理解基本的概念,就可以编写适合
2023-06-14

【Java基础教程】(三十六)常用类库篇 · 第六讲:数学运算类——全面讲解Java数学计算支持类库,BigDecimal、Math、Random、DecimalFormat...~

Java基础教程之常用类库 · 数学运算类 1️⃣ 概念🔍 数学运算类汇总 2️⃣ 优势和缺点3️⃣ 使用3.1 各数学计算支持类使用案例3.2 Math类3.3 BigDecimal类3.4 Random
2023-08-16

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录