本人前段时间作一个社区电商应用,发现了一个 天坑 ...................让我哭会 。 下面听听个人踩坑之路吧 ,电商确定跟¥打交道了,计算少不了的。因为本人太菜 单纯的觉得 float double 能够直接参与加减乘除 感受这种代码万无一失没去想这么多直接 float*int 。 以前简单测试没问题,项目上线后本身偶然才发现的(不知道公司测试干吗的) ,当选择多件商品时 , 仍是直接说现象吧 好比 在代码中 0.1 f * A A为int 型 当A = 1结果没错 可是 慢慢增大 到 A = 9 的时候 结果等于 0.9000000.(多少0忘了)...4 ,这就尴尬了 当时一脸蒙逼 后来百度查了一下说 浮点型精度不许什么的 , 反正我这个菜鸟不怎么动 , 可是人家有了解决方法这是重点.... 因此之后千万不要随便拿浮点型进行运算 ,尤为是涉及金额的。不说了 我把运算的工具类贴出来吧 ,趁老板还没发现 赶忙更新掉。java
工具类以下:ide
/** * @author Mr_Peng * @created at 2017/6/9 10:13. * @describe: java 精度运算 */public class ArithUtil { private static final int DEF_DIV_SCALE=10; private ArithUtil(){} public static double add(double d1,double d2){ BigDecimal b1=new BigDecimal(Double.toString(d1)); BigDecimal b2=new BigDecimal(Double.toString(d2)); return b1.add(b2).doubleValue(); } public static double sub(double d1,double d2){ BigDecimal b1=new BigDecimal(Double.toString(d1)); BigDecimal b2=new BigDecimal(Double.toString(d2)); return b1.subtract(b2).doubleValue(); } public static double mul(double d1,double d2){ BigDecimal b1=new BigDecimal(Double.toString(d1)); BigDecimal b2=new BigDecimal(Double.toString(d2)); return b1.multiply(b2).doubleValue(); } public static double div(double d1,double d2){ return div(d1,d2,DEF_DIV_SCALE); } public static double div(double d1,double d2,int scale){ if(scale<0){ throw new IllegalArgumentException("The scale must be a positive integer or zero"); } BigDecimal b1=new BigDecimal(Double.toString(d1)); BigDecimal b2=new BigDecimal(Double.toString(d2)); return b1.divide(b2,scale, BigDecimal.ROUND_HALF_UP).doubleValue(); }}证实:真实有效 ,运算结果100%准确 不会出现多余小数位数。