проверить этот Scala-код:
def rec(n: Int) {
if (n > 1) {
val d = n / 2
rec(d)
// if (d > 1) // abort loop
rec(n/d)
}
}
Этот код приведет к бесконечному циклу. Из-за хвостовой рекурсивной оптимизации я не получаю StackOverflowError.
Декомпилировано с JAD Я получил этот Java-код:
public void rec(int n)
{
int d;
for(; n > 1; n /= d)
{
int i = n;
d = i / 2;
rec(d);
}
}
В последней строке цикла метод вызывает сам себя, поэтому я не понимаю позицию хвостового вызова. Кто-нибудь, кто может объяснить это?