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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 协程高并发 – asyncio异步

    协程高并发 – asyncio异步aoao 快的协程

    2025年7月2日
    3
  • Observability:运用 Fleet 来轻松地导入 Nginx 日志及指标

    Observability:运用 Fleet 来轻松地导入 Nginx 日志及指标在我之前的文章: Observability:使用ElasticAgent和IngestManager简化数据导入(一) Observability:使用ElasticAgent和IngestManager简化数据导入(二) 我有讲到如何使用IngestManager简化数据输入。今天我重新看了一下界面确实变了很多,这就是为什么实验版本的功能一直在演化中。在今天的文章中,我将基于7.13的版本如何使用Fleet导入Nginx日志。..

    2022年6月10日
    61
  • solr删除索引_solr索引迁移

    solr删除索引_solr索引迁移http方式删除某个core下的所有索引其中collection_test是这个core的名称http://127.0.0.1:8983/solr/collection_test/update/?stream.body=*:*&stream.contentType=text/xml;charset=utf-8&commit=true

    2025年7月17日
    8
  • 风格迁移综述

    风格迁移综述风格迁移综述 0 引言 1 基于图像迭代的风格迁移方法 1 1 基于最大均值差异的风格迁移 1 2 基于马尔科夫随机场的风格迁移 限制条件较多 有时视觉效果不是很好 1 3 基于深度图像类比的风格迁移 2 基于模型迭代的风格迁移算法 2 1 基于生成模型的风格迁移 2 2 基于图像重构解码器的风格迁移 3 应用举例 4 未来研究方向 5 参考文献推荐论文 Y Jing Y Yang Z Feng J Ye Y YuandM Song NeuralStyleT AReview

    2025年12月8日
    5
  • pycharm配置tensorflow环境_python3.6对应的tensorflow版本

    pycharm配置tensorflow环境_python3.6对应的tensorflow版本Round1:打开PyCharm,点击File->Settings,点击弹出界面的“+”号,在搜索框中键入关键字“tensorflow”,从列表中选中“tensorflow”,点击下方的“InstallPackage”,等待一段时间,华丽丽的安装失败了-_-Round2:在Pycharm的terminal中运行pipinstalltensorflow,在等了半小时后,倒计时还有3个多小时,我弃疗了!安装失败!Round3:以上用的都是官方的源,现在考虑换成国

    2022年8月26日
    8
  • 系统蓝屏代码

    系统蓝屏代码

    2021年9月10日
    51

发表回复

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

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