[kotlin] inline 函数

inline

inline函数是什么?

  • nline 函数,就是在编译时会把函数体和传入的 lambda 代码"展开"到调用处,而不是像普通函数一样生成函数调用。
    这样做的最大特点是:消除了高阶函数调用的性能损耗

inline函数解决了什么问题?

问题:高阶函数的性能损耗

  • 每次传 lambda,JVM 都会创建一个对象(匿名类),并有额外的函数调用开销。如果高阶函数用得多,性能损耗就明显了。
kotlin 复制代码
fun doSomething(action: () -> Unit) { action() }

解决方案:inline函数

  • Kotlin 的 inline 关键字告诉编译器:
    把函数体和传入的 lambda 代码直接展开到调用处,不用生成额外对象和函数调用。 这样 lambda 不再生成对象,也没有函数调用栈,性能几乎和普通代码一样高效。
kotlin 复制代码
inline fun doSomething(action: () -> Unit) { action() }

典型应用场景

  • 集合操作 (如 forEachmapfilter 等)都用 inline,提高性能。
  • DSL 设计:比如 Kotlin 的协程、Anko、Jetpack Compose 等,广泛用 inline 实现语法糖。

缺点

  • 代码膨胀(Code Bloat) :每次调用 inline 函数,都会把代码"展开",如果调用很多次,最终编译出的字节码会变大,影响 APK/程序体积。
  • 调试困难:因为函数被展开,调试时栈信息变得不直观。
  • 不能用递归:inline 函数不能递归调用自己,否则展开会无限循环。
  • 某些场景不能 inline :比如 lambda 被跨作用域保存(这时需要用 noinlinecrossinline 修饰)。

crossinline

crossinline

Kotlin 中用于 lambda 参数声明 的一个修饰符,主要用于 inline 函数

它的作用是:禁止在传入的 lambda 表达式中使用 non-local return ,即不能在 lambda 里直接用 return 跳出外层函数。

  • 场景 代码
kotlin 复制代码
inline fun foo(action: () -> Unit) {
    action() // 如果 action() 里 return,会直接退出 foo
}
fun test() {
    foo {
        return // 非本地 return,直接退出 test()
    }
}

crossinline 的作用

有些情况下,这种"非本地 return"是不安全或不允许的,比如你要把 lambda 存起来、用在另一个线程、或者作为参数传递。

这时就需要用 crossinline 修饰 lambda 参数,强制只允许局部 return(即只能退出 lambda 本身,不能跳出外层函数)。

kotlin 复制代码
inline fun doSomething(crossinline action: () -> Unit) {
    val runnable = Runnable { action() }
    runnable.run()
}
fun test() {
    doSomething {
        // return // 编译错误!不能在 crossinline lambda 里用非本地 return
        println("hello")
    }
}
相关推荐
AryaNimbus几秒前
你不知道的 Cursor系列(三):再也不用死记硬背 Linux 命令,终端 Cmd+K 来帮你!
前端·ai编程·cursor
uhakadotcom2 分钟前
Rollup 从0到1:TypeScript打包完全指南
前端·javascript·面试
Mintopia8 分钟前
实时语音转写 + AIGC:Web 端智能交互的技术链路
前端·javascript·aigc
2503_9284115610 分钟前
9.15 ES6-变量-常量-块级作用域-解构赋值-箭头函数
前端·javascript·es6
Pedantic11 分钟前
SwiftUI ShareLink – 显示分享表单的使用
前端
徐小夕16 分钟前
花了一天时间,开源了一套精美且支持复杂操作的表格编辑器tablejs
前端·算法·github
Mintopia17 分钟前
Next.js 单元测试究竟该选 JTest 还是 Vitest?
前端·javascript·next.js
Alice-YUE18 分钟前
【CSS学习笔记3】css特性
前端·css·笔记·html
bug_kada18 分钟前
告别页面卡顿!用DocumentFragment打造高性能DOM操作
前端
遂心_19 分钟前
深入浅出 querySelector:现代DOM选择器的终极指南
前端·javascript·react.js