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

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.csdn.net/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/

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值