美文网首页
kotlin:标准函数之作用域函数(Scope Function

kotlin:标准函数之作用域函数(Scope Function

作者: Yapple | 来源:发表于2020-05-12 18:48 被阅读0次
    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

    相关文章

      网友评论

          本文标题:kotlin:标准函数之作用域函数(Scope Function

          本文链接:https://www.haomeiwen.com/subject/thtlnhtx.html