一、出现空指针问题的原因分析
- jdk 常用类型中的对象产生空指针,比如:String,BigDecimal,等类型。
- 程序中出现的集合类型产生的空指针。比如:没有对List进行赋值,或者是rpc调用返回之后的没有对List属性进行赋值。
- 程序中出现的自定义类中产生空指针。比如:自己定义一个User类,而在使用的过程没有对其进行判空操作。或者在返回的参数中出现了返回null的情况。
二、如何改变和应对
1. 上线的前的处理方案:
-
从代码编码层面控制,养成对集合、字符串、复杂对象编码完,自我review的习惯。努力把空指针问题控制在自我review阶段发现,而不是在预发测试发现。
-
寻找代码检测工具,借助工具对编写完的代码进行扫描。
-
应把自己总结的检查代码中存在空指针经验总结下来,并分享给测试的同学,方便测试同学查看代码的时候,及时发现并提醒。
2. 上线后的告警方案
- 在线上配置空指针异常监控,一旦发现有空指针异常的时候要及时治理,避免空指针数量变多,到最后改造起来成本高,压力大。