Kotlin 中let 、run 、with、apply、also的用法与区别

实例代码

Kotlin 复制代码
User(val userName:String,val age:Int){

    fun printName(){
        println(userName)
    }


    fun getUserName():String{
        return userName
    }

}

let 函数

let 函数常用来与对象的空判断一起用,起到作用于的限定效果。let 函数最后一行返回值。(比如实例需要let函数返回一个处理后的字符串值,则最后一行直接返回一个字符串)

Kotlin 复制代码
val param:User? = null

//let 的用法,判空
val uName = param?.let{//it
    //在这个闭包内部 it 指代非空的param 参数
    it.printName()

    //闭包内最后一个代码执行的结果即为返回值
    it.getUserName()   //返回一个字符串对象
}

run 函数

run 函数和let 函数非常相似,但是有一点不同:闭包内部不再像let函数中指定it代表对象,run 函数的闭包直接是this,可以简单理解为 run 方法扩展函数内部代用该对象的任何函数和属性就是在该对象内部调用一样,不再需要通过实例对象。看代码:

Kotlin 复制代码
val param:User? = null


val uName= param?.run{ //this
    //在这个闭包内部 this 指代非空的User 对象
    printName()  //因为run 内部所有调用都相当于在User对象内部,所以可以不用this
    this.printName()    

    //闭包内最后一个代码执行的结果即为返回值
    this.getUserName()   //返回一个字符串对象.
}

with 函数

适用于调用同一个类的多个方法时,可以省去类名重复,直接调用类的方法即可,有点和run方法相似,但是with函数不是一个扩展函数,是一个一般函数,直接调用。返回值仍然是最后一行代码执行的结果。

Kotlin 复制代码
val param:User? = null


val uName= with(param){ //this
    //在这个闭包内部 this 指代非空的User 对象
    printName()  //因为with 内部所有调用都相当于在User对象内部,所以可以不用this
    this.printName()    

    //闭包内最后一个代码执行的结果即为返回值
    this.getUserName()   //返回一个字符串对象.
}

apply 函数

apply 有点类似于 with 与run 的结合,但是不同的是返回值不再是代码的最后一行的结果,而是返回对象本身。

Kotlin 复制代码
val param:User? = null

val newUser:User? = null 

val newUser = param?.apply{ //this
    //在这个闭包内部 this 指代非空的User 对象
    printName()  //因为apply 内部所有调用都相当于在User对象内部,所以可以不用this
    this.printName()    

    this.getUserName()   //这里不再返内容,而是直接返回param对象
}

also 函数

also 有点类似于let 与run 的结合,但是不同的是返回值不再是代码的最后一行的结果,而是返回对象本身,闭包内部不再是this对象而是it

Kotlin 复制代码
val param:User? = null

val newUser:User? = null 

val newUser = param?.apply{ //it
    //在这个闭包内部 it指代非空的param 对象
    it.printName()

    it.getUserName()   //这里不再返内容,而是直接返回param对象
}

这个方法非常类似,灵活应用即可。主要却别返回值和闭包内的作用域

相关推荐
笑醉踏歌行2 小时前
NVM 在安装老版本 Node环境时,无法安装 NPM的问题
前端·npm·node.js
YUJIANYUE2 小时前
Gemini一次成型龙跟随鼠标html5+canvas特效
前端·计算机外设·html5
abiao19812 小时前
npm WARN ERESOLVE overriding peer dependency
前端·npm·node.js
TechExplorer3652 小时前
禁用 npm 更新检查
前端·npm·node.js
行云流水6265 小时前
uniapp pinia实现数据持久化插件
前端·javascript·uni-app
zhangyao9403305 小时前
uniapp动态修改 顶部导航栏标题和右侧按钮权限显示隐藏
前端·javascript·uni-app
福尔摩斯张7 小时前
Axios源码深度解析:前端请求库设计精髓
c语言·开发语言·前端·数据结构·游戏·排序算法
aiguangyuan7 小时前
React 中什么是可中断更新?
javascript·react·前端开发
李牧九丶8 小时前
从零学算法1334
前端·算法