首页
学习
活动
专区
工具
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
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3667932

复制
相关文章

相似问题

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