`

BigDecimal 运用小数

 
阅读更多

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则向下舍

 

 

注释:

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

		String yearRate ="0.13999999999999999999";
		System.out.println(yearRate);
		BigDecimal decimal = new BigDecimal(yearRate).multiply(new BigDecimal(100));
		yearRate = decimal.setScale(2, BigDecimal.ROUND_DOWN).toString();
		System.out.println(yearRate);

 ----结果:

0.13999999999999999999

 

13.99

 

 

 

static BigDecimal ONE 

          值为 1,标度为 0。 

static int ROUND_CEILING 

          接近正无穷大的舍入模式。 

static int ROUND_DOWN 

          接近零的舍入模式。 

static int ROUND_FLOOR 

          接近负无穷大的舍入模式。 

static int ROUND_HALF_DOWN 

          向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为上舍入的舍入模式。 

static int ROUND_HALF_EVEN 

          向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。 

static int ROUND_HALF_UP 

          向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为向上舍入的舍入模式。 

static int ROUND_UNNECESSARY 

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

static int ROUND_UP 

          舍入远离零的舍入模式。 

static BigDecimal TEN 

          值为 10,标度为 0。 

static BigDecimal ZERO 

          值为 0,标度为 0。

 

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics