关于Java中的BigDecimal

news2024/12/23 14:05:20

文章目录

  • 为什么用BigDecimal
  • BigDecimal构造方法
  • 通过静态方法创建BigDecimal对象
  • BigDecimal常用API
    • 关于除法运算的roundingMode
  • 将BigDecimal转换为基本类型
  • 代码展示
  • 小结
  • 其他文章

为什么用BigDecimal

  • 使用float、double及其对应的包装类时,运算精度可能不满足需求
    • float最多只有7位有效数,则其精度为6-7位。
    • double最多只有16位有效数,则其精度为15~16位。
  • 使用float、double及其对应的包装类时,不便于对小数点以后的若干位进行截取四舍五入或相关处理
    所以BigDecimal主要是用来解决误差问题(精度问题)

BigDecimal构造方法

在这里插入图片描述

通过静态方法创建BigDecimal对象

返回值类型方法说明
BigDecimalvalueOf(double val)基于float / double类型的数据创建BigDecimal对象
BigDecimalvalueOf(long val)基于byte/ short / int / long类型的数据创建BiqDecimal对象

BigDecimal常用API

返回值类型方法说明
BigDecimaladd(BigDecimal augend)加法运算
BigDecimalsubtract(BigDecimal subtrahend)减法运算
BigDecimalmultiply(BigDecimal multiplicand)乘法运算
BigDecimaldivide(BigDecimal divisor)除法运算
BigDecimaldivide(BigDecimal divisor, int roundingMode)除法运算
BigDecimaldivide(BiaDecimaldivisor,int scale, int roundinaMode)除法运算
BigDecimalremainder(BigDecimal divisor)求余运算
BigDecimal[]divideAndRemainder(BigDecimal divisor)除并求余运算
BigDecimalmin(BigDecimal val)取最大值运算
BigDecimalmax(BiqDecimal val)取最小值运算

解释:

  • 在调用divide()方法时,使用roundingMode可以设置运算时的舍入模式
  • 使用BigDecimal类中以ROUND为前缀的常量表示
    • 例如: BigDecimal.ROUND_HALF_UP

关于除法运算的roundingMode

常量值说明
ROUND_UP在丢弃非零部分之前始终增加数字(始终对非零舍弃部分前面的数字加1)
ROUND_DOWN在丢弃某部分之前始终不增加数字(从不对舍弃部分前面的数字加1,即截短)
ROUND_CEILING正数时,与ROUND_UP相同,负数时,与ROUND_DOWN相同
ROUND_FLOOR正数时,与ROUND_DOWN相同,负数时,与ROUND_UP相同
ROUND_HALF_UP满足四舍五入时,与ROUND_UP相同,否则,与ROUND_DOWN相同
ROUND_HALF_DOWN满足五舍六入时,与ROUND_UP相同,否则,与ROUND_DOWN相同
ROUND_HALF_EVEN若舍弃部分左侧为奇数,与ROUND_HALE_UP相同,否则,与ROUND_HALE_DOWN相同
ROUND_UNNECESSARY断言请求的操作具有精确的结果,因此不需要舍入

将BigDecimal转换为基本类型

返回值类型方法说明
intintValue()转换为int,可能丢失精度
intintValueExact()转换为int,若丢失精度则抛出ArithmeticException
longlongValue()转换为long,可能丢失精度
longlongValueExact()转换为long,若丢失精度则抛出ArithmeticException
floatfloatValue()转换为float,可能丢失精度
doubledoubleValue()转换为double,可能丢失精度
bytebyteValueExtra()转换为byte,若丢失精度则抛出ArithmeticException
shortshortValueExact ()转换为short,若丢失精度则抛出ArithmeticException

注意:在进行转换之前,应该明确是否会丢失精度,避免转换结果不符合预期!

代码展示

