一次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 再排查问题造成了很大的困难。。。。。

转载于:https://www.cnblogs.com/lwmp/p/11024664.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值