其他分享
首页 > 其他分享> > 一次NaN引发的npe

一次NaN引发的npe

作者:互联网

# 先上代码

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();
    }

}

# 当然我只是把主要的逻辑提出来了,实际项目中还夹杂其他复杂的逻辑

# 上面代码的结果是:

NaN
{"value":null}
null


#  可以看到 Java Bean 转 jsonStr 的时候,把NaN给抹去了,这就给后面出现 npe 再排查问题造成了很大的困难。。。。。

标签:npe,NaN,引发,value,resultBean,toString,result,double,public
来源: https://www.cnblogs.com/lwmp/p/11024664.html