记录学习Double转Bigdecimal丢失精度的原因 注意事项: 不能直接使用Bigdecimal的构造函数传double进行转换,部分数值会丢失精度,因为计算机是二进制的Double无法精确的储存一些小数位,0.1的double数据存储的值实际上并不真的等于0.1 如该方式将0.1转换为Bigdecimal得到的结果是 0.1000000000000000055511151231257827021181583404541015625 ...
一般来说,double类型的变量可以处理16位有效数,但实际应用中,如果超过16位,就需要BigDecimal类来操作。 既然这样,那用BigDecimal就能够很好解决这个问题咯? public static void main(String[] args) { // 方法1 BigDecimal a = new BigDecimal(0.1); System.out.println("a --> " + a); // 方法2 BigDecim...
一般来说,double类型的变量可以处理16位有效数,但实际应用中,如果超过16位,就需要BigDecimal类来操作。 既然这样,那用BigDecimal就能够很好解决这个问题咯? public static void main(String[] args) { // 方法1 BigDecimal a = new BigDecimal(0.1); System.out.println("a --> " + a); // 方法2 BigDecim...