public class BigDecimalDemo {
    public static void main(String[] args) {
        //创建2个基本类型的浮点数
        double d1 = 0.1;
        double d2 = 0.2;
        //计算2个double的和
        System.out.println("两个double求和:");
        System.out.println(d1+d2);//可以发现最后面有误差
        System.out.println();

        //创建BigDecimal
         /**
         * 当原数使用String表示时,使用构造方法创建BIgDecimal对象
         * 当原数使用double表示时,使用静态ValueOf()方法创建BigDecimal对象
         * 当原始使用double表示时,不要使用double作为构造方法来创建BigDecimal
         */
        String s1 = "0.1";
        String s2 = "0.2";
        BigDecimal number1 = new BigDecimal(s1);
        BigDecimal number2 = new BigDecimal(s2);
        //或者
//        BigDecimal number1 = BigDecimal.valueOf(d1);
//        BigDecimal number2 = BigDecimal.valueOf(d2);

        //通过BigDecimal求和
        System.out.println("两个BigDecimal求和:");
        System.out.println(number1.add(number2));
    }
}

小结

  • 使用BigDecimal主要解决基本数据类型运算精度不足的问题
  • 当原数使用String表示时,使用构造方法创建BigDecimal对象;
  • 当原数使用double表示时,使用valueOf()静态方法创建BigDecimal对象;
  • 当需要进行算术运算时,必须使用BigDecimal提供的API;
  • BigDecimal的API几乎包括了你所能想到的所有数值操作:
  • 你可以将Bignteger转换成任何基本数据类型,但可能丢失精度。
    • 在转换之前,应先明确是否可能丢失精度
    • 你不一定需要将结果转换为数值型,使用字符串也可以用于显示或存储

在这里插入图片描述

其他文章

关于java中的BigInteger

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/193170.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

scrollTo() 无效问题处理

需求: 实现访问当前页面直接滚动到最底部 方案:window对象的scrollTo()方法 API介绍: 参数接收一个点(文档坐标),让该点位于左上角。 可选参数为behavior(设置滚动的效果) 错误案例:…

【My Electronic Notes系列——数制与编码】

目录 序言: 🏆🏆人生在世,成功并非易事,他需要破茧而出的决心,他需要永不放弃的信念,他需要水滴石穿的坚持,他需要自强不息的勇气,他需要无畏无惧的凛然。要想成功&…

剑指 Offer II 005单词长度的最大乘积

给定一个字符串数组 words,请计算当两个字符串 words[i] 和 words[j] 不包含相同字符时,它们长度的乘积的最大值。假设字符串中只包含英语的小写字母。如果没有不包含相同字符的一对字符串,返回 0。 示例 1: 输入: words ["abcw"…

前端CSS第二阶段-001

😊博主页面:鱿年年 👉博主推荐专栏:《WEB前端》👈 ​💓博主格言:追风赶月莫停留,平芜尽处是春山❤️ 目录 第二阶段学习目标 一、Emmet语法 1.快速生成HTML结构语法 2.快速生成…

在Runtime下,IL2CPP与Mono打包对应的PSS内存占用问题

1)在Runtime下,IL2CPP与Mono打包对应的PSS内存占用问题 ​2)获得AssetBundle内部依赖关系的方法 3)Unity 2019 Streaming Mipmap在某些情况下采样等级错误 4)根据RenderDoc的数据,计算渲染量 这是第322篇UW…

2024年部分MBA/MEM项目提面日程已经开启,气氛已然开始渐涨了

进入到二月份,一切都将愈发生机盎然!全国范围内的MBA/MEM/MPA项目都有各自的招生节奏和特点,提前批面试作为项目招考的重要方式之一,每年都会从年初开始陆续开放申请,而对于像浙大等名校来说,提前批面试的批…

mysql:数据库调优策略,sql调优

mysql:数据库调优策略。 硬件,系统配置,数据库表结构,sql及索引通过这些方面来优化项目的数据库层面。 越往后成本越低,但是效果确实越好。 第1步:选择适合的 DBMS第2步:优化表设计第3步&#…

【Java】面向对象笔记(下)

static关键字 static 静态 什么是静态 主要意义是在于创建独立于具体对象的域变量或者方法。以致于即使没有创建对象,也能使用属性和调用方法! static关键字还有一个比较关键的作用就是用来形成静态代码块以优化程序性能。static块可以置于类中的任何…

数字授权如何满足工业软件多样化需求?

