apply
apply 函数接收一个目标并回来该目标自身。它答应您在目标上履行一些操作,同时仍然回来原始目标。
fun <T> T.apply(block: T.() -> Unit): T
T 是目标的类型,block 是一个 lambda 表达式,能够在该目标上履行一些操作。在这个 lambda 中,您能够运用 this 关键字来引证当时目标。
val person = Person().apply {
name = "John"
age = 30
address = "New York"
}
在这个例子中,咱们创建了一个 Person 目标并在 apply 函数中设置了该目标的特色。最终回来的是这个 Person 目标自身。
let
let 同样是一个扩展函数,它也接收一个 Lambda 表达式作为参数。不同于 apply,在 Lambda 表达式中,let 函数将接收者目标作为 Lambda 的参数,一般用 it 作为隐式称号。let 函数的回来值是 Lambda 表达式的成果。
fun <T, R> T.let(block: (T) -> R): R
T 是目标的类型,R 是回来值的类型,block 是一个 lambda 表达式,它对该目标进行一些操作并回来一个成果。
val person = Person("Alice", 25)
val ageAfterFiveYears = person.let {
it.age + 5
}
在这个示例中,let 函数用于核算 Person 目标五年后的年纪。
also
also 是一个扩展函数,与 apply 相似,但有一个关键区别:also 函数的回来值是接收者目标自身,而 Lambda 表达式的参数是接收者目标,一般用 it 作为隐式称号。
fun <T> T.also(block: (T) -> Unit): T
T 是目标的类型,block 是一个 lambda 表达式,能够在该目标上履行一些操作。在这个 lambda 中,您能够运用 it 关键字来引证当时目标。
val person = Person("Alice", 25).also {
it.name = "Bob"
it.age = 30
}
在上述示例中,also 函数用于修正 Person 类的特色,最终回来修正后的目标。
run
run 是一个扩展函数,它结合了 apply 和 let 的特色。run 函数在 Lambda 表达式中直接访问接收者目标的特色和方法,同时回来 Lambda 表达式的成果。
fun <T, R> T.run(block: T.() -> R): R
T 是目标的类型,R 是回来值的类型,block 是一个 lambda 表达式,它对该目标进行一些操作并回来一个成果。在这个 lambda 中,您能够运用 this 关键字来引证当时目标。
val person = Person("Alice", 25)
val greeting = person.run {
"Hello, $name! You are $age years old."
}
在这个示例中,run 函数用于生成一个包括 Person 目标信息的字符串。
总结
with
不怎么使用,因为它确实不防空; 经常使用的是
run和
apply
- run 闭包返回结果是闭包的执行结果;apply 返回的是调用者本身。
- 使用上的差别:run 更倾向于做一些其他复杂逻辑操作,而 apply 更多的是对调用者自身配置。
- 大部分情况下,如果不是对调用者本身进行设置,我会使用 run。