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

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

相关推荐
一只小阿乐5 分钟前
react 封装弹框组件 传递数据
前端·javascript·react.js
533_27 分钟前
[element-plus] el-tree 动态增加节点,删除节点
前端·javascript·vue.js
禁止摆烂_才浅32 分钟前
前端开发小技巧-【JavaScript】- 获取元素距离 document 顶部的距离
前端·javascript·react.js
wshzd33 分钟前
LLM之Agent(二十九)|LangChain 1.0核心组件介绍
前端·javascript·langchain
程序猿_极客37 分钟前
Vue 2脚手架从入门到实战核心知识点全解析(day6):从工程结构到高级通信(附代码讲解)
前端·javascript·vue.js·vue2学习笔记
q***71851 小时前
海康威视摄像头ISUP(原EHOME协议) 摄像头实时预览springboot 版本java实现,并可以在浏览器vue前端播放(附带源码)
java·前端·spring boot
一只小阿乐1 小时前
vue3 使用v-model开发弹窗组件
javascript·vue.js·elementui
web加加1 小时前
vue3 +vite项目页面防f12,防打开控制台
前端·javascript·vue.js
A尘埃2 小时前
大模型应用python+Java后端+Vue前端的整合
java·前端·python
遥遥晚风点点2 小时前
Spark导出数据文件到HDFS
前端·javascript·ajax