当前位置: 首页 > news >正文

Java8: BigDecimal

 Java8:BigDecimal 转两位小数的百分数-CSDN博客

BigDecimal 先做除法 然后取绝对值

在Java 8中,如果你想要对一个BigDecimal值进行除法操作,并随后取其绝对值,你可以通过组合divide方法和abs方法来实现这一目的。不过,需要注意的是,divide方法可能会抛出ArithmeticException,如果除法的结果无法精确表示(比如,尝试除以0,或者结果的小数点后的位数超过了scale参数指定的位数,且没有指定舍入模式)。

以下是一个简单的示例,展示了如何对两个BigDecimal值进行除法操作,并取其结果的绝对值:

import java.math.BigDecimal;  
import java.math.RoundingMode;  public class BigDecimalExample {  public static void main(String[] args) {  // 假设这是你的两个BigDecimal值  BigDecimal dividend = new BigDecimal("10.0");  BigDecimal divisor = new BigDecimal("3.0");  try {  // 执行除法操作,并设置舍入模式和scale  // 这里使用RoundingMode.HALF_UP(四舍五入)和scale为2(保留两位小数)  BigDecimal result = dividend.divide(divisor, 2, RoundingMode.HALF_UP);  // 取绝对值  BigDecimal absoluteResult = result.abs();  // 输出结果  System.out.println("原始结果: " + result);  System.out.println("绝对值结果: " + absoluteResult);  } catch (ArithmeticException e) {  // 处理可能出现的除数为0或其他算术异常  System.err.println("发生算术异常: " + e.getMessage());  }  }  
}

在这个例子中,我们首先通过divide方法对两个BigDecimal值进行除法操作,并指定了结果需要保留的小数位数(scale)和舍入模式(RoundingMode)。之后,我们使用abs方法获取了除法结果的绝对值。

请注意,根据你的具体需求,你可能需要调整scaleRoundingMode的值。scale参数定义了结果中小数点后的位数,而RoundingMode则定义了当结果无法精确表示时如何进行舍入。Java提供了多种舍入模式,如RoundingMode.HALF_UP(四舍五入)、RoundingMode.DOWN(向下舍入)、RoundingMode.UP(向上舍入)等。

BigDecimal 仅保留有效小数位

在Java中,BigDecimal 类提供了处理精确小数的功能,但直接保留“有效小数位”可能需要根据你的具体定义来操作,因为“有效小数位”这个概念不像四舍五入到固定小数位数那样直接。不过,我们可以通过一些方法来近似实现这一目标。

如果你的目标是去除末尾不必要的零(即保留有效数字),同时保证不超过某个小数位数(如果需要的话),你可以结合使用 stripTrailingZeros() 方法和 setScale() 方法(但后者在这里主要用于控制最大小数位数,如果不关心最大小数位数,则可以省略)。

以下是一个示例,展示了如何仅保留BigDecimal的有效小数位(并可选地限制最大小数位数):

import java.math.BigDecimal;  
import java.math.RoundingMode;  public class BigDecimalExample {  public static void main(String[] args) {  // 示例BigDecimal值  BigDecimal number = new BigDecimal("123.4500");  // 仅保留有效小数位(去除末尾的0)  BigDecimal effectiveNumber = number.stripTrailingZeros();  // 如果需要限制最大小数位数,可以额外使用setScale方法  // 假设我们限制最大小数位数为2(这里实际上不需要,因为已经没有多余的0了)  // 注意:setScale可能会引入四舍五入,这里使用RoundingMode.DOWN避免不必要的四舍五入  BigDecimal effectiveNumberWithScale = effectiveNumber.setScale(2, RoundingMode.DOWN);  // 输出结果  System.out.println("原始值: " + number);  System.out.println("去除末尾0后的值: " + effectiveNumber);  System.out.println("限制最大小数位数后的值(如果需要): " + effectiveNumberWithScale);  // 对于更复杂的情况,比如小数部分很短但需要保留至少一位小数  BigDecimal shortDecimal = new BigDecimal("123.0");  BigDecimal shortDecimalEffective = shortDecimal.setScale(1, RoundingMode.HALF_UP); // 四舍五入到1位小数  System.out.println("短小数部分的值,保留1位小数: " + shortDecimalEffective);  }  
}

请注意,stripTrailingZeros() 方法会去除小数部分末尾的零,但不会改变整数值。如果你想要对整数部分也进行某种形式的“压缩”(比如去除不必要的零,尽管整数部分通常不这样处理),那么你可能需要自定义逻辑来处理这种情况,因为BigDecimal没有直接提供这样的方法。

此外,如果你想要确保结果总是至少有一位小数(即使它是零),你应该使用 setScale() 方法并指定最小的小数位数为1,同时根据需要选择合适的舍入模式。在上面的示例中,shortDecimalEffective 展示了如何对短小数部分的值进行四舍五入到1位小数。

 

--end--

http://www.lryc.cn/news/409780.html

相关文章:

  • 苹果推送iOS 18.1带来Apple Intelligence预览
  • testRigor-基于人工智能驱动的无代码自动化测试平台
  • hadoop学习(一)
  • Linux性能监控:sar的可视化方案
  • 如何录制电脑屏幕视频,5招让您成为电脑录制高手
  • AI届的新宠:小语言模型(SLM)?
  • PMP模拟题错题本
  • Laravel Dusk:点亮自动化测试的明灯
  • Git、Gitlab以及分支管理
  • TCP/IP 协议栈介绍
  • 香橙派orangepi系统没有apt,也没有apt-get,也没有yum命令,找不到apt、apt-get、yum的Linux系统
  • 在invidia jetpack4.5.1上运行c++版yolov8(tensorRT)
  • Vue3 接入 i18n 实现国际化多语言
  • 深度学习环境坑。
  • LLM——10个大型语言模型(LLM)常见面试题以及答案解析
  • MongoDB - 聚合阶段 $count、$skip、$project
  • 如何获取文件缩略图(C#和C++实现)
  • create-vue项目的README中文版
  • Centos 7系统(最小化安装)安装Git 、git-man帮助、补全git命令-详细文章
  • Golang零基础入门课_20240726 课程笔记
  • 杂记-镜像
  • 如何将WordPress文章中的外链图片批量导入到本地
  • primetime如何合并不同modes的libs到一个lib文件
  • 【运维笔记】数据库无法启动,数据库炸后备份恢复数据
  • 成功解决:java.security.InvalidKeyException: Illegal key size
  • 微服务事务管理(分布式事务问题 理论基础 初识Seata XA模式 AT模式 )
  • 测试面试宝典(三十五)—— fiddler的工作原理
  • 旷野之间32 - OpenAI 拉开了人工智能竞赛的序幕,而Meta 将会赢得胜利
  • 机械学习—零基础学习日志(高数15——函数极限性质)
  • 树 形 DP (dnf序)