setscale方法的用法_基于BigDecimal.setScale的用法小结

setscale方法的用法_基于BigDecimal.setScale的用法小结1.BigDecimalnum1=newBigDecimal(2.225667);//这种写法不允许,会造成精度损失2.BigDecimalnum2=newBigDecimal(2);//这种写法是可以的3.BigDecimalnum=newBigDecimal(“2.225667”);//一般都会这样写最好4.intcount=num.scale();Sys…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

1. BigDecimal num1 = new BigDecimal(2.225667);//这种写法不允许,会造成精度损失

2. BigDecimal num2 = new BigDecimal(2);//这种写法是可以的

3. BigDecimal num = new BigDecimal(“2.225667”);//一般都会这样写最好

4. int count = num.scale();

System.out.println(count);//6 返回的是小数点后位数

好了,下面开始正式介绍知识点啦~~~~~~

1. ROUND_DOWN

BigDecimal b = new BigDecimal(“2.225667”).setScale(2, BigDecimal.ROUND_DOWN);

System.out.println(b);//2.22 直接去掉多余的位数

2. ROUND_UP

BigDecimal c = new BigDecimal(“2.224667”).setScale(2, BigDecimal.ROUND_UP);

System.out.println(c);//2.23 跟上面相反,进位处理

3. ROUND_CEILING

天花板(向上),正数进位向上,负数舍位向上

BigDecimal f = new BigDecimal(“2.224667”).setScale(2, BigDecimal.ROUND_CEILING);

System.out.println(f);//2.23 如果是正数,相当于BigDecimal.ROUND_UP

BigDecimal g = new BigDecimal(“-2.225667”).setScale(2, BigDecimal.ROUND_CEILING);

System.out.println(g);//-2.22 如果是负数,相当于BigDecimal.ROUND_DOWN

4. ROUND_FLOOR

地板(向下),正数舍位向下,负数进位向下

BigDecimal h = new BigDecimal(“2.225667”).setScale(2, BigDecimal.ROUND_FLOOR);

System.out.println(h);//2.22 如果是正数,相当于BigDecimal.ROUND_DOWN

BigDecimal i = new BigDecimal(“-2.224667”).setScale(2, BigDecimal.ROUND_FLOOR);

System.out.println(i);//-2.23 如果是负数,相当于BigDecimal.ROUND_HALF_UP

5. ROUND_HALF_UP

BigDecimal d = new BigDecimal(“2.225”).setScale(2, BigDecimal.ROUND_HALF_UP);

System.out.println(“ROUND_HALF_UP”+d); //2.23 四舍五入(若舍弃部分>=.5,就进位)

6. ROUND_HALF_DOWN

BigDecimal e = new BigDecimal(“2.225”).setScale(2, BigDecimal.ROUND_HALF_DOWN);

System.out.println(“ROUND_HALF_DOWN”+e);//2.22 四舍五入(若舍弃部分>.5,就进位)

7. ROUND_HALF_EVEN

BigDecimal j = new BigDecimal(“2.225”).setScale(2, BigDecimal.ROUND_HALF_EVEN);

System.out.println(j);//2.22 如果舍弃部分左边的数字为偶数,则作 ROUND_HALF_DOWN

BigDecimal k = new BigDecimal(“2.215”).setScale(2, BigDecimal.ROUND_HALF_EVEN);

System.out.println(k);//2.22 如果舍弃部分左边的数字为奇数,则作 ROUND_HALF_UP

System.out.println(“************************************”);

