频道栏目
首页 > 资讯 > 其他综合 > 正文

项目中BigDecimal计算实例讲解

18-06-25        来源:[db:作者]  
收藏   我要投稿

在项目中经常会用到小数的一些计算,而float和double类型的主要设计目标是为了科学计算和工程计算。他们执行二进制浮点运算,这是为了在广域数值范围上提供较为精确的快速近似计算而精心设计的。然而,它们没有提供完全精确的结果,所以不应该被用于要求精确结果的场合。但是,商业计算往往要求结果精确。所以有时候必须要采用BigDecimal。

public class Demo {

public static void main(String[] args) {

BigDecimal a =null;

Integer faultRate = 6;

a = BigDecimal.valueOf(faultRate.doubleValue()/3);

BigDecimal b =a.setScale(2, RoundingMode.HALF_UP);//保留两位小数

System.out.println("结果是"+b);

//下面将结果转化成百分比

NumberFormat percent = NumberFormat.getPercentInstance();

percent.setMaximumFractionDigits(2);

System.out.println(percent.format(b.doubleValue()));

}

}

运行结果是:

BigDecimal.setScale()方法用于格式化小数点

setScale(1)表示保留一位小数,默认用四舍五入方式

setScale(1,BigDecimal.ROUND_DOWN)直接删除多余的小数位,如2.35会变成2.3

setScale(1,BigDecimal.ROUND_UP)进位处理,2.35变成2.4

setScale(1,BigDecimal.ROUND_HALF_UP)四舍五入,2.35变成2.4

setScaler(1,BigDecimal.ROUND_HALF_DOWN)四舍五入,2.35变成2.3,如果是5则向下舍

setScaler(1,BigDecimal.ROUND_CEILING)接近正无穷大的舍入

setScaler(1,BigDecimal.ROUND_FLOOR)接近负无穷大的舍入,数字>0和ROUND_UP作用一样,数字<0和ROUND_DOWN作用一样

setScaler(1,BigDecimal.ROUND_HALF_EVEN)向最接近的数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。

注释:1:scale指的是你小数点后的位数。比如123.456则score就是3.score()就是BigDecimal类中的方法啊。

比如:BigDecimal b = new BigDecimal("123.456");b.scale(),返回的就是3.

2:roundingMode是小数的保留模式。它们都是BigDecimal中的常量字段,有很多种。

比如:BigDecimal.ROUND_HALF_UP表示的就是4舍5入。

3:pubilc BigDecimal divide(BigDecimal divisor, int scale, int roundingMode)

的意思是说:我用一个BigDecimal对象除以divisor后的结果,并且要求这个结果保留有scale个小数位,roundingMode表示的就是保留模式是什么,是四舍五入啊还是其它的,你可以自己选!

4:对于一般add、subtract、multiply方法的小数位格式化如下:

BigDecimal mData = new BigDecimal("9.655").setScale(2, BigDecimal.ROUND_HALF_UP);

System.out.println("mData=" + mData);----结果:----- mData=9.66

相关TAG标签
上一篇:SQOOP抽取各类型数据库脚本示例
下一篇:springboot中jsp引用静态资源css,js的实现方法
相关文章
图文推荐

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站