您的位置:首页 > IT > 正文

Kotlin 1.9.0 正式发布|世界速递

来源:OSCHINA     时间:2023-07-07 15:42:35

Kotlin 1.9.0 版本已正式发布,JVM 的 K2 编译器现已处于测试阶段。此版本包含新的语言功能以及 Kotlin Multiplatform 和 Kotlin/Native 的改进。

以下是此版本的重要内容:

新的 Kotlin K2 编译器更新

Kotlin 团队继续稳定 K2 编译器,1.9.0 版本引入了进一步的改进。 JVM 的 K2 编译器现在处于 Beta 阶段。


【资料图】

现在已提供对 Kotlin/Native 和多平台项目的基本支持。

枚举类值函数的稳定替换

在 1.8.20 中,枚举类的entries属性作为实验功能引入。entries属性是values()函数的现代且高性能的替代品。

在 1.9.0 中,entries属性已经稳定。虽然仍支持 values() 函数,但官方建议改用 entries 属性。

enum class Color(val colorName: String, val rgb: String) {    RED("Red", "#FF0000"),    ORANGE("Orange", "#FF7F00"),    YELLOW("Yellow", "#FFFF00")}fun findByRgb(rgb: String): Color? = Color.entries.find { it.rgb == rgb }

用于开放式范围的稳定 ..< 运算符

用于开放式范围的新..<运算符在 Kotlin 1.7.20 中引入,并在 1.8.0 中变得稳定。在 1.9.0 中,用于处理开放式范围的标准库 API 也已稳定。

新的..<运算符使声明开放式范围时更容易理解。如果使用until函数,很容易被错误地理解成包含上限。

以下是使用until函数的示例:

fun main() {    for (number in 2 until 10) {        if (number % 2 == 0) {            print("$number ")        }    }    // 2 4 6 8}

这是使用新的..<运算符的示例:

fun main() {    for (number in 2..<10) {        if (number % 2 == 0) {            print("$number ")        }    }    // 2 4 6 8}

新的通用函数:通过名称获取正则表达式捕获组

在 1.9.0 中有一个通用函数groups,可以使用它通过正则表达式匹配的名称检索组的内容。在想要访问属于特定捕获组的正则表达式匹配结果时,这非常有用。

以下是包含三个捕获组的正则表达式的示例:citystateareaCode。可以使用这些组名称来访问匹配的值:

fun main() {    val regex = """\b(?[A-Za-z\s]+),\s(?[A-Z]{2}):\s(?[0-9]{3})\b""".toRegex()    val input = "Coordinates: Austin, TX: 123"    val match = regex.find(input)!!    println(match.groups["city"]?.value)    // Austin    println(match.groups["state"]?.value)    // TX    println(match.groups["areaCode"]?.value)    // 123}

用于创建父目录的新路径实用程序

1.9.0 中,有一个新的扩展函数createParentDirectories(),可以使用它来创建包含所有必需父目录的新文件。

createParentDirectories()在复制文件时特别有用。例如,您可以将其与copyToRecursively()函数结合使用:

sourcePath.copyToRecursively(   destinationPath.createParentDirectories(),   followLinks = false)

Kotlin 多平台中的 Gradle 配置缓存预览

Kotlin 1.9.0 支持多平台库中的 Gradle 配置缓存,库作者已经可以从改进的构建性能中受益。Gradle 配置缓存通过在后续构建中重用配置阶段的结果来加快构建过程。自 Gradle 8.1 以来,该功能已变得稳定。

注意:Kotlin Multiplatform 插件仍然不支持带有 Xcode 集成任务的 Gradle 配置缓存或 Kotlin CocoaPods Gradle 插件。

Kotlin 多平台中对 Android 目标的更改

将来,Google 的 Android 团队将提供自己的 Gradle 插件,以在 Kotlin 多平台中支持 Android。为了给 Google 让出名称, 1.9.0 中重命名了当前 Kotlin DSL 中的android块,将构建脚本中出现的所有android块更改为androidTarget

这是一项临时更改,仅针对从 Google 中释放即将推出的 DSL 的android名称,后续Google 的插件将成为在多平台项目中使用 Android 的首选方式。

Kotlin/Native 中自定义内存分配器(预览版)

Kotlin 1.9.0 引入了自定义内存分配器的预览版,该分配系统提高了 Kotlin/Native 内存管理器的运行时性能。它将系统内存划分为多个页面,允许按连续顺序进行独立清理。每次分配都会成为页面内的一个内存块,并且页面会跟踪块大小。

新的分配器允许同时拥有多个独立的分配空间,允许 Kotlin 团队尝试不同的页面布局,以进一步提高性能。

Kotlin/Native 中的库链接

从 Kotlin 1.9.0 开始,Kotlin/Native 编译器以与 Kotlin/JVM 相同的方式处理 Kotlin 库中的链接问题。

如果第三方 Kotlin 库之间出现链接问题,构建在编译期间不会失败。相反,只会在运行时遇到这些错误,就像在 JVM 上一样。

Kotlin/Native 编译器每次检测到库链接问题时都会报告警告。您可以在编译日志中找到此类警告,例如:

No function found for symbol "org.samples/MyRemovedClass.doSomething|3657632771909858561[0]"Can not get instance of singleton "MyEnumClass.REMOVED_ENTRY": No enum entry found for symbol "org.samples/MyEnumClass.REMOVED_ENTRY|null[0]"Function "getMyRemovedClass" can not be called: Function uses unlinked class symbol "org.samples/MyRemovedClass|null[0]"

Kotlin/Wasm 中与文件大小相关的优化

Kotlin 1.9.0 为 WebAssembly (Wasm) 项目引入了显着的文件大小改进。比个“Hello World”项目,Kotlin 1.9.0 中 Wasm 的代码占用量现在比 Kotlin 1.8.20 中小 10 倍以上。

当针对具有 Kotlin 代码的 Wasm 平台时,这些大小优化可以提高资源利用率并提高性能。

有关更改的完整列表,请参阅 Kotlin 1.9.0 中的新增功能或 GitHub 上的发行说明。

相关文章