System.out.println(“4.05: “+new BigDecimal(“4.05”).setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.05: 4.0 down

System.out.println(“4.15: “+new BigDecimal(“4.15”).setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.15: 4.2 up

System.out.println(“4.25: “+new BigDecimal(“4.25”).setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.25: 4.2 down

System.out.println(“4.35: “+new BigDecimal(“4.35”).setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.35: 4.4 up

System.out.println(“4.45: “+new BigDecimal(“4.45”).setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.45: 4.4 down

System.out.println(“4.55: “+new BigDecimal(“4.55”).setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.55: 4.6 up

System.out.println(“4.65: “+new BigDecimal(“4.65”).setScale(1, BigDecimal.ROUND_HALF_EVEN));//4.65: 4.6 down

System.out.println(“3.05: “+new BigDecimal(“3.05”).setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.05: 3.0 down

System.out.println(“3.15: “+new BigDecimal(“3.15”).setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.15: 3.2 up

System.out.println(“3.25: “+new BigDecimal(“3.25”).setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.25: 3.2 down

System.out.println(“3.35: “+new BigDecimal(“3.35”).setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.35: 3.4 up

System.out.println(“3.45: “+new BigDecimal(“3.45”).setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.45: 3.4 down

System.out.println(“3.55: “+new BigDecimal(“3.55”).setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.55: 3.6 up

System.out.println(“3.65: “+new BigDecimal(“3.65”).setScale(1, BigDecimal.ROUND_HALF_EVEN));//3.65: 3.6 down

8.ROUND_UNNECESSARY

BigDecimal l = new BigDecimal(“2.215”).setScale(3, BigDecimal.ROUND_UNNECESSARY);

System.out.println(l);

//断言请求的操作具有精确的结果,因此不需要舍入。

//如果对获得精确结果的操作指定此舍入模式,则抛出ArithmeticException。

补充知识:BigDecimal中divide方法注意问题

BigDecimal中divide方法抛异常:

Non-terminating decimal expansion; no exact representable decimal result

在使用

BigDecimal rate = new BigDecimal(1).divide(new BigDecimal(3));

时抛异常:

Non-terminating decimal expansion; no exact representable decimal result

原来是在做除法的时候出现了无限不循环小数如:0.333333333333

解决方案

在做做除法的时候指定保留的小数的位数:

BigDecimal rate = new BigDecimal(1).divide(new BigDecimal(3), 6, BigDecimal.ROUND_HALF_UP);

以上这篇基于BigDecimal.setScale的用法小结就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/179842.html原文链接:https://javaforall.net

(0)
上一篇 2022年10月20日 下午5:00
下一篇 2022年10月20日 下午5:00


相关推荐

  • 在 Windows10 系统下安装 Ubuntu22.04 系统

    在 Windows10 系统下安装 Ubuntu22.04 系统在Windows10系统下安装Ubuntu22.04系统

    2022年10月9日
    4
  • 智能优化算法:灰狼优化算法-附代码

    智能优化算法:灰狼优化算法-附代码智能算法:灰狼优化算法-附代码摘要:受灰狼群体捕食行为的启发,Mirjalili等[1]于2014年提出了一种新型群体智能优化算法:灰狼优化算法。GWO通过模拟灰狼群体捕食行为,基于狼群群体协作的机制来达到优化的目的。GWO算法具有结构简单、需要调节的参数少,容易实现等特点,其中存在能够自适应调整的收敛因子以及信息反馈机制,能够在局部寻优与全局搜索之间实现平衡,因此在对问题的求解精度和收敛速度方面都有良好的性能。1.算法原理灰狼属于犬科动物,被认为是顶级的掠食者,它们处于生物

    2022年5月24日
    33
  • 熔断机制什么意思_什么是熔断机制 熔断机制是什么意思

    熔断机制什么意思_什么是熔断机制 熔断机制是什么意思熔断机制正式实施的首个交易日 A 股遭遇重挫 沪深 300 指数午后开盘接连跌破 5 和 7 两次触发熔断机制 A 股史上首次提前收市 那么 到底什么是熔断机制呢 小编告诉您 熔断机制是指对某一合约在达到涨跌停板之前 设置一个熔断价格 使合约买卖报价在一段时间内只能在这一价格范围内交易的机制 这一机制在全球金融市场最早起源于美国的股票交易保护机制 即在交易过程中 当价格波动幅度达到某一限定目标时 交易将暂停

    2026年3月19日
    2
  • 使用LoadRunner进行并发测试、压力测试和负载测试

    使用LoadRunner进行并发测试、压力测试和负载测试版本为LoadRunner12.551.前期准备工作1.1录制脚本并实现参数化和参数关联1.2插入集合点函数lr_rendezvous(“**”);目的是为了让虚拟用户在这个集合点同时向服务器发送请求以实现并发测试2.开始测试2.1压力测试、负载测试和并发测试的区别分析压力测试:系统达到一定饱和度时,系统处理业务的能力负载测试:找到系统最大的负载能力(通过给系统不断的施压达到饱和状态不能加压为止)…

    2022年7月18日
    27
  • HttpURLConnection的方法setRequestProperty(参数)的参数解读和用法[通俗易懂]

    HttpURLConnection的方法setRequestProperty(参数)的参数解读和用法[通俗易懂]https://blog.csdn.net/zcf520android/article/details/51314959学到东西

    2025年9月4日
    9
  • OpenClaw 保姆级超详细教程:小白也能轻松上手的 AI 智能体

    OpenClaw 保姆级超详细教程:小白也能轻松上手的 AI 智能体

    2026年3月15日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号