kotlin标准函数指的是Standard.kt文件中定义的函数。本文将根据函数功能的相似性一个一个记录。这些标准函数本质上都是接收lambda参数的函数,下文为了方便理解和使用,在描述上将使用更为通俗形象的说法。目前标准函数一共只有11个,如果同名重载的只算一个那就连10个也不到。我们可将其大致分类为作用域函数(Scope Functions)、其他函数(除了作用域函数以外,其他函数没有具体的归类)。
作用域函数(Scope Functions)
我们先看下官方对于作用域函数的介绍:
作用域函数一共有5个,它们唯一的目的是在对象上下文环境中执行代码块。当你使用对象调用这些函数时,通过lambda表达式它们将给你提供一个临时作用域。在这个范围内你可以不通过该对象的名字访问该对象。这种函数称为作用域函数。基本上,这些函数的作用是相同的:在一个对象上执行一段代码。不同的是这个对象在块中是如何变得可用的,以及整个表达式的结果是什么。
我们先介绍这5个作用域函数(Scope Functions):let, run, with, apply, 和 also.
//这里的代码是为了下文介绍标准函数使用到的“辅助”对象
val things = mutableListOf("pineapple", "apple", "pen")
class Student {
var name: String = ""
var age: Int = 0
}
var xiaoxin: Student? = null
let函数
描述:某对象“创建”一个拥有该对象引用的代码区域。该引用在该区域的名字为“it”,返回值为最后一行的返回值,若最后一行无返回值则返回Unit(对应java中的void)。
常见用处:主要配合"?."操作符来进行辅助判空处理。
格式:
//由于全局变量可以在其他线程进行操作,所以将下面的let语句换成if判断语句仍然有空指针风险
val letResult = xiaoxin?.let {
println(it.name)
println(it.age)
xiaoxin.name
}
also函数
**描述:also函数和let函数极其的相似。唯一的不同就是返回值不同,let是将lambda最后一行的返回值作为返回值,而also则是将被操作对象本身作为返回值。
格式:
//下文中的this只是为了表示其上下文为StringBuilder()对象,可以省略
val letResult = xiaoxin?.also {
it.name = "xiao xin"
it.age = 18
}?.also {
println(it.name)
println(it.age)
}
run函数
**描述:run函数和let函数极其的相似。let是像将操作对象变成参数一样的操作,而run函数则提供了被操作对象的上下文环境,即通过“this”就可以调用被操作的对象(let函数中的it其实是lambda函数的参数)。而返回值也和let一样,返回最后一行。
格式:
//下文中的this只是为了表示其上下文为StringBuilder()对象,可以省略
val runResult = StringBuilder().run {
for (thing in things) {
this.append(thing).append("、")
}
this.toString()
}
run函数“重载”
**描述:除了上面描述的run函数外,作用域函数中run还有一个“重载”的函数,与前面的run函数不同,该“重载”函数并不是扩展函数,且不提供任何对象的上下文环境。它的使用看起来就像仅仅开辟了一块单独的区域执行某些语句。当然它仍然是讲最后一行的返回值作为该函数的返回值。
格式:
val run2Result = run {
val builder = StringBuilder()
for (thing in things) {
builder.append(thing).append("、")
}
builder.toString()
}
apply函数
**描述:apply函数和run函数极其的相似。同样的调用方式,同样提供上下文环境,唯一不通的是apply的返回值不是最后一行,而是被操作对象本身。
格式:
//下文中的this只是为了表示其上下文为StringBuilder()对象,可以省略
val applyResult = StringBuilder().apply {
for (thing in things) {
this.append(thing).append("、")
}
}
with函数
描述:with和上面几个函数有处明显的不同,上面几个函数都是扩展函数(由于被扩展的class为泛型形式表述,所以所有的对象都可以调用上面那些函数)。而with则是以传参的形式来操作对象(第一个参数为被操作对象,第二个为lambda函数)。同run、apply一样创造了一个具有操作对象上下文的环境。同run、let一样,最后一行为返回值。所以说with又和run极其相似,对于操作对象的获取一个是扩展函数的形式,一个是传参形式。
格式:
val withResult = with(StringBuilder()) {
for (thing in things) {
this.append(thing).append("、")
}
this.toString()
}
上面几个函数功能几乎完全一样,而且几乎所有的使用情景都可以互相替换,只有细微的使用方式不同,如何区分以及合理使用需要用户通过大量的经验和习惯来实现。
下一遍文章将介绍kotlin标准函数中剩下的几个函数(TODO,takeIf,takeUnless,repeat)
地址:https://www.jianshu.com/p/f9a7c2f1446b