记录一次空指针异常(NullPointerException)的断点调试

14 篇文章 0 订阅

前提:SalariedEmployee(月薪资) 和HourlyEmployee(时薪资)子类继承Employee的抽象父类,来获取父类里的属性/方法,并重写扩展为自己的方法。

先来看下我的报错情况:NullPointerException
在这里插入图片描述

  1. 此处输出的3是因为我获取了一下当前的月份,所以基本锁定在输出语句System.out.println(month);也就是24行之后;
    在这里插入图片描述

空指针异常:是一个运行级别的异常,即只有在运行时才会抛出NullPointerException
在看到这个异常之后,我首先想我的数组是存在的,有没有初始化?有;访问的对象是否存在?存在;对象是否为空?应该不为空(结果是空的,草率了)

  1. 断点调试:主要针对24行以后的代码:可以看到emps[0] = null; emps[1] = null;首先我确定了数组有初始化后,其次new SalariedEmployee()new HourlyEmployee()是没问题的;接着name/number/birthday等的赋值操作都是调用的子类的toString()方法;
    在这里插入图片描述
  2. 继续往下走,果然显示toString()方法抛出了NullPointerException
    在这里插入图片描述
  3. 首先两个子类的toString()方法都是重写的父类的toString()方法,但方法内部调用了super.toString();
    在这里插入图片描述
    在这里插入图片描述
  4. 继续往下走,可以看到父类EmployeetoString()方法只是returnname,number,birthday.toDateString()方法而已;
    在这里插入图片描述
  5. 想着总不可能变量出错吧,检查birthday.toDateString()方法,里面也只是returnMyDate的属性,且没有问题;
    在这里插入图片描述
  6. 一路都没有问题,不得不去检查Employee的属性了,好吧,破案了!属性没有问题,构造器里空空如也,没有this调用,所以当调用此构造器时,输入的name/number/birthday将不能传给此时正在创建的对象,当然也就无法输出了;
    在这里插入图片描述
    8.破案后的正常输出!
    在这里插入图片描述
    名言(我说的):debug很难搞,但debug成功后还好:)
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值