1.apply函数
apply
函数用于对一个对象进行配置操作。在apply
函数内部的this
关键字指代这个对象,和run
函数类似,则会返回配置好的接收者。apply
能让每个配置函数都作用于接收者,这种行为又叫相关作用域。配置函数是针对接收者的隐式调用。
fun main() {
var file = File("D://file.txt").apply {
setReadable(true)
setWritable(true)
}
}
适用场景:常用于对象的初始化配置。
2.let函数
主要用于对一个非空对象进行操作,let函数能使某个变量作用于lambda表达式里面,让it
关键字能够引用它。并且let函数的返回值是 lambda 表达式的最后一行的返回值。
函数 | 参数 | 返回值 |
---|---|---|
let | 接收者对象 | lambda表达式的最后一行 |
apply | -- | 当前接收者 |
fun main() {
val ret = listOf<Int>(5,2,1).last().let {
it.shl(2)
}
println(ret)
}
适用场景:常用于对一个对象进行一系列操作后返回一个新的结果。
3.run函数
从作用域行为上看,run
函数和apply
类似,但在返回结果上又不相同,apply
返回接收者,而run
返回的是lambda表达式的执行结果,从返回值上看类似let。run
函数内部的this
关键字指代的是这个对象。另外,run
函数还可以执行函数的引用。
fun main() {
val ret = "Welcom,zhh".run {
contains("zh")
length
}
println(ret)
//执行函数的引用
20.run(::getAge)
.run(::getName)
.run(::println)
}
private fun getAge(age:Int) = "年龄:$age"
private fun getName(name:String) = "名字:$name"
应用场景:当需要在一个对象的上下文中执行多个操作并且返回一个最终结果时很有用。
4.with函数
是run
函数的变体,他们的行为一致。主要的区别在于with
函数的第一个参数是要操作的对象,而不是像run
函数那样在接收者对象上调用。
fun main() {
//值参作为第一个参数传入
val ret = with("Hello,Kotlin"){
length > 5
}
println(ret)
}
适用场景:适用于对一个对象进行一组相关操作的场景。
5.also函数
also
和let
类似,把接收者当中值参传给lambda表达式,并且可以在 lambda 表达式中使用it
关键字来指代这个对象,但在返回值上有所不同,also
返回的是接收者对象,而let返回的是lambda表达式的执行结果。鉴于此区别,also经常作用于同一个原始对象
fun main() {
var list : List<String>
File("D://file.txt")
.also {
println(it.name)
}.also {
it.setReadable(true)
}.also {
list = it.readLines()
}
println(list)
}
适用场景:当需要在对一个对象进行操作的同时,还能继续使用这个原始对象时很有用。
6.takeIf函数
takeIf函数与其他标准函数有所不同,它需要判断lambda表达式中提供的条件表达式,给出true或false结果,如果判断是true,则返回接收者对象,否则返回null。该函数主要用在先判断某个条件是否满足,再执行的场景中。类似与If
fun main() {
val ret = File("D://file.txt").takeIf {
it.exists() && it.canRead()
}?.readText()
println(ret)
}
7.takeUnless函数
是takeIf的辅助函数,只有给定的条件判断结果为false,takeUnless才会返回原始接收者对象。
fun main() {
//不满足条件时,才执行后续
val ret = File("D://file.txt").takeUnless {
it.isHidden
}?.readText()
println(ret)
}
欢迎留言大家互相交流学习!
示例源码地址kotlin_demo