lihat kode Scala ini:
def rec(n: Int) {
if (n > 1) {
val d = n / 2
rec(d)
// if (d > 1) // abort loop
rec(n/d)
}
}
Kode ini akan menghasilkan perulangan tanpa akhir. Karena optimasi rekursif ekor saya tidak mendapatkan StackOverflowError.
Didekompilasi dengan jad saya mendapatkan kode Java ini:
public void rec(int n)
{
int d;
for(; n > 1; n /= d)
{
int i = n;
d = i / 2;
rec(d);
}
}
Di baris terakhir dari loop, metode memanggil dirinya sendiri oleh karena itu saya tidak mengerti posisi tail call. Adakah yang bisa menjelaskan hal ini?