java 处理Float和Double时要小心陷阱

本文详细介绍了在Java中处理Float和Double类型时应注意的问题,包括如何避免使用NaN和Infinity值,以及如何正确地验证和初始化这些类型的变量。此外,还提供了来自Princeton的示例代码,展示了如何检查浮点数的有效性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Float和Double包括float和double,有

NEGATIVE_INFINITY
-0.0
0
0.0
POSITIVE_INFINITY


NaN
与NaN进行比较,结果都是false。
所以尽量把“targeted执行的语句”放在确定的判断中,并且该判断返回true(因为NaN参与的判断一律返回false)

public employee(float monthly_salary)
{
  if (monthly_salary >= 0.0)
  {
    this.yearly_salary = 12.0 * monthly_salary; // targeted执行的语句
  }
  else throw IllegalArgumentException("illegal monthly salary");
}

而下面的代码因为没有考虑monthly_salary等于NaN的情况,而不正确:

public employee(float monthly_salary)
{
  if (monthly_salary < 0.0)
    throw IllegalArgumentException("illegal monthly salary");
  this.yearly_salary = 12.0 * monthly_salary; // targeted执行的语句在外面
}

参考:
http://blog.youkuaiyun.com/jierui001/article/details/3278382
除此以外,在对浮点型进行处理时,可以参照Princeton的代码:

    public Point2D(double x, double y) {
        if (Double.isInfinite(x) || Double.isInfinite(y))
            throw new IllegalArgumentException("Coordinates must be finite");
        if (Double.isNaN(x) || Double.isNaN(y))
            throw new IllegalArgumentException("Coordinates cannot be NaN");
        if (x == 0.0) this.x = 0.0;  // convert -0.0 to +0.0
        else          this.x = x;

        if (y == 0.0) this.y = 0.0;  // convert -0.0 to +0.0
        else          this.y = y;
    }

以及

    public Interval1D(double min, double max) {
        if (Double.isInfinite(min) || Double.isInfinite(max))
            throw new IllegalArgumentException("Endpoints must be finite");
        if (Double.isNaN(min) || Double.isNaN(max))
            throw new IllegalArgumentException("Endpoints cannot be NaN");

        // convert -0.0 to +0.0
        if (min == 0.0) min = 0.0;
        if (max == 0.0) max = 0.0;

        if (min <= max) {
            this.min = min;
            this.max = max;
        }
        else throw new IllegalArgumentException("Illegal interval");
    }

参考:
https://algs4.cs.princeton.edu/12oop/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值