Kotlin 标准函数 with
、run
、apply
的定义和使用
1. with
函数
定义:
with
函数允许你在一个对象的上下文中执行一个 lambda 表达式,而不需要在 lambda 表达式中重复引用该对象。
|---|--------------------------------------------------------------------------------------|
| | @kotlin.internal.InlineOnly
|
| | public inline fun <T, R> with(receiver: T, block: T.() -> R): R = receiver.block()
|
使用场景:
当你需要在多个地方引用同一个对象,并且不想每次都显式地写出这个对象名时,可以使用 with
函数。
示例:
|---|------------------------------------------------|
| | val stringBuilder = StringBuilder()
|
| | with(stringBuilder) {
|
| | append("Hello")
|
| | append(", ")
|
| | append("World!")
|
| | }
|
| | println(stringBuilder) // 输出 "Hello, World!"
|
2. run
函数
定义:
run
是 Kotlin 中所有类的成员函数,用于在当前对象的上下文中执行一个 lambda 表达式,但不返回任何值(返回 Unit
)。
虽然这不是显式定义的函数,但它是通过扩展函数为所有类隐式提供的。
使用场景:
当你需要在对象的上下文中执行一些操作,但不需要返回任何结果时,可以使用 run
。
示例(虽然不常见,因为可以直接在对象上调用方法):
|---|------------------------------------------------|
| | val stringBuilder = StringBuilder()
|
| | stringBuilder.run {
|
| | append("Hello")
|
| | append(", ")
|
| | append("World!")
|
| | }
|
| | println(stringBuilder) // 输出 "Hello, World!"
|
3. apply
函数
定义:
apply
是 Kotlin 的一个扩展函数,它执行给定的 lambda 表达式,并返回调用它的对象本身。
|---|----------------------------------------------------------------------------------|
| | public inline fun <T> T.apply(block: T.() -> Unit): T { block(); return this }
|
使用场景:
当你需要在对象的上下文中执行一些操作,并希望返回该对象以便进行链式调用时,可以使用 apply
。
示例:
|---|------------------------------------------------|
| | val stringBuilder = StringBuilder().apply {
|
| | append("Hello")
|
| | append(", ")
|
| | append("World!")
|
| | }
|
| | println(stringBuilder) // 输出 "Hello, World!"
|
区别
with
:接受一个对象和一个 lambda 表达式,在 lambda 表达式中可以直接调用该对象的方法,无需前缀。返回 lambda 表达式的返回值。run
:是类的成员函数,接受一个 lambda 表达式,在 lambda 表达式中可以直接调用该对象的方法。返回Unit
。apply
:是扩展函数,接受一个 lambda 表达式,在 lambda 表达式中可以直接调用该对象的方法。返回调用它的对象本身。
定义静态方法
在 Kotlin 中,没有直接的"静态方法"概念,但你可以通过以下几种方式实现类似的功能:
- 顶层函数:在文件的顶层定义的函数可以在没有类实例的情况下调用。
|---|--------------------------------------------------------------------------------------------|
| | // MyUtils.kt
|
| | fun staticLikeFunction() {
|
| | // ...
|
| | }
|
| | |
| | // 在其他文件中
|
| | MyUtilsKt.staticLikeFunction() // 注意:Kotlin 会为顶层函数生成一个包含文件名的类(除非你用 @file:JvmName 指定一个名称)
|
- 对象表达式或对象声明:你可以创建一个单例对象,并在其中定义函数。
|---|-------------------------------------------|
| | object MyUtils {
|
| | @JvmStatic // 如果你希望这个函数在 Java 中看起来像静态的
|
| | fun staticLikeFunction() {
|
| | // ...
|
| | }
|
| | }
|
| | |
| | // 调用
|
| | MyUtils.staticLikeFunction()
|