我要免费建立一个网站吗,wordpress自动排版的编辑器,奇月网络官方网站,中国建设银行网站密码忘了怎么办上面的代码主要的区别在于
初始化BigDecimal时形参是double、String和float的区别
从上面可以看到#xff0c;当double 和 float 时#xff0c;实际保存的值并不是是准确的0.99#xff0c;这是为什么呢
大致的原因是#xff1a;
BigDecimal(double val)将会把double型二… 上面的代码主要的区别在于
初始化BigDecimal时形参是double、String和float的区别
从上面可以看到当double 和 float 时实际保存的值并不是是准确的0.99这是为什么呢
大致的原因是
BigDecimal(double val)将会把double型二进制浮点型值精确的转换成十进制的BigDecimal。
你可能认为java中用new BigDecimal(0.1)创建的BigDecimal应该等于0.1一个是1的无精度的值一个是有精度的值但实际上精确的是等于0.1000000000000000055511151231257827021181583404541015625。这是因为0.1不能被double精确的表示下面大概描述一下原理。因此传入构造函数的值不是精确的等于0.1。
对与float也是同样的道理。首先此函数会自动进行精度扩展将float类型的0.99转成double类型的因为0.99本身就是无法用二进制表示的也就说无论你的精度是多少位都无法用二进制来精确表示0.99或者你用二乘来判断0.9921.98 0.9821.960.96*21.92 。。。永远无法得到一个整数。这就是二进制计算机的缺点就如同十进制也也无法表示1/31/6一样。 所以在0.99f转成double时进行了精度扩展变成了0.9900000095367432而接着转成字符串最后转成BigDecimal.
总结
所以在当遇到需要涉及到精确计算的时候如上面代码所示要注意该构造函数是一个精确的转换它无法得到与先调用Double.toString(double)方法将double转换成String再使用BigDecimal(String)构造函数一样的结果。如果要达到这种结果应该使用new BigDecimal(Stringvalue) 或 BigDecimal.valueof( double value)
扩展