首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >为什么在Java比较中使用Float.floatToIntBits()?

为什么在Java比较中使用Float.floatToIntBits()?
EN

Stack Overflow用户
提问于 2010-09-08 20:56:24
回答 2查看 6.1K关注 0票数 20

在JBox2d中,存在用于Vec2.equals()的以下代码

代码语言:javascript
复制
@Override
public boolean equals(Object obj) { //automatically generated by Eclipse
    if (this == obj)
        return true;
    if (obj == null)
        return false;
    if (getClass() != obj.getClass())
        return false;
    Vec2 other = (Vec2) obj;
    if (Float.floatToIntBits(x) != Float.floatToIntBits(other.x))
        return false;
    if (Float.floatToIntBits(y) != Float.floatToIntBits(other.y))
        return false;
    return true;
}

我想知道这里的浮点数<->整型位转换函数有什么作用。这是否提供了一种绕过Java浮点比较不准确问题的方法(如果可能的话)?或者完全是别的什么东西?我想知道它是否是epsilon方法的替代方法:

代码语言:javascript
复制
if (Math.abs(floatVal1 - floatVal2) < epsilon)

PS。出于完整性和趣味性的考虑,这里是Vec2.hashCode()

代码语言:javascript
复制
@Override
public int hashCode() { //automatically generated by Eclipse
    final int prime = 31;
    int result = 1;
    result = prime * result + Float.floatToIntBits(x);
    result = prime * result + Float.floatToIntBits(y);
    return result;
}

仅供参考,我完全明白为什么在hashCode()中使用转换函数--散列ID必须是整数。

EN

回答 2

Stack Overflow用户

发布于 2010-09-08 21:14:11

当涉及到比较时,Double.Nan (非数字)是一个特殊的值:

代码语言:javascript
复制
System.out.println(Float.NaN == Float.NaN);
System.out.println(Float.floatToIntBits(Float.NaN) == Float.floatToIntBits(Float.NaN));

这将打印:

代码语言:javascript
复制
false
true 
票数 10
EN

Stack Overflow用户

发布于 2010-09-08 21:24:21

我不是百分之百知道,但很可能他们是在试图绕过NaN != NaN问题。如果你的浮点数恰好是NaN,你不能与任何东西进行比较,因为结果总是假的。比较intBits将为您提供NaN == NaN。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3667932

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档