史上最全BigDecimal的5种进位方式:ROUND_UP,ROUND_DOWN,ROUND_CEILING,ROUND_FLOOR,ROUND_HALF_UP,ROUND_HALF_DOWN的比较

2024-09-03 04:58

本文主要是介绍史上最全BigDecimal的5种进位方式:ROUND_UP,ROUND_DOWN,ROUND_CEILING,ROUND_FLOOR,ROUND_HALF_UP,ROUND_HALF_DOWN的比较,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

先上JAVA官方文档

    /*** Rounding mode to round away from zero.  Always increments the* digit prior to a nonzero discarded fraction.  Note that this rounding* mode never decreases the magnitude of the calculated value.*/public final static int ROUND_UP =           0;/*** Rounding mode to round towards zero.  Never increments the digit* prior to a discarded fraction (i.e., truncates).  Note that this* rounding mode never increases the magnitude of the calculated value.*/public final static int ROUND_DOWN =         1;/*** Rounding mode to round towards positive infinity.  If the* {@code BigDecimal} is positive, behaves as for* {@code ROUND_UP}; if negative, behaves as for* {@code ROUND_DOWN}.  Note that this rounding mode never* decreases the calculated value.*/public final static int ROUND_CEILING =      2;/*** Rounding mode to round towards negative infinity.  If the* {@code BigDecimal} is positive, behave as for* {@code ROUND_DOWN}; if negative, behave as for* {@code ROUND_UP}.  Note that this rounding mode never* increases the calculated value.*/public final static int ROUND_FLOOR =        3;/*** Rounding mode to round towards {@literal "nearest neighbor"}* unless both neighbors are equidistant, in which case round up.* Behaves as for {@code ROUND_UP} if the discarded fraction is* ≥ 0.5; otherwise, behaves as for {@code ROUND_DOWN}.  Note* that this is the rounding mode that most of us were taught in* grade school.*/public final static int ROUND_HALF_UP =      4;/*** Rounding mode to round towards {@literal "nearest neighbor"}* unless both neighbors are equidistant, in which case round* down.  Behaves as for {@code ROUND_UP} if the discarded* fraction is {@literal >} 0.5; otherwise, behaves as for* {@code ROUND_DOWN}.*/public final static int ROUND_HALF_DOWN =    5;

看不懂别急,看翻译版本

/***舍入模式,从零开始舍入。总是增加*非零舍弃分数之前的数字。请注意,此舍入*模式从不降低计算值的大小。*/public final static int ROUND_UP =           0;/***舍入模式,向零舍入。从不递增数字*在丢弃的分数之前(即截断)。请注意*舍入模式从不增加计算值的大小。*/public final static int ROUND_DOWN =         1;/***舍入模式,向正无穷大舍入。如果*{@code BigDecimal}为正,行为与*{@code ROUND\u};如果为负,则行为与*{@code ROUND\u DOWN}。请注意,此舍入模式从不*减小计算值。*/public final static int ROUND_CEILING =      2;/***舍入模式,向负无穷大方向舍入。如果*{@code BigDecimal}为正,行为与*{@code ROUND\u DOWN};如果为负,则按*{@code ROUND\u}。请注意,此舍入模式从不*增加计算值。*/public final static int ROUND_FLOOR =        3;/***舍入模式向{@literal“nearest neighbor”舍入*除非两个邻居都是等距的,在这种情况下,就把他们围起来。*如果丢弃的分数是*≥0.5;否则,行为与{@code ROUND\u DOWN}相同。注意*这就是我们大多数人所学的四舍五入模式*小学。*/public final static int ROUND_HALF_UP =      4;/***舍入模式向{@literal“nearest neighbor”舍入*除非两个邻居是等距的,在这种情况下是圆的*趴下。如果丢弃*分数为{@literal>}0.5;否则,其行为与*{@code ROUND\u DOWN}。*/public final static int ROUND_HALF_DOWN =    5;

看到这里,除了最后两个翻译的,不懂之外,其他的,应该都清楚了,

这里解释一下最后两个的差别:

ROUND_HALF_UP: 遇到.5的情况时往上近似,例: 1.5 ->;2
ROUND_HALF_DOWN : 遇到.5的情况时往下近似,例: 1.5 ->;1

仅此而已

 

收工

 

 

这篇关于史上最全BigDecimal的5种进位方式:ROUND_UP,ROUND_DOWN,ROUND_CEILING,ROUND_FLOOR,ROUND_HALF_UP,ROUND_HALF_DOWN的比较的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1132092

相关文章

Mybatis官方生成器的使用方式

《Mybatis官方生成器的使用方式》本文详细介绍了MyBatisGenerator(MBG)的使用方法,通过实际代码示例展示了如何配置Maven插件来自动化生成MyBatis项目所需的实体类、Map... 目录1. MyBATis Generator 简介2. MyBatis Generator 的功能3

Python数据处理之导入导出Excel数据方式

《Python数据处理之导入导出Excel数据方式》Python是Excel数据处理的绝佳工具,通过Pandas和Openpyxl等库可以实现数据的导入、导出和自动化处理,从基础的数据读取和清洗到复杂... 目录python导入导出Excel数据开启数据之旅:为什么Python是Excel数据处理的最佳拍档

SpringBoot项目启动后自动加载系统配置的多种实现方式

《SpringBoot项目启动后自动加载系统配置的多种实现方式》:本文主要介绍SpringBoot项目启动后自动加载系统配置的多种实现方式,并通过代码示例讲解的非常详细,对大家的学习或工作有一定的... 目录1. 使用 CommandLineRunner实现方式:2. 使用 ApplicationRunne

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

MYSQL行列转置方式

《MYSQL行列转置方式》本文介绍了如何使用MySQL和Navicat进行列转行操作,首先,创建了一个名为`grade`的表,并插入多条数据,然后,通过修改查询SQL语句,使用`CASE`和`IF`函... 目录mysql行列转置开始列转行之前的准备下面开始步入正题总结MYSQL行列转置环境准备:mysq

Linux(Centos7)安装Mysql/Redis/MinIO方式

《Linux(Centos7)安装Mysql/Redis/MinIO方式》文章总结:介绍了如何安装MySQL和Redis,以及如何配置它们为开机自启,还详细讲解了如何安装MinIO,包括配置Syste... 目录安装mysql安装Redis安装MinIO总结安装Mysql安装Redis搜索Red

Java文件上传的多种实现方式

《Java文件上传的多种实现方式》文章主要介绍了文件上传接收接口的使用方法,包括获取文件信息、创建文件夹、保存文件到本地的两种方法,以及如何使用Postman进行接口调用... 目录Java文件上传的多方式1.文件上传接收文件接口2.接口主要内容部分3.postman接口调用总结Java文件上传的多方式1

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如

多模块的springboot项目发布指定模块的脚本方式

《多模块的springboot项目发布指定模块的脚本方式》该文章主要介绍了如何在多模块的SpringBoot项目中发布指定模块的脚本,作者原先的脚本会清理并编译所有模块,导致发布时间过长,通过简化脚本... 目录多模块的springboot项目发布指定模块的脚本1、不计成本地全部发布2、指定模块发布总结多模

MySQL中my.ini文件的基础配置和优化配置方式

《MySQL中my.ini文件的基础配置和优化配置方式》文章讨论了数据库异步同步的优化思路,包括三个主要方面:幂等性、时序和延迟,作者还分享了MySQL配置文件的优化经验,并鼓励读者提供支持... 目录mysql my.ini文件的配置和优化配置优化思路MySQL配置文件优化总结MySQL my.ini文件