java float 运算_【Java】Float计算不准确

importjava.math.BigDecimal;public classFloatCalculator {/***

add

*@parama

*@paramb

*@return

*/

public static float add(float a, floatb) {

BigDecimal b1= new BigDecimal(a + "");

BigDecimal b2= new BigDecimal(b + "");float f =b1.add(b2).floatValue();returnf;

}/***

subtract

*@parama

*@paramb

*@return

*/

public static float subtract(float a, floatb) {

BigDecimal b1= new BigDecimal(a + "");

BigDecimal b2= new BigDecimal(b + "");float f =b1.subtract(b2).floatValue();returnf;

}/***

multiply

*@parama

*@paramb

*@return

*/

public static float multiply(float a, floatb) {

BigDecimal b1= new BigDecimal(a + "");

BigDecimal b2= new BigDecimal(b + "");float f =b1.multiply(b2).floatValue();returnf;

}/***

divide

*

当不整除,出现无限循环小数时,向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向上舍入, 1.55保留一位小数结果为1.6

*@parama

*@paramb

*@return

*/

public static float divide(float a, floatb) {return divide(a, b, 2, BigDecimal.ROUND_HALF_UP);

}/***

divide

*@parama

*@paramb

*@paramscale

*@paramroundingMode

*@return

*/

public static float divide(float a, float b, int scale, introundingMode) {/** 通过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();returnf;

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值