kotlin-Android开发依赖库

这篇博客探讨了Kotlin标准库的不同版本,包括kotlin-stdlib、kotlin-stdlib-jdk7和kotlin-stdlib-jdk8。主要区别在于后两者针对JDK7和JDK8提供了额外的扩展功能。kotlin-stdlib是基础版本,而jdk7和jdk8版本则分别添加了对应JDK版本的特定扩展。通过源码分析,可以看到jdk7和jdk8版本包含了针对这些JDK版本的特定API扩展。文章还提到了如何选择和使用这些库,并提供了一个链接供进一步阅读。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

kotlin-stdlib 与 kotlin-stdlib-jdk7

在学习过程中发现引用kotlin依赖版本有kotlin-stdlib、kotlin-stdlib-jdk7

那么他们到底有什么区别呢?

1.第一步,百度搜索、谷歌搜索

没有搜到。。。

2.第二部,kotlin官网搜索

发现一句话

If you're targeting JDK 7 or JDK 8, you can use extended versions of the Kotlin standard library. They contain additional extension functions for APIs added in new JDK versions. Instead of kotlin-stdlib, use kotlin-stdlib-jdk7 or kotlin-stdlib-jdk8, depending on your JDK version.

翻译:

如果您的目标是 JDK 7 或 JDK 8,则可以使用 Kotlin 标准库的扩展版本。它们包含新 JDK 版本中添加的 API 的附加扩展功能。根据您的 JDK 版本,使用 kotlin-stdlib-jdk7 或 kotlin-stdlib-jdk8 代替 kotlin-stdlib
 这时看到还有一个jdk8版本,通过上面能了解到kotlin-stdlib是默认版本。jdk7或jdk8是对使用的对应jdk版本的一个扩展。

但是他们到底有什么区别呢?

3、第三步,看源码

(1)引用kotlin-stdlib

 kotlin-stdlib-jdk7

 kotlin-stdlib-jdk8

 查看多出来的包下边代码

此时明显能看出来,jdk7里面多出来的是有关jdk7的扩展代码。jdk8对应的是jdk7和jdk8部分的扩展代码。

4.第四步、寻找如何使用。

没研究出来。。。有小伙伴知道的告诉我一下,jdk8里的代码有一个类

PlatformThreadLocalRandom        不知道 为什么无法引用。
继续搜索,找到一篇文章介绍比较详细,大家可以参考

https://mbonnin.medium.com/the-different-kotlin-stdlibs-explained-83d7c6bf293

    //Core KTX 模块为属于 Android 框架的通用库提供扩展程序。
    implementation 'androidx.core:core-ktx:1.8.0'


     //旧版jre,新版使用jdk
    //implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:1.7.0"
    implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk8:1.7.0"
    
    //协程依赖:coroutines-core协程核心,coroutines-android协程Android
    implementation 'org.jetbrains.kotlinx:kotlinx-coroutines-core:1.6.1'
    implementation 'org.jetbrains.kotlinx:kotlinx-coroutines-android:1.6.1'
    
    //kotlin反射
    implementation "org.jetbrains.kotlin:kotlin-reflect:1.7.0"

    implementation 'javax.activation:activation:1.1.1'

### 如何在 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 功能,则务必集成对应的注解处理器支持。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值