面试的时候,面试官问我在java中涉及金额的数值,应该用什么类型?
当时我想到了是double和float两个浮点类型。
最终我选择了double类型,考虑金额的大小,double是8个字节,float是4个字节。
面试后我查了一下,结论:
1.浮点数(double,flot)因为精度问题, 容易出现不精确的计算结果
2.浮点数范围比较小
Java中Math函数 java.math.BigDecimal;
//BigDecimal除数
System.out.println("除法:"+new BigDecimal(123.1)
.divide(new BigDecimal(100),8,BigDecimal.ROUND_UP));
//结果除法没有取后8时:1.23099999999999994315658113919198513031005859375
//8:取后几位? BigDecimal.ROUND_UP 8位后的舍入:1.23100000
//加法
System.out.println("加法:"+new BigDecimal(129.4)
.add(new BigDecimal(0.32)));
//结果129.720000000000005691003224228552426211535930633544921875
//减法
System.out.println("减法:"+new BigDecimal(123.4)
.subtract(new BigDecimal(78)));
//结果400000000000005684341886080801486968994140625
//乘法
System.out.println("乘法:"+new BigDecimal(233.23)
.multiply(new BigDecimal(2.321)));
//541.326830000000016853327622357026522483087829845192293499837876691316296273726038634777069091796875
}
java.math.BigDecimal中有四个构造器,分别是+-*/的方法,最多可以保留后96位小数点
精度也是比double和float高。
个人见解,如若有不对的地方提出来我会尽快的改正。