一次NaN引起的npe

# 先上代碼json

import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;

public class QQ {

    public static void main(String[] args) {
        double result = calcute() < 0 ? 0 : calcute();
        System.out.println(result);
        ResultBean resultBean = new ResultBean(result);
        System.out.println(resultBean.toString());
        // 若是再用resultBean.value進行計算,則你會發現出現一堆npe,並且你還不必定知道問題到底出在哪兒。。。
        JSONObject jsonObject = JSON.parseObject(resultBean.toString());
        System.out.println(jsonObject.get("value"));
    }

    public static double calcute() {
        Double temp1 = 1d;
        Double temp2 = 2d;
        double temp3 = temp1 - temp2;
        double temp4 = Math.sqrt(temp3);
        double result = ((temp1 + temp4) / temp2);
        return result;
    }
}

class ResultBean {

    private double value;

    public ResultBean(double value) {
        this.value = value;
    }

    public double getValue() {
        return value;
    }

    public void setValue(double value) {
        this.value = value;
    }

    public String toString() {
        Object result = JSON.toJSON(this);
        return result.toString();
    }

}

# 固然我只是把主要的邏輯提出來了,實際項目中還夾雜其餘複雜的邏輯this

# 上面代碼的結果是:spa

NaN
{"value":null}
null

code

#  能夠看到 Java Bean 轉 jsonStr 的時候,把NaN給抹去了,這就給後面出現 npe 再排查問題形成了很大的困難。。。。。blog

相關文章
相關標籤/搜索