Kotlin尾递归优化以及递归问题还没搞懂?

8 篇文章 0 订阅
1 篇文章 0 订阅

由于细节内容实在太多啦,所以只把部分知识点整理出来粗略的介绍,每个小节点里面都有更细化的内容! 

接下来开始分享啦 

递归(Recursive)是指自己方法内部调用自己

如求 1- n(n>1)之间的和:

    public static long sum(long n) {

        if (n == 1) {
            return 1;
        }

        return n + sum(n - 1);

    }

这是使用递归的方式求和,很消耗内存,比如我求 1 - 2147483647 ( Integer.MAX_VALUE ) ,就会StackOverflowError ,堆栈溢出

Kotlin尾递归优化以及递归问题还没搞懂?

StackOverflowError

但是其实使用循环是可以计算出的

    static long sum(long n){
        
        long res = 0;
        while (n > 0){
            res+=n;
            n--;
        }
        
        return res;
    }

继续求 1 - 2147483647 ( Integer.MAX_VALUE ) 的和

Kotlin尾递归优化以及递归问题还没搞懂?

中场休息时间!最近整理了一份Java核心知识点。覆盖了JVM、锁、并发、Java反射、Spring

原理、微服务、Zookeeper、数据库、数据结构等大量知识点。

   如果需要免费获取到这个【资料】文档的话可以扫一扫下面

结果

第二行是结果,第三行是用时

那么什么是尾递归呢?

就是递归时只返回函数本身,没有其他计算机:

    static long sum(long n,long sum){
        
        if (n == 0){
            return sum;
        }
        return sum(n - 1,n+sum);
    }

在某些语言中,写成这样的递归在编译时会被自动优化,或者运行时会清除上次的栈信息,因为上次执行中的任何数据在下次执行时都是无关的

那么在 java上既然可能会出现问题,那么在使用递归时需要注意,尽量使用循环,或者在计算很小的数据时使用

在kotlin中,我们写成尾递归的时候,配合关键字 tailrec

如下:

tailrec fun sum(n: Int, res: Long): Long {
    if (n == 0) {
        return res;
    }
    return sum(n - 1, res + n)
}

测试代码

fun main(args: Array<String>) {

    val start = System.currentTimeMillis()
    val result = sum(Int.MAX_VALUE, 0)
    val end = System.currentTimeMillis()

    println(result)
    println("time:${end - start}")

}

Kotlin尾递归优化以及递归问题还没搞懂?

kotlin结果

结果和上面使用循环的结果一致时间上好像变短了

反编译kotlin生成的class文件

Kotlin尾递归优化以及递归问题还没搞懂?

kotlin生成的class

现在测试不加 tailrec 试试

Kotlin尾递归优化以及递归问题还没搞懂?

StackOverflowError

一样会溢出
再次反编译class查看

Kotlin尾递归优化以及递归问题还没搞懂?

kotlin class

代码并没有做优化因此在使用 kotlin 时,可以使用关键字 tailrec 来进行优化尾递归注意:必须是尾递归!!!

而使用 java编写时,尽量避免使用递归做深度的计算,可以使用循环代替!

总结

通过上面的介绍,相信大家对Kotlin尾递归方面有了进一步的认识,希望能够帮助到大家!

由于细节内容实在太多啦,所以只把部分知识点整理出来粗略的介绍

最近整理了一份Java核心知识点。覆盖了JVM、锁、并发、Java反射、Spring
原理、微服务、Zookeeper、数据库、数据结构等大量知识点。

如果需要免费获取到这个【资料】文档的话可以扫一扫下面


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值