kotlin-协成同步

先阐述需求,我需要在退出APP之前进行sp存储操作,由于sp存储耗时,如果sp数据过大,则会造成sp还未存储成功,APP就已经退出,这显然不符合需求

解决方案一、
        sp存储是有返回值的,可以查看源码,此时可以等待有返回值后再退出
此方案有一定局限性,很多项目sp都进行了封装,修改不易,此时可以讲代码进行同步操作,等待执行完成sp后再退出,即为方案二、

1.首先新增依赖
implementation 'androidx.lifecycle:lifecycle-runtime-ktx:2.2.0'//lifecycleScope implementation 'androidx.lifecycle:lifecycle-viewmodel-ktx:2.2.0'//viewModelScope

编辑我的demo

可以看到此时的执行顺序,通过 join方法阻塞代码,等待协成代码执行完后再执行后面的

再进行代码优化,可以这样

fun testLaunch(){
        runBlocking {
            val job = GlobalScope.launch {
                SpUtils.setLogin(false)
            }
            job.join()
            exitApp()
        }
    }

最终可实现 sp存储成功后再退出APP

### 如何在 Android 项目中应用 `kotlin-android`、`kotlin-kapt` 和 `kotlin-parcelize` 插件 #### 使用 `plugins {}` 块的方式 现代 Gradle 构建脚本推荐使用 `plugins {}` 块来声明插件。这种方式更加简洁明了,能够减少配置冲突的可能性。 以下是完整的 `build.gradle` 文件中的插件部分: ```gradle plugins { id 'com.android.application' // 或者 com.android.library 如果是库模块 id 'org.jetbrains.kotlin.android' id 'kotlin-kapt' id 'kotlin-parcelize' } ``` 上述方法适用于大多数场景,并且可以有效避免传统 `apply plugin:` 方式的潜在问题[^1]。 --- #### 调整插件顺序的重要性 如果仍然选择使用传统的 `apply plugin:` 方法,则需要注意插件的应用顺序。某些情况下,特定插件的加载依赖于其他插件已经完初始化的过程。例如,在引入 `kotlin-android-extensions` 的时候,通常需要先加载 `kotlin-android` 插件[^2]。 以下是一个典型的例子: ```gradle apply plugin: 'com.android.application' apply plugin: 'kotlin-android' apply plugin: 'kotlin-kapt' apply plugin: 'kotlin-parcelize' // apply plugin: 'kotlin-android-extensions' (已废弃) ``` 注意:`kotlin-android-extensions` 已被官方标记为弃用,建议改用 Jetpack Compose 或 View Binding 替代其功能[^3]。 --- #### 数据绑定支持 (`kotlin-kapt`) 当涉及到数据绑定(Data Binding)或者 Room 数据库等注解处理器时,必须显式地添加 `kotlin-kapt` 插件并正确配置相关依赖项。这是因为这些工具通过编译期生代码实现运行时的功能扩展[^5]。 示例配置如下所示: ```gradle dependencies { kapt "androidx.databinding:databinding-compiler:<version>" } plugins { id 'kotlin-kapt' } ``` 其中 `<version>` 应替换为当前项目的 Data Binding 版本号。 --- #### 组件化开发下的特殊需求 对于采用组件化架构的大型项目来说,可能需要动态判断当前模块是否属于应用程序入口点还是普通的库模块。此时可以通过根项目的全局变量控制插件的选择逻辑。 具体实现可参考以下片段: ```groovy if (rootProject.ext.android.isApplication) { apply plugin: 'com.android.application' } else { apply plugin: 'com.android.library' } plugins { id 'org.jetbrains.kotlin.android' id 'kotlin-kapt' id 'kotlin-parcelize' } ``` 此方案允许开发者灵活管理不同类型的子模块,而无需重复定义相同的构建规则。 --- #### 总结 为了确保最佳实践,请优先考虑利用 `plugins {}` 声明所需插件;同时留意各插件之间的兼容性和加载次序关系。针对高级特性如数据绑定或 Parcelize 功能,则务必集对应的注解处理器支持。 ---
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值