java支持并优化尾递归调用吗?

 一个具有骨感的女人0 发布于 2023-02-07 16:41

假设我有一个尾递归的递归函数.

System.out.println( sum(Arrays.asList(0, 1, 2, 3, 4, 5)) );

int sum(List integers) {
    if (integers.isEmpty())
        return 0;
    else
        return integers.get(0) + sum(integers.subList(1, integers.size()));
}

我想知道这个函数sum是否会在堆栈上增长,还是会被改为循环(因为它是一个尾递归函数)?

我刚刚读到Scala检测到这样的调用并对其进行优化但是这只是一个Scala专用的东西还是JVM?

1 个回答
  • Java支持尾递归调用,但是AFAIK并没有对它们进行优化.我认为Scala编译器只是能够做到这一点,而不是JVM本身.查看@tailrecScala中的注释,看看编译器能够做什么:)

    但无论Java/JVM是否优化尾递归,您的函数都将比必要时更难优化.

    看这个:

    int sum(List<Integer> integers) {
        return sum(integers, 0);
    }
    
    int sum(List<Integer> integers, int sumSoFar) {
        if (integers.isEmpty())
            return sumSoFar;
        else
            return sum(
                    integers.subList(1, integers.size()),
                    sumSoFar + integers.get(0)
            );
    }
    

    看,我添加了一个重载sum的远程计算的sum参数.这样当你在else分支中重复时,你不再需要实际的堆栈框架了 - 你在递归调用中得到了所有你需要的函数参数.

    在您的代码段中,只要递归调用,堆栈帧可能必须存在.

    2023-02-07 16:44 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有