String.equals实现

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字节码优化有关,但不了解如何.

Thi*_*ilo 5

我认为这是死代码,从字符串时仍然共享后盾阵列和有遗留下来的offsetcount,这样你需要调整的指标一点点.

在JDK 7 Update 6中更改了String实现(很多人对此感到不满,特别是它发生在次要版本中).字符串不再共享后备数组(除非字符串本身相等,在这种情况下,新的重复数据删除器会尝试重新共享它们).

您可以在" String.equals()如何工作 "中看到对旧实现的讨论.