错误案例
(int)(Float.parseFloat(price)*100) 这样处理,对于8.90这样的价格会转化成889,实际应该是890才对
(int)(Double.parseDouble(price)*100) ,对于8.90转化的结果是对的,但是对于 1.15会把它转化成114,又出问题了
错误分析
float和double都采用了micro-optimization方式提升计算性能,所以都有计算偏差。可以使用BigDecimal来避免精度丢失。
正确用法
可见Double,Float都不能很好的处理精度问题,终极处理方法是使用BigDecimal,这里我们的框架对它有封装,那就是Money类,很简单:
new Money(price).getCent();