NPE问题,100%的Java程序员都碰到,并且曾经是心中的痛。
业务模型
Person 有车一族, 有Car字段,
Car 车,每个车都有购买保险, 有Insurance字段;
Insurance 保险,每个保险都有名字 有name字段;
需求:获取某个Person对象的购买保险的名称;
public String getCarInsuranceName(Person person) { return person.getCar().getInsurance().getName(); }
public String getCarInsuranceName_check(Person person) { if (Objects.nonNull(person)) { final Car car = person.getCar(); if (Objects.nonNull(car)) { final Insurance insurance = car.getInsurance(); if (Objects.nonNull(insurance)) { return insurance.getName(); } } } return "unkown"; }
public String getCarInsuranceName_protect(Person person) { if (Objects.isNull(person)) { return "unkown"; } final Car car = person.getCar(); if (Objects.isNull(car)) { return "unkown"; } final Insurance insurance = car.getInsurance(); if (Objects.isNull(insurance)) { return "unkown"; } return insurance.getName(); }
编程方法 | 缺点 |
---|---|
常规编程 | NPE问题 |
检查式编程 | 1.可读性不好,多层if嵌套; 2.扩展性不好,需要熟悉全流程,否则不知道应该在哪个if中扩展,极易出错; |
防御式编程 | 1. 维护困难,4个不同的退出点,极易出错,容易遗漏检查项目 |
构造方法 | 说明 | 备注 |
---|---|---|
Optional.empty() | 一定是空的对象 | 跟null有区别,是一个单例对象 |
Optional.of(T t) | 一定是不空的对象 | 如果给了null值会立刻抛出NPE |
Optioanl.ofNullable(T t) | 允许为空的对象放在里面 | 使用值之前需要做检查 |
原创不易,转载请注明出处,欢迎沟通交流。