Я просто просматривал реализацию класса Java String
, и следующее поразило меня как нечетное:
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) { // Here n is being decremented...
if (v1[i] != v2[i])
return false;
i++; // while i is being incremented
}
return true;
}
}
return false;
}
Это может быть легко реализовано только с одной переменной подсчета, тогда как n
будет эффективно окончательным, например:
while (i != n) {
if (v1[i] != v2[i])
return false;
i++;
}
Это также означает, что он полностью избавляется от i
:
while (n-- != 0) {
if (v1[n] != v2[n])
return false;
}
Связано ли это с сравнением с 0 (младшим битом) дешевле, чем с другой переменной, или есть ли какая-то другая причина, почему он реализован таким образом?