进阶JAVA篇- BigDecimal 类的常用API(四)
目录
API
1.0 BigDecimal 类说明
1.1 为什么浮点数会计算不精确呢?
1.2 如何创建 BigDecimal 类型的对象
1.2.1具体来介绍三种方式来创建:
1.2.2 结合三种创建方法,一起来分析一下。
1.3 BigDecimal 类中的 valueOf(String str) 方法
1.4 BigDecimal 类中的 add() 方法(加减乘除的操作都是一样的,就不多赘述了)
1.5 BigDecimal 类中的 doubleValue() 方法
API
1.0 BigDecimal 类说明
BigDecimal 类是Java中用于精确表示大数的类,可以进行精确的数值运算。在需要精确计算的场景中,可以使用 BigDecimal 类来避免由于浮点数计算误差导致的计算结果不准确的问题。
1.1 为什么浮点数会计算不精确呢?
代码如下:
public class Text {public static void main(String[] args) {double data1 = 0.1;double data2 = 0.2;System.out.println(data1+data2);} }
运行代码如下:
结果不是0.3,显然结果跟我们预想的不一样。当然不是所以的浮点数运行出来的结果都是错误的,只是有这一部分是运行出来的结果是错误的,但是这一部分我们作为合格的程序员来说是不能接收的。
浮点数在计算机中的表示方式是通过将数值分为两部分:尾数和指数。尾数用来表示数值的有效位数,而指数用来表示数值的大小范围。然而,由于计算机内存的限制,尾数和指数都只能用有限的位数来表示,这就导致了浮点数的精度有限。
二进制表示:计算机使用二进制来表示浮点数,而大部分十进制数无法精确转换为二进制表示。例如,0.1(十进制)在二进制表示中是一个无限循环的小数0.00011001100110011...,因此在计算机中只能近似表示。
有限的位数:浮点数的尾数和指数都只能用有限的位数来表示,这就导致了浮点数的精度有限。例如,Java中的double类型只能精确表示15位有效数字,超过这个范围的数字会被截断或四舍五入。
浮点数运算误差:在进行浮点数运算时,由于尾数和指数的有限位数表示,计算机无法精确表示所有的运算结果。这就导致了浮点数运算的结果可能存在一定的误差。
舍入误差:在将一个浮点数转换为二进制表示时,可能会存在舍入误差。例如,一个无限循环的小数在转换为二进制表示时会被截断或四舍五入,从而导致精度损失。
1.2 如何创建 BigDecimal 类型的对象
1.2.1具体来介绍三种方式来创建:
1.代码如下:
import java.math.BigDecimal;public class BigDecimalMethod1 {public static void main(String[] args) {//先定义了两个基本数据类型,我们知道//0.1 + 0.2 在double 类型运行是不精确的double data1 = 0.1;double data2 = 0.2;//由基本数据类型转变为引用类型//利用自动装箱,在等号后面可以直接写基本数据类型,它会自动装箱Double d1 = data1;Double d2 = data2;//将Double类型转变为String类型//利用Double类型实例方法toString()String s1 = d1.toString();String s2 = d2.toString();//利用构造器传进字符串来创建对象,//由字符串类型转变为BigDecimal类型BigDecimal b1 = new BigDecimal(s1);BigDecimal b2 = new BigDecimal(s2);//BigDecimal类中的实例方法 add()方法,//将两个BigDecimal类型相加BigDecimal c = b1.add(b2);//调用BigDecimal的实例方法 doubleValue(),//将BigDecimal类型转变为基本数据类型double a = c.doubleValue();//+1是为了表达a是浮点型,不是字符串System.out.println(a+1);}}
运行结果如下:
2.代码如下:
import java.math.BigDecimal;public class BigDecimalMethod2 {public static void main(String[] args) {//先定义了两个基本数据类型,我们知道//0.1 + 0.2 在double 类型运行是不精确的double data1 = 0.1;double data2 = 0.2;//直接调用Double类中的静态方法toString(),//转变为字符串String s1 = Double.toString(data1);String s2 = Double.toString(data2);//利用有参数的构造器,传入字符串创建对象BigDecimal b1 = new BigDecimal(s1);BigDecimal b2 = new BigDecimal(s2);//BigDecimal类中的实例方法 add()方法,//将两个BigDecimal类型相加BigDecimal c = b1.add(b2);//调用BigDecimal的实例方法 doubleValue(),//将BigDecimal类型转变为基本数据类型double a = c.doubleValue();//+1是为了表达a是浮点型,不是字符串System.out.println(a + 1);}}
运行结果如下:
3.代码如下:
import java.math.BigDecimal;public class BigDecimalMethod3 {public static void main(String[] args) {//先定义了两个基本数据类型,我们知道//0.1 + 0.2 在double 类型运行是不精确的double data1 = 0.1;double data2 = 0.2;//这个就更加直接了,直接用BigDecimal中静态方法,//将浮点数类型转变为BigDecimal类型BigDecimal b1 = BigDecimal.valueOf(data1);BigDecimal b2 = BigDecimal.valueOf(data2);//BigDecimal类中的实例方法 add()方法,//将两个BigDecimal类型相加BigDecimal c = b1.add(b2);//将BigDecimal类型转变为浮点数类型double a = c.doubleValue();//+1是为了表达a是浮点型,不是字符串System.out.println(a+1);} }
运行代码如下:
1.2.2 结合三种创建方法,一起来分析一下。
第一种方式与第二种方式都是通过浮点型转变为字符串,然后再通过构造器转入字符串来创建BigDecimal 类型的对象,二者的区别在于有无创建Double对象,第一种是通过创建对象得到实例方法 toString() 将浮点型转变为字符串,而第二种没有创建Double对象,直接用Double类的静态方法 toString() 将浮点型转变为字符串。这两种方式的历程是由 浮点数 - 字符串 - BigDecimal类型。
第三种是直接调用BigDecimal 类中的静态方法来创建对象,历程是 浮点数 - BigDecimal类型。事实上,第三种是第二种的封装。即JAVA中为了方便,为了效率,将第二种的长串的代码“封装”成第三种方法。
1.3 BigDecimal 类中的 valueOf(String str) 方法
通过传进字符串来创建方法,由于上面有详细讲到,就不多赘述了。
1.4 BigDecimal 类中的 add() 方法(加减乘除的操作都是一样的,就不多赘述了)
两个BigDecimal 类型的对象进行相加,得到总和。
代码如下:
import java.math.BigDecimal;public class Text {public static void main(String[] args) {double data1 = 0.1;double data2 = 0.2;BigDecimal b1 = BigDecimal.valueOf(data1);BigDecimal b2 = BigDecimal.valueOf(data2);BigDecimal c = b1.add(b2);System.out.println(c);} }
运行结果:
其他运算的方法:
减法 subtract(),乘法 multiply(),除法 divide()
其中 divide()还可以指定小数点后的几位数。
代码如下:
import java.math.BigDecimal;public class Text {public static void main(String[] args) {double data1 = 0.1;double data2 = 0.3;BigDecimal b1 = BigDecimal.valueOf(data1);BigDecimal b2 = BigDecimal.valueOf(data2);BigDecimal c = b1.divide (b2,5);System.out.println(c);} }
运行结果:
假如0.1/0.3 不去指定位数的时候,会报错。
import java.math.BigDecimal;public class Text {public static void main(String[] args) {double data1 = 0.1;double data2 = 0.3;BigDecimal b1 = BigDecimal.valueOf(data1);BigDecimal b2 = BigDecimal.valueOf(data2);BigDecimal c = b1.divide (b2);System.out.println(c);} }
运行结果:
1.5 BigDecimal 类中的 doubleValue() 方法
将 BigDecimal 类型转变为 double 类型。
代码如下:
import java.math.BigDecimal;public class Text {public static void main(String[] args) {double data1 = 0.1;double data2 = 0.3;BigDecimal b1 = BigDecimal.valueOf(data1);BigDecimal b2 = BigDecimal.valueOf(data2);BigDecimal c = b1.add (b2);double a = c.doubleValue();System.out.println(a);} }
运行结果如下:
相关文章:

进阶JAVA篇- BigDecimal 类的常用API(四)
目录 API 1.0 BigDecimal 类说明 1.1 为什么浮点数会计算不精确呢? 1.2 如何创建 BigDecimal 类型的对象 1.2.1具体来介绍三种方式来创建: 1.2.2 结合三种创建方法,一起来分析一下。 1.3 BigDecimal 类中的 valueOf(Strin…...

UE4 顶点网格动画播放后渲染模糊问题
问题描述:ABC格式的顶点网格动画播放结束后,改模型看起来显得很模糊有抖动的样子 解决办法:关闭逐骨骼动态模糊...

centos 磁盘挂载与解挂
磁盘挂载 查看已挂载的磁盘 df -TH查看磁盘分区,对比第一步,看哪些磁盘没有挂载,例如发现/dev/sdb的磁盘没有在第一步中显示 fdisk -l磁盘分区(/dev/sdb为上一步骤中没有挂载的磁盘) fdisk /dev/sdb执行上一命令后…...

C语言 位操作
定义 位操作提高程序运行效率,减少除法和取模的运算。在计算机程序中,数据的位是可以操作的最小数据单位,理论上可以用“位运算”来完成所有的运算和操作。 左移 后空缺自动补0 右移 分为逻辑右移和算数右移 逻辑右移 不管什么类型&am…...

Go语言中入门Hello World以及IDE介绍
您可以阅读Golang教程第1部分:Go语言介绍与安装 来了解什么是golang以及如何安装golang。 Go语言已经安装好了,当你开始学习Go语言时,编写一个"Hello, World!"程序是一个很好的入门点。 下面将会提供了一些有关IDE和在线编辑器的…...

Java面试题-Java核心基础-第二天(基本语法)
目录 一、注释有几种形式 二、标识符与关键字的区别 三、自增自减运算符 四、移位运算符 五、continue、break、return的区别 一、注释有几种形式 注释除了有其他编程语言有的单行注释和多行注释之外,还有其Java特有的文档注释 文档注释能够使用javadoc命令就…...

Linux 部署 GitLab idea 连接
概述 GitLab 是一个开源的代码管理平台,使用 Git 作为版本控制工具,提供了 Web 界面和多种功能,如 wiki、issue 跟踪、CI/CD 等。 GitLab 可以自托管或使用 SaaS 服务,支持多种操作系统和执行器。 GitLab 可以帮助软件开发团队…...

Java延迟队列——DelayQueue
Java延迟队列——DelayQueue DelayQueue的定义 public class DelayQueue<E extends Delayed> extends AbstractQueue<E> implements BlockingQueue<E>DelayQueue是一个无界的BlockingQueue,是线程安全的(无界指的是队列的元素数量不存…...

Vulnhub系列靶机---Raven2
文章目录 Raven2 渗透测试信息收集提权UDF脚本MySQL提权SUID提权 Raven2 渗透测试 信息收集 查看存活主机 arp-scan -l 找到目标主机。 扫描目标主机上的端口、状态、服务类型、版本信息 nmap -A 192.168.160.47目标开放了 22、80、111 端口 访问一下80端口,并…...

设计模式-生成器模式
生成器模式(Builder Pattern)是一种创建型设计模式,用于构建复杂的对象。这种模式将构造代码和表示代码分离开来,使得同样的构造过程可以创建不同的表示。 以下是一个简单的Java实现: // 产品 class Product …...

Nginx正向代理配置(http)
前言 在工作中我们经常使用nginx进行反向代理,今天介绍下怎么进行正向代理,支持http请求,暂不支持https 首先先介绍下正向代理和反向代理。 正向代理 在客户端(浏览器)配置代理服务器,通过代理服务器进行互联网访问。 反向代理 客户端只…...

ARMv5架构对齐访问异常问题
strh非对齐访问 在ARMv5架构中,对于strh指令(Store Halfword),通常是要求对地址进行对齐访问的。ARMv5架构对于半字(Halfword)的存储操作有对齐要求,即地址必须是2的倍数。 如果尝试使用strh指…...

Go中varint压缩编码原理分析
文章目录 编码介绍无符号整数较小的值较大的值Go中的实现编码PutUvarint解码Uvarint 有符号整数较小的值(指绝对值)较大的负数(只绝对值)Go中的实现编码PutVarint解码Varint 总结 编码介绍 varint是一种将整数编码为变长字节的压缩编码算法,本篇文章就是分析该编码…...

在IDEA中如何用可视化界面操作数据库? 在idea中如何操作数据库? 在idea中如何像Navicat一样操作数据库?
1、找到database,创建连接 我用了中文包,英文状态下和我的操作完全一样 英文下第二列数据库名称为 database 2、配置相关属性,如IP地址,密码等 3、选择对应的库名,此处也叫架构 4、然后就可以进行愉快的操作了...

数据库安全-RedisHadoopMysql未授权访问RCE
目录 数据库安全-&Redis&Hadoop&Mysql&未授权访问&RCE定义漏洞复现Mysql-CVE-2012-2122 漏洞Hadoop-配置不当未授权三重奏&RCE 漏洞 Redis-未授权访问-Webshell&任务&密匙&RCE 等漏洞定义:漏洞成因漏洞危害漏洞复现Redis-未授权…...

辅助驾驶功能开发-功能规范篇(27)-3-导航式巡航辅助NCA华为
书接上回 2.2.2.3.7控制模块 控制模块由横向控制和纵向控制组成。根据横、纵向规划给出的行驶轨迹和给定速度,进行车辆的纵横向控制,输出方向盘转角、加速度或制动踏板开度和档位信息,必要条件下输出车灯信号等。 2.2.2.4 行为仲裁模块 纵向状态: 当纵向位于Off/Standby…...

探索UI设计|栅格系统的深入分析和应用
界面排版太乱了。你知道网格系统的用途吗?网格系统困扰着许多初级网页设计师,就像一个谜。如果您对网格在设计中的应用有任何疑问,本文是为您量身定制的,并深入分析UI设计中网格系统的基本要素和优点。 什么是网格系统 网格系统…...

AI 律助 Alpha GPT 线上实操发布会,重磅发布!
数字化时代,随着人工智能的迅猛发展,各行各业都在积极探索通过智能化工具实现工作效率翻升的可能性。“ ChatGPT 类产品”是未来办公应用软件发展的重要趋势之一,但如何将 ChatGPT 真正应用于法律人的工作,赋能效率提升?法律行业同样面临着新的挑战和机遇。 破局的关键是实现技…...

【漏洞复现】安全云平台存在任意文件下载getshell
漏洞描述 深圳市强鸿电子有限公司鸿运主动安全云平台存在任意文件下载漏洞,攻击者可通过此漏洞下载敏感文件信息。 免责声明 技术文章仅供参考,任何个人和组织使用网络应当遵守宪法法律,遵守公共秩序,尊重社会公德,不得利用网络从事危害国家安全、荣誉和利益,未经授权…...

【JUC】原子操作类及LongAddr源码分析
文章目录 1. 十八罗汉2. 原子类再分类2.1 基本类型原子类2.2 数组类型原子类2.3 引用类型原子类2.4 对象的属性修改原子类2.5 原子操作增强类 3. 代码演示及性能比较:4. LongAddr原理5. LongAddr源码分析5.1 add()5.2 longAccumulate()5.3 sum() 6. 小总结6.1 Atomi…...

203、RabbitMQ 之 使用 direct 类型的 Exchange 实现 消息路由 (RoutingKey)
目录 ★ 使用direct实现消息路由代码演示这个情况二ConstantUtil 常量工具类ConnectionUtil 连接RabbitMQ的工具类Publisher 消息生产者测试消息生产者 Consumer01 消息消费者01测试消费者结果: Consumer02 消息消费者02测试消费者结果: 完整代码&#x…...

微服务+Java+Spring Cloud +UniApp +MySql智慧工地综合管理云平台源码,SaaS模式
智慧工地围绕工程现场人、机、料、法、环及施工过程中质量、安全、进度、成本等各项数据满足工地多角色、多视角的有效监管,实现工程建设管理的降本增效. 智慧工地综合管理云平台源码,PC监管端、项目端;APP监管端、项目端、数据可视化大屏端源码…...

QMidi Pro for Mac:打造您的专属卡拉OK体验
你是否曾经厌倦于在KTV里与朋友们争夺麦克风?是否想要在家中享受自定义的卡拉OK体验?现在,有了QMidi Pro for Mac,一切变得简单而愉快! QMidi Pro是一款功能强大的卡拉OK播放器,专为Mac用户设计。它充分利…...

bindtap和catchtap的区别?
bindtap和catchtap都是小程序中用于绑定点击事件的方法。 1.bindtap的作用是绑定一个触摸事件并指定对应的处理函数。当用户点击或触摸相关元素时,会触发该事件,并执行相应的处理逻辑。 示例: <button bindtap"handleTap">…...

IDEA—java: 常量字符串过长问题解决
问题描述: Error: java: 常量字符串过长 问题分析: 字符串长度过长,导致 idea 默认使用的 javac 编译器编译不了。 解决办法: Javac 编译器改为 Eclipse 编译器。 File -> Settings -> Build,Execution,Deployment -&…...

云原生SIEM解决方案
云原生(Cloud Native)是一种基于云计算的软件开发和部署方法论,它强调将应用程序和服务设计为云环境下的原生应用,以实现高可用性、可扩展性和灵活性。 云原生的优势有哪些 高可用性:云原生可以实现应用程序的高可用…...

工艺边与定位孔设计经验规则总结
🏡《总目录》 目录 1,什么是工艺边和定位孔2,工艺边的设计经验原则2.1,避免尖锐角2.2,工艺边宽度设置2.3,工艺边的方向2.4,定位孔尺寸2.5,定位孔的位置3,去除工艺边的方法注意事项4,总结1,什么是工艺边和定位孔 工艺边是在SMT焊接时,为了PCB和导轨接触预留的PCB边…...

软件架构设计(业务架构、应用架构、数据架构、技术架构)
一、架构相关概念 1、系统 系统:由一群有关联的个体组成,根据某种规则运作,能完成个别原件不能独立完成的工作的群体。大的系统可以嵌套小系统,被嵌套的小系统往往称为大系统的子系统。 2、模块 模块是从逻辑上将系统分解&#…...

我们又组织了一次欧洲最大开源社区活动,Hugging Face 博客欢迎社区成员发帖、Hugging Chat 功能更新!...
每一周,我们的同事都会向社区的成员们发布一些关于 Hugging Face 相关的更新,包括我们的产品和平台更新、社区活动、学习资源和内容更新、开源库和模型更新等,我们将其称之为「Hugging News」。本期 Hugging News 有哪些有趣的消息࿰…...

学信息系统项目管理师第4版系列26_项目绩效域(下)
1. 项目工作绩效域 1.1. 涉及项目工作相关的活动和职能 1.2. 预期目标 1.2.1. 高效且有效的项目绩效 1.2.2. 适合项目和环境的项目过程 1.2.3. 干系人适当的沟通和参与 1.2.4. 对实物资源进行了有效管理 1.2.5. 对采购进行了有效管理 1.2.6. 有效处理了变更 1.2.7. 通…...