当前位置: 代码网 > 科技>软件教程>工具软件 > 编程语言 Kotlin 2.0.0 现已发布,K2 编译器进入稳定状态

编程语言 Kotlin 2.0.0 现已发布,K2 编译器进入稳定状态

2024年05月27日 工具软件 我要评论
JetBrains 官方宣布 Kotlin 2.0.0 正式发布,其代码已上传到 GitHub 库。

5 月 22 日消息,jetbrains 官方宣布 kotlin 2.0.0 正式发布,其代码已上传到 github 库。

kotlin 2.0 亮点

k2 编译器现已进入稳定状态

默认用于所有平台(jvm、native、wasm 和 js),且性能显著提升。性能方面,jetbrains 团队编译了 1000 万行代码以确保其质量稳定,涉及 18,000 多名开发人员和 80,000 多个项目。

ide 支持

新版 kotlin 插件已集成在 intellij idea 和 android studio 中。

新 compose 编译器已集成 gradle 插件

从 kotlin 2.0.0 开始,org.gradle.jvm.environmentgradle 属性默认会与 kotlin 版本一同公布,从而更好地区分 kotlin 多平台库的 jvm 和 android 版本。

kotlinx-metadata-jvm 库:

kotlinx-metadata-jvm 库现已进入稳定状态

lambda 函数:

kotlin 2.0.0 引入了一种使用生成 lambda 函数的新默认方法“invokedynamic”,可生成更小的二进制文件。

使用 apple 平台上的标记(signposts)监控 kotlin / native 中的 gc 性能

以前,开发者只能通过查看日志来监控 kotlin / native 的垃圾回收器 (gc) 的性能。然而,这些日志并未集成到 xcode instruments 中(后者是一款用于调试 ios 应用性能问题的工具包)。从 kotlin 2.0.0 开始,gc 会通过 instruments 中提供的特殊标记来报告暂停,从而允许在应用程序内进行自定义日志记录。

使用 objective-c 方法解决 kotlin / native 中的冲突:

objective-c 方法可以用不同的名称,但必须具有相同的数量和类型参数。例如,locationmanager:didenterregion:locationmanager:didexitregion:。在 kotlin 中,它们都具有相同的签名,因此尝试使用时也会触发冲突重载报错。

放在以前,开发者必须手动解决冲突才能避免此编译错误,而为了改善 kotlin 与 objective-c 的互操作性,kotlin 2.0.0 引入了新的 @objcsignatureoverride 注释。该注释会指示 kotlin 编译器忽略冲突的重载,以防从 objective-c 类继承多个具有相同参数类型但参数名称不同的函数。

支持 kotlin / wasm 中的命名导出:

支持命名导出和无符号原始类型的 @jsexport 函数,从而提高了可读性,并帮助开发者更好地管理模块之间的依赖关系,还能使 kotlin 和 javascript 模块之间的代码共享更容易。

此外, kotlin 2.0.0 还支持生成 kotlin / wasm 中 typescript 声明文件(代码网注:实验性功能,可能会随时被删),能够根据 @jsexport kotlin 代码中的声明生成 typescript 定义,从而让 ide 和 javascript 工具使用这些定义来提供代码自动补完功能。

默认使用 binaryen 优化生产版本:

kotlin / wasm 工具链现在会在生产编译过程中对所有项目默认应用 binaryen 工具,而无需进行手动设置。官方估计,这将进一步改善项目的运行时性能并减小二进制文件大小。当然,此更改仅影响生产编译。开发编译过程保持不变。

用于多平台项目中编译器选项的新 gradle dsl 实验性功能(可能随时被删):

kotlin 2.0.0 引入了全新的 gradle dsl,可用于在多平台项目中更轻松地配置编译选项。此前在 kotlin 中使用 gradle 配置编译选项只能针对较低的层面,例如单个任务、编译过程或源代码集。有了这个新的 gradle dsl,您就可以直接设置全局配置编译选项。

替换枚举类值泛型函数的稳定方式

在 kotlin 2.0.0 中,访问枚举类值的方式变得更加稳定。kotlin 2.0.0 引入了新的专门用于枚举的稳定函数 enumentries<t>(),可返回给定枚举类型 t 的所有枚举条目列表。

kotlin 之前还引入了一个枚举类的属性 entries,目前已经进入稳定状态并将与上述函数一起替代“不再推荐使用”的 values ()。

稳定的 autocloseable 接口

自 kotlin 2.0.0 开始,开发者常用的 autocloseable 接口宣布进入稳定状态,它可以允许开发者轻松关闭资源,并包含两种有用的函数:

  • use () 扩展函数,用于在选定的资源上执行给定的块函数,并保证能够在无论是否抛出异常的状态下都能正确关闭相关资源。

  • autocloseable () 构造函数,用于创建 autocloseable 接口的实例。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com