В 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, но не понимает, как это сделать.