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 错误

文档

相关推荐
小池先生11 小时前
docker中的mysql变更宿主机映射端口
android·mysql·docker
小道士写程序11 小时前
如何简单理解状态机、流程图和时序图
java·开发语言·流程图
0wioiw011 小时前
Python基础(①③GIL全局解释器锁)
开发语言·python
VBA633711 小时前
VBA中类的解读及应用第二十七讲:利用类完成查找的方案-5
开发语言
2501_9301040411 小时前
C 盘清理技巧分享:释放磁盘空间,提升系统性能
c语言·开发语言
Prosper Lee12 小时前
前端基础(四十三):文本数据解析为键值对
开发语言·前端·javascript
yzx99101312 小时前
构建下一代互联网:解码Web3、区块链、协议与云计算的协同演进
c语言·开发语言·人工智能·自动化·区块链
obroccolio12 小时前
【C++题解】关联容器
开发语言·数据结构·c++·算法
NiKo_W12 小时前
C++11 类功能与包装器
开发语言·c++
FirstFrost --sy12 小时前
C++11 智能指针的使⽤及其原理
开发语言·c++·智能指针