Art*_*zko 11 java string equals
在JDK 8中,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;
}
}
return false;
}
Run Code Online (Sandbox Code Playgroud)
为什么迭代使用两个操作 - 递增i和递减n而不是类似的东西:
while (i < n) {
if (v1[i] != v2[i])
return false;
i++;
}
Run Code Online (Sandbox Code Playgroud)
要么
while (i-- != 0) {
if (v1[i] != v2[i])
return false;
}
Run Code Online (Sandbox Code Playgroud)
一次递增或递减操作?
我想,它在某种程度上与JVM字节码优化有关,但不了解如何.
我认为这是死代码,从字符串时仍然共享后盾阵列和有遗留下来的offset和count,这样你需要调整的指标一点点.
在JDK 7 Update 6中更改了String实现(很多人对此感到不满,特别是它发生在次要版本中).字符串不再共享后备数组(除非字符串本身相等,在这种情况下,新的重复数据删除器会尝试重新共享它们).
您可以在" String.equals()如何工作 "中看到对旧实现的讨论.