在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;
}
为什么迭代使用两个操作 - 递增i
并递减n
而不是类似的东西:
while (i < n) {
if (v1[i] != v2[i])
return false;
i++;
}
或
while (i-- != 0) {
if (v1[i] != v2[i])
return false;
}
有一次递增或递减操作吗?
我想,它与JVM字节码优化有某种关系,但不了解如何。
答案 0 :(得分:5)
我认为这是死代码,从字符串仍然共享支持数组并且有offset
和count
的时代遗留下来,所以你需要稍微调整一下索引。
在JDK 7 Update 6中更改了String实现(许多人对此感到不满,特别是它发生在次要版本中)。字符串不再共享支持数组(除非字符串本身是相同的,在这种情况下,新的重复数据删除器会尝试重新共享它们。)
您可以在&#34; how does String.equals() work&#34;上看到对旧实施的讨论。
答案 1 :(得分:0)
实际上这个java代码与真实机器代码没有直接关系(至少对于现代桌面/服务器JVM而言)。您可以阅读“HotSpot VM中的内在方法”。例如。 When will JVM use intrinsics