前言数字化转型的洪流正在不断对工业软件提出新的要求。在包括“智能工厂”、“智能生产”以及“智能物流”在内的主要领域里,工业软件正逐渐向智能化、嵌入式、分布式、互联化的方向演进。传统的软件保护和授权方式并不能适应工业软件新形式的需求。一方面&#xf…

蓝桥杯 stm32 RTC实时时钟

文章代码使用 HAL 库。 文章目录前言一、RTC 重要特性:二、CubeMX 创建工程。三、读取系统日期 函数。四、读取系统时间 函数。四、在 LCD 上显示 时间。总结实验效果前言 RTC (Real Time Clock): 实时时钟。 RTC 模块拥有一个连续计数的 计数器&#…

mysql:有哪些索引,什么时候创建索引,什么时候不创建索引,创建索引的原则有哪些。

最近学习mysql,学习的索引的一些总结。 1.哪些索引 普通索引唯一性索引主键索引单列索引多列(组合、联合)索引全文索引补充:空间索引 小结:不同的存储引擎支持的索引类型也不一样 InnoDB :支持 B树。MyISAM : 支持…

基于JavaWeb的校园故障报修系统

项目描述 临近学期结束,还是毕业设计,你还在做java程序网络编程,期末作业,老师的作业要求觉得大了吗?不知道毕业设计该怎么办?网页功能的数量是否太多?没有合适的类型或系统?等等。这里根据疫情当下,你想解决的问…

Java里面为什么搞了双重检查锁,写完这篇文章终于真相大白了

双重检查锁定与延迟初始化 在 java 程序中,有时候可能需要推迟一些高开销的对象初始化操作,并且只有在使用这些对象时才进行初始化。此时程序员可能会采用延迟初始化。但要正确实现线程安全的延迟初始化需要一些技巧,否则很容易出现问题。比如…

城市POI数据爬取-百度地图版

1 API说明 目前百度地图的最新版为地图检索V2.0服务。详细介绍可以通过开发文档-web服务Api-地点检索V2.0获取。 在使用API前需要提前注册账号获取ak。对于免费账号:目前的每日访问次数是100次,最多可以获取2000条数据。 如不需讲解仅需要下载代码&am…

阿里软件架构师手写JDK源码,看完真的膜拜

最近有不少小伙伴在后台留言,说 Java 的面试越来越难了,尤其是技术面,考察得越来越细,越来越底层。 通过和大厂的面试官聊了一下发现,现在大厂特别爱考底层的一些原理,因为一些底层是不涉及到语言的&#x…

【Linux】进程状态的理解

🤣 爆笑教程 👉 《看表情包学Linux》👈 猛戳订阅 🔥 💭 写在前面:本章我们专门讲解进程的状态。我们先学习具体的 Linux 系统状态,再去介绍 OS 学科面对的概念如何理解 —— 运行态、终止态、阻…

二叉树的基础应用

二叉树 树概念及结构 1.1树的概念 树是一种非线性的数据结构,它是由n(n>0)个有限结点组成一个具有层次关系的集合。把它叫做树是因 为它看起来像一棵倒挂的树,也就是说它是根朝上,而叶朝下的。 有一个特殊的结点…

Seata分布式事务落地解决方案

引言上一篇文章介绍了分布式事务理论和相关解决方案的具体思路,我们下面快速复习一下相关知识点:1.分布式事务问题1.1.本地事务本地事务,也就是传统的单机事务。在传统数据库事务中,必须要满足四个原则:1.2.分布式事务分布式事务&…

Houdini_grass_sim (关于植物结算)

2023-2-2 开年第一篇 (记录下关于植物结算的笔记) 这是我们要算的植物(草) 思路 这个草分2部分 主干和叶子(这里我没考虑取解决穿插) 1.主干提取中心线 —— 2.用线结算器(主干)—…

MongoDB的安装(window系统)

最近因为用到mongodb,所以研究了一下,遇到一些问题,和大家分析一下。介绍:MongoDB 是一个基于分布式文件存储的数据库。由 C 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。MongoDB 是一个介于关系数据库和非关系…