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对象
}

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

相关推荐
WeiXiao_Hyy32 分钟前
成为 Top 1% 的工程师
java·开发语言·javascript·经验分享·后端
吃杠碰小鸡1 小时前
高中数学-数列-导数证明
前端·数学·算法
kingwebo'sZone1 小时前
C#使用Aspose.Words把 word转成图片
前端·c#·word
xjt_09011 小时前
基于 Vue 3 构建企业级 Web Components 组件库
前端·javascript·vue.js
我是伪码农1 小时前
Vue 2.3
前端·javascript·vue.js
夜郎king2 小时前
HTML5 SVG 实现日出日落动画与实时天气可视化
前端·html5·svg 日出日落
辰风沐阳2 小时前
JavaScript 的宏任务和微任务
javascript
夏幻灵3 小时前
HTML5里最常用的十大标签
前端·html·html5
冰暮流星3 小时前
javascript之二重循环练习
开发语言·javascript·数据库
Mr Xu_3 小时前
Vue 3 中 watch 的使用详解:监听响应式数据变化的利器
前端·javascript·vue.js