Kotlin 尾递归函数

函数式编程中,重要的概念 尾递归

当一个函数 在最后调用 自身,称为 尾递归,是一种特殊的递归函数。

Kotlin 使用 tailrec 声明尾递归函数,可以避免 StackOverflowError 的风险。

原理是:通过编译器优化 为 循环GOTO 跳转,代替 原来递归调用。

在JVM中,每次方法调用时,都会产生新的栈帧(stack frame) ,消耗栈内存。当 调用层级过多时,就会产生 StackOverflowError 错误。

举例

计算 1 ~ N 的数之和。

kotlin 复制代码
tailrec fun sum(top: Long, initValue: Long): Long {
    return if (top <= 0) {
        initValue
    } else {
        sum(top - 1, initValue + top)
    }
}

fun main(args: Array<String>) {
    // 计算 100万 数字累加之和
    println("sum: ${sum(1_000_000L, 0)}")
}

说明:

1. idea 查看 编译代码,Show Kotlin Bytecode -> Decompile

2. 尝试把 tailrec 去掉,运行会 java.lang.StackOverflowError 错误

文档

相关推荐
缺点内向3 小时前
C#: 高效移动与删除Excel工作表
开发语言·c#·.net·excel
老前端的功夫3 小时前
Web应用的永生之术:PWA落地与实践深度指南
java·开发语言·前端·javascript·css·node.js
六件套是我4 小时前
redission实现延时队列
android·java·servlet
ᐇ9594 小时前
Java HashMap深度解析:数据结构、原理与实战指南
java·开发语言·数据结构
QT 小鲜肉5 小时前
【个人成长笔记】在 Linux 系统下撰写老化测试脚本以实现自动压测效果(亲测有效)
linux·开发语言·笔记·单片机·压力测试
程序员龙一5 小时前
C++之static_cast关键字
开发语言·c++·static_cast
yue0085 小时前
C# 分部类读取学生信息
开发语言·c#
奶茶树5 小时前
【C++/STL】map和multimap的使用
开发语言·c++·stl
聪明努力的积极向上5 小时前
【C#】事件简单解析
开发语言·c#