你们可能都遇到过,float在计算某些值时,会有不许确的状况。java
好比以下状况:ide
package com.nicchagil.study.java.demo.No10float计算.No01不许确的举例; public class Call { public static void main(String[] args) { System.out.println(0.08f + 0.01f); } }
打印:工具
0.089999996
若是须要准确计算float,一种方法就是用BigDecimal来进行计算,看如下工具类:spa
import java.math.BigDecimal; public class FloatCalculator { /** * <p>add</p> * @param a * @param b * @return */ public static float add(float a, float b) { BigDecimal b1 = new BigDecimal(a + ""); BigDecimal b2 = new BigDecimal(b + ""); float f = b1.add(b2).floatValue(); return f; } /** * <p>subtract</p> * @param a * @param b * @return */ public static float subtract(float a, float b) { BigDecimal b1 = new BigDecimal(a + ""); BigDecimal b2 = new BigDecimal(b + ""); float f = b1.subtract(b2).floatValue(); return f; } /** * <p>multiply</p> * @param a * @param b * @return */ public static float multiply(float a, float b) { BigDecimal b1 = new BigDecimal(a + ""); BigDecimal b2 = new BigDecimal(b + ""); float f = b1.multiply(b2).floatValue(); return f; } /** * <p>divide</p> * <p>当不整除,出现无限循环小数时,向(距离)最近的一边舍入,除非两边(的距离)是相等,若是是这样,向上舍入, 1.55保留一位小数结果为1.6</p> * @param a * @param b * @return */ public static float divide(float a, float b) { return divide(a, b, 2, BigDecimal.ROUND_HALF_UP); } /** * <p>divide</p> * @param a * @param b * @param scale * @param roundingMode * @return */ public static float divide(float a, float b, int scale, int roundingMode) { /* * 经过BigDecimal的divide方法进行除法时就会抛异常的,异常以下: * java.lang.ArithmeticException: Non-terminating decimal expansion; no exact representable decimal result. at java.math.BigDecimal.divide(Unknown Source) * 解决之道:就是给divide设置精确的小数点divide(xxxxx,2, BigDecimal.ROUND_HALF_EVEN) * BigDecimal.ROUND_HALF_UP : 向(距离)最近的一边舍入,除非两边(的距离)是相等,若是是这样,向上舍入, 1.55保留一位小数结果为1.6 */ BigDecimal b1 = new BigDecimal(a + ""); BigDecimal b2 = new BigDecimal(b + ""); float f = b1.divide(b2, scale, roundingMode).floatValue(); return f; } }