Я получаю StackOverFlowException для этого кода, потому что моя JVM не поддерживает оптимизацию хвостовых вызовов, верно? - PullRequest
5 голосов
/ 13 декабря 2010

Я получаю StackOverflowException для этого метода Java:

private static final Integer[] populate(final Integer[] array, final int length, final int current) {

    if (current == length) {
        return array;
    } else {
        array[current] = TR.random.nextInt();
        System.out.println(array[current]);
        return populate(array, length, current + 1);
    }
}

Я играю с рекурсией хвостового вызова, поэтому я думаю, что это происходит, когда JVM не закорачивает стек, верно?

Ответы [ 4 ]

7 голосов
/ 13 декабря 2010

Нет JVM, о которой я знаю, поддерживает оптимизацию хвостового вызова. Это не недосмотр. Очевидно, что эта оптимизация имеет существенные последствия для рефлексии Java и менеджеров безопасности Java.

Ссылки:

3 голосов
/ 13 декабря 2010

Да, оптимизация Tail Call в настоящее время не поддерживается JVM из-за модели безопасности и необходимости всегда иметь доступную трассировку стека, хотя этот пример можно легко переписать с использованием итерации.

1 голос
/ 13 декабря 2010

Обычная Java не имеет оптимизации хвостового вызова, AFAIK.Scala имеет несколько ограниченную реализацию: http://fupeg.blogspot.com/2009/04/tail-recursion-in-scala.html

1 голос
/ 13 декабря 2010

Я нашел ссылку на хвостовую рекурсию в Java, поэтому я проверю это (позже, когда у меня будет время).

Хотя это было бы крайне неэффективно для вашего случая использования.

...