Kotlin 中 also 方法的用法和使用场景

Kotlin 中 also 方法的用法和使用场景

1. 作用

also 是 Kotlin 标准库中的一个范围函数,用于对对象执行操作并返回该对象本身。它的主要作用是:

  • 提供一种简洁的方式对对象进行额外操作。
  • 返回值始终是调用 also 的对象本身。

语法:

kotlin 复制代码
object.also { it ->
    // 在这里可以对 object 进行操作
}
  • object :调用 also 的对象。
  • it :默认参数名,代表传入 also 的对象。
  • 返回值also 函数的返回值是调用它的对象本身。

2. 使用场景
场景 1:链式调用中插入日志或调试信息

在链式调用中,可以使用 also 插入日志或调试信息,而不会中断链式调用。

示例:

kotlin 复制代码
val result = fetchData()
    .also { SLog.d("Fetched data: $it") }
    .processData()
    .also { SLog.d("Processed data: $it") }
    .saveData()

在这个例子中,also 被用来记录每一步的操作结果,同时保持链式调用的完整性。


场景 2:对象初始化后立即执行操作

当创建一个对象后需要立即对其执行某些操作时,可以使用 also

示例:

kotlin 复制代码
val user = User().also {
    it.name = "Alice"
    it.age = 25
    SLog.d("User initialized: ${it.name}, ${it.age}")
}

如果没有 also,可能需要先创建对象,再单独设置属性,代码会显得冗长。


场景 3:避免重复调用对象

类似于 letalso 可以减少对同一个对象的重复调用。

示例:

kotlin 复制代码
val response = getResponse()
response.also { 
    if (it.isSuccess) {
        processSuccess(it.data)
    } else {
        handleError(it.error)
    }
}.saveToDatabase()

在这里,also 用于处理响应逻辑,而链式调用继续执行后续操作。


场景 4:apply 的区别

alsoapply 都可以在对象上执行操作,返回调用者本身:

  • apply:返回对象本身,适合用于对象初始化。
  • also:也返回对象本身,但更倾向于插入额外操作(如日志记录)。

对比示例:

kotlin 复制代码
val user = User().apply {
    name = "Alice"
    age = 25
} // 返回的是 User 对象

user.also {
    SLog.d("User created: ${it.name}, ${it.age}")
} // 返回的也是 User 对象,但主要用于插入额外操作

3. 注意事项
  • also 的返回值始终是调用它的对象本身。
  • 如果不需要返回值,可以选择使用 runlet 等其他范围函数。

4. 结合用户上下文的应用

AIDLSettingsService.kt 文件中,also 可以用于以下场景:

示例 1:日志记录

requestAsyn 方法中,可以使用 also 记录日志:

kotlin 复制代码
override fun requestAsyn(packageName: String?, jsonParams: String?) {
    LogUtil.i(LOG_TAG,"requestAsyn ----> packageName: $packageName jsonParams: $jsonParams callback.hashcode: ${mCallbackTemp[packageName]}")
    if (hasPermission()) {
        if (null != packageName && (packageName == PACKAGE_NAME || packageName == PACKAGE_NAME_SETTINGS || packageName == PACKAGE_NAME_SYSTEM_SETTINGS)) {
            mCallbackTemp[packageName]?.also {
                try {
                    SettingsServiceHelper.requestAsycn(jsonParams, it, this@AIDLSettingsService)
                } catch (e: Exception) {
                    if (BuildConfig.DEBUG) {
                        e.printStackTrace()
                    }
                    LogUtil.e(LOG_TAG,
                        "requestAsyn ----> packageName: $packageName jsonParams: $jsonParams", e
                    )
                }
            } ?: LogUtil.e(LOG_TAG,"requestAsyn ----> packageName: $packageName jsonParams: $jsonParams  no callback")
        }
    }
}
示例 2:对象初始化

onCreate 方法中,可以使用 also 初始化服务:

kotlin 复制代码
override fun onCreate() {
    super.onCreate()
    startForeground()
    AppUtil.initSDK(application).also {
        SLog.d("SDK initialized: $it")
    }
    LogUtil.i(LOG_TAG, "onCreate")
    VRSettingsManager.create(this).also {
        SLog.d("VRSettingsManager created: $it")
    }
    createNotificationChannel()
}

总结来说,also 是一个非常实用的工具,尤其在需要对对象执行额外操作而不中断链式调用时,能够显著提升代码的可读性和简洁性。

相关推荐
鹏北海9 分钟前
多标签页登录状态同步:一个简单而有效的解决方案
前端·面试·架构
_AaronWong14 分钟前
基于 Vue 3 的屏幕音频捕获实现:从原理到实践
前端·vue.js·音视频开发
孟祥_成都22 分钟前
深入 Nestjs 底层概念(1):依赖注入和面向切面编程 AOP
前端·node.js·nestjs
let_code23 分钟前
CopilotKit-丝滑连接agent和应用-理论篇
前端·agent·ai编程
Apifox1 小时前
Apifox 11 月更新|AI 生成测试用例能力持续升级、JSON Body 自动补全、支持为响应组件添加描述和 Header
前端·后端·测试
木易士心1 小时前
深入剖析:按下 F5 后,浏览器前端究竟发生了什么?
前端·javascript
在掘金801101 小时前
vue3中使用medium-zoom
前端·vue.js
xump1 小时前
如何在DevTools选中调试一个实时交互才能显示的元素样式
前端·javascript·css
折翅嘀皇虫1 小时前
fastdds.type_propagation 详解
java·服务器·前端
Front_Yue1 小时前
深入探究跨域请求及其解决方案
前端·javascript