我在这段代码上得到了一个StackOverFlowException,因为我的JVM不支持尾调用优化,对吧?

Edd*_*ddy 5 java stack-overflow tail-recursion tail-call-optimization

我得到了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);
    }
}
Run Code Online (Sandbox Code Playgroud)

我正在玩尾调用递归,所以我猜这是当JVM没有将堆栈短路时会发生什么?

Ste*_*n C 7

我所知道的没有JVM支持尾调用优化.这不是疏忽.显然,这种优化对Java反射和Java安全管理器有重大影响.

参考文献: