正例 :
// 正例,code可能为null, LEVEL_DESC_CODE为常量
LEVEL_DESC_CODE.equals(code);
// 反例
code.equals(LEVEL_DESC_CODE);
提出问题 :无论 null 变量在后都会被读到,为什么使用定值对象调用 equals 方法,将 null 变量放在括号内就能够避免空指针异常?
源码 :
1-> Object 类下的 equals 源码
public boolean equals(Object obj){
// 比较对象的是否指向同一个内存地址
return (this == obj);
}
2-> String 类下的覆写后的 equals 源码
public boolean equals(Object anObject) {
// 比较调用发起对象与传入对象是否为同一个
if (this == anObject) {
return true;
}
// 判断当前传入是否为字符串类型
if (anObject instanceof String) {
String anotherString = (String) anObject;
int n = value.length;
// 比较两个字符串对象长度
if (n == anotherString.value.length) {
char v1[] = value;
char v2[] = anotherString.value;
int i = 0;
// 若长度相同,则比较字符数组的每一位
while (n-- != 0) {
if (v1[i] != v2[i])
return false;
i++;
}
return true;
}
}
// 不为字符串直接返回 false/
return false;
}
回答 :
能够避免空指针的原因,将 null 值对象作为参数传入,两个 if 判断均为假,所以直接返回 false,不报 NPX 异常。