对于一些精准的数字,如涉及到金额时我们一般会使用BigDecimal类型来保存和处理。在处理保留小数位数时,如果通过DecimalFormat表达式需要注意下。
1、通过DecimalFormat保留两位小数
通过上图可以看到,#在补位时,如果该位没有数字会补空,如果是0.123这样的整数位为0的数字,则会丢失整数位;
0在补位时,如果该位没有数字会补0,所以整数位切勿用00.这样的表达式,造成最左侧存在多余0。
推荐:在保留小数位上,#0.00这种类型比较适宜。
2、通过setScale保留小数。
由上可以看到,在小数位大于等于2位时可以正常保留两位小数;如果该数字不足两位小数,则也不会补0,需要注意一些场景可能不合适。
3、推荐保留两位小数方式
一般通过string.format处理的结果比较合适。
4、附BigDecimal的常用方法
(1)、加法 add()函数、
(2)、减法subtract()函数、
(3)、乘法multiply()函数、
(4)、除法divide()函数、
BigDecimal result = num2.divide(num1,5,BigDecimal.ROUND_HALF_UP);
除法运算需要注意指定小数位数,和四舍五入方式
(5)、绝对值abs()函数、
(6)、比较大小compareTo()方法,如果返回1则前者大,0一样大,-1前者小。需要注意空指针。
学海无涯苦作舟!!!