koltin的常用操作符(参考他人进行整理,用于个人笔记)
- 内联扩展函数之 let
- 内联扩展函数之 with
- 内联扩展函数之 apply
- 内联扩展函数之 run
- 内联扩展函数之 also
- 内联扩展函数之 use
一、内联扩展函数之 let
1. let函数底层的inline扩展函数+lambda结构
@kotlin.internal.InlineOnly
public inline fun <T, R> T.let(block: (T) -> R): R = block(this)
2. let函数的使用的一般结构
object.let{
it.todo()//在函数体内使用it替代object对象去访问其公有的属性和方法
...
}
//另一种用途 判断object为null的操作
object?.let{//表示object不为null的条件下,才会去执行let函数体
it.todo()
}
3. let函数适用的场景
- 从源码let函数的结构来看它是只有一个lambda函数块block作为参数的函数,调用T类型对象的let函数,则该对象为函数的参数。在函数块内可以通过 it 指代该对象。返回值为函数块的最后一行 或指定 return表达式。
- 使用场景
场景一: 最常用的场景就是使用let函数处理需要针对一个可null的对象统一做判空处理。
场景二: 然后就是需要去明确一个变量所处特定的作用域范围内可以使用。
二、内联函数之with
1. with函数底层的inline扩展函数+lambda结构
@kotlin.internal.InlineOnly
public inline fun <T, R> with(receiver: T, block: T.() -> R): R = receiver.block()
2. with函数使用的一般结构
Object object = new Object()
object.name="张三"
object.age()
// 相比于let 省略了 it 但是使用 最好先判断非空 object !=null
with(object){
name="张三"
age()
}
3. with函数的适用的场景
- with函数和前面的几个函数使用方式略有不同,因为它不是以扩展的形式存在的。它是将某对象作为函数的参数,在函数块内可以通过 this 指代该对象。返回值为函数块的最后一行 或指定 return表达式。
- 适用于调用同一个类的多个方法时,可以省去类名重复,直接调用类的方法即可,经常用于Android中RecyclerView中onBinderViewHolder中,数据model的属性映射到UI上
三、内联扩展函数之apply
1. apply函数的inline+lambda结构
@kotlin.internal.InlineOnly
public inline fun <T> T.apply(block: T.() -> Unit): T { block(); return this }
2. apply函数使用的一般结构
Object object = new Object()
object.name="张三"
object.age()
// 和with 基本相似 ,但是可以直接 ?. 方式判断非空
object?.{
name="张三"
age()
}
3. apply函数的适用场景
- 它返回的值是 对象本身。
- apply一般用于一个对象实例初始化的时候,需要对对象中的属性进行赋值。或者动态inflate出一个XML的View的时候需要给View绑定数据也会用到,这种情景非常常见。特别是在我们开发中会有一些数据model向View model转化实例化的过程中需要用到。
四、内联扩展函数之apply
1. run函数的inline+lambda结构
@kotlin.internal.InlineOnly
public inline fun <T, R> T.run(block: T.() -> R): R = block()
2.run函数使用的一般结构
Object object = new Object()
object.name="张三"
object.age()
// 和with ,apply 基本相似 ,但是可以直接 ?. 方式判断非空 、返回值不一样
// apply 返回传入对象本身。
object?.{
name="张三"
age()
}
3. run函数的适用场景
- 适用于let,with函数任何场景。因为run函数是let,with两个函数结合体,准确来说它弥补了let函数在函数体内必须使用it参数替代对象,在run函数中可以像with函数一样可以省略,直接访问实例的公有属性和方法>
- 另一方面它弥补了with函数传入对象判空问题,在run函数中可以像let函数一样做判空处理。
五、内联扩展函数之also
1. also函数的inline+lambda结构
@kotlin.internal.InlineOnly
@SinceKotlin("1.1")
public inline fun <T> T.also(block: (T) -> Unit): T { block(this); return this }
2. also函数使用的一般结构
object.also{
it.todo()//在函数体内使用it替代object对象去访问其公有的属性和方法
...
}
//另一种用途 判断object为null的操作
//而also函数返回的则是传入对象的本身
object?.also{//表示object不为null的条件下,才会去执行also函数体
it.todo()
}
3. also函数的适用场景
- 和let函数类似
- 适用于let函数的任何场景,also函数和let很像,只是唯一的不同点就是let函数最后的返回值是最后一行的返回值而also函数的返回值是返回当前的这个对象。一般可用于多个扩展函数链式调用
六、use 的使用
1. use的用法
//读取文件方式一
val br = BufferedReader(FileReader("hello.txt")) //打开文件读取
with(br) { //对br中的属性和方法直接进行操作
var line: String?
while (true) {
line = readLine() ?: break //读取一行数据,若为空则退出循环
println(line) //打印读取的数据
}
close() //关闭文件读取
}
//读取文件方式二
BufferedReader(FileReader("hello.txt")).use {
var line: String?
while (true) {
line = it.readLine() ?: break //读取一行数据,若为空则退出循环
println(line) //打印读取的数据
}
}
//读取文件方式三
println(BufferedReader(FileReader("hello.txt")).readText()) //最简单的读取文件的方法
2. use的使用总结
- 一般使用与文件流的操作,且不需要 关闭流 close()