Java如何判断两个浮点数是否相等?

如何判断两个浮点数是否相等?Java

问题场景

 /**
  *  两个浮点数直接判断
  */
 double value1 = 0.9 - 0.8;
 double value2 = 0.8 - 0.7;
 System.out.println(value1 == value2); // false

why? 为什么结果为false?

因为不论是float还是double都是浮点数,计算机是二进制,浮点数会失去一定的精确度。
value1 = 0.09999999999999998, value2 = 0.10000000000000009

How? 怎么判断两个浮点数是否相等?

方式一 指定一个误差范围,两个浮点数的差值在此范围之内,则认为是相等的
/**
 * 浮点数比较的第一种方式(失精度的方式)
 * 指定一个误差范围,两个浮点数的差值在此范围之内,则认为是相等的。
 */
float diff = 1e-6f;
if (Math.abs(value1 - value2) < diff) {
    System.out.println("value1的值与value2的值相等");
}

方式二 使用 BigDecimal 来定义值,再进行浮点数的运算操作
前置知识1-问题场景
/**
* 前置知识1
* 浮点数的bigDecimal表示形式-采用String构造器的注入方式
*/
float value = 0.1f;
System.out.println(new BigDecimal(value));  // 0.100000001490116119384765625
System.out.println(new BigDecimal(String.valueOf(value)));// 0.1

前置知识1结论:浮点数的BigDecimal的表现形式为:

float value = 0.1f;
BigDecimal bigDecimal = new BigDecimal(String.valueOf(value));

或者(推荐)

float value = 0.1f;
BigDecimal bigDecimal1 = BigDecimal.valueOf(value);
前置知识2- BigDecimal中compareTo和equals的区别
System.out.println(new BigDecimal("0.1").equals(new BigDecimal("0.10"))); 
System.out.println(new BigDecimal("0.1").compareTo(new BigDecimal("0.10")));

输出结果:

false
0

Bigdecimal的equals方法不仅仅比较值的大小是否相等,首先比较的是scale(scale是bigdecimal的保留小数点位数,比如 new Bigdecimal(“1.001”),scale为3),也就是说,不但值得大小要相等,保留位数也要相等,equals才能返回true
前置知识2结论:

BigDecimal比较两个浮点数是否相等时,如果考虑小数点位数,则用equals方法;不考虑小数点位数,则用compareTo方法。

综上,使用BigDecimal进行浮点数比较的方法如下:

/**
* 用BigDecimal判断两个浮点数是否相等-compareTo
* 两个值相等,则返回值为0,否则返回值为-1
*/
BigDecimal bigDecimalValue1 = BigDecimal.valueOf(0.9).subtract(BigDecimal.valueOf(0.8));
BigDecimal bigDecimalValue2 = BigDecimal.valueOf(0.8).subtract(BigDecimal.valueOf(0.7));
System.out.println(bigDecimalValue1.compareTo(bigDecimalValue2));

输出结果

0

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值