前言
只要是接触过java的人都不会对null感到陌生。null在java里是很神奇的东西,默认情况下可以充当任何参数,但很多时候又会造成错误。谷歌在Guava的wiki说,null在95%的场合下是不需要的。
对于安卓开发而言,因为Google Play禁止热更新,App的bug-free更为重要,而毫无疑问的最大bug就是NullPointerException了。因此,讨论null,对代码稳定性是有着显著意义的。
初级处理方法
初级开发者很常见的一个问题就是到处都进行if(object!=null)的判断。其实这不单单是这个判断的问题,而在于初级开发者往往没有往更深层次思考:这里到底应不应该出现null?如果不应该,为什么出现了?如果应该,那么这个判断就是合理而且必须的。
也就是说,抛开技术层面不谈,关于null更多是一种思考和编程的方式。
拿安卓来举例,常见的场合就是从API获取数据的时候可能会产生null,也就是说后端是源头。因此,客户端不应该信任后端对null的处理,无论是马上进行null的排查也好,进行默认值的设置也好,在这一步就可以把null排除掉。这样下游的一些方法或者类使用数据的时候,就不用担心null。
此外,安卓本身系统也可能导致null,getContext()可能会失败。当然这并不是世界末日,对于这种情况,try-catch组合正好可以用来处理失败。
总体而言,对于null:
- 如果不接受null,要在源头就把null去除;
- 如果接受null,要知道它代表什么,以及如何处理;
- 对于无法去除的意外的null,妥善捕获处理。
null的处理
- 对象默认值
可以在新建一个对象的时候就设置好参数的默认值。 - 替代null
还有一个思路就是,在object=null的时候替换掉null。很多get函数有第二个参数就是用来设置替代值的。此外,java 8和Guava都有Optional,可以使用Optional.fromNullable(x).or(defaultValue)来把可能的null用默认值代替。 - 使用能接受null的函数
有些函数接受null为参数。例如a.equals(b),b可以为null而a不能,这就是一个小trick。
当然,以上介绍的其实都是很基础的方法,不过简单并不代表不重要。相反,细微之处见功夫。