写点什么

Kotlin 1.9.0 发布:带来多项新的语言特性,改进 Multiplatform/Native 支持

  • 2023-08-03
    北京
  • 本文字数:2251 字

    阅读完需:约 7 分钟

Kotlin 1.9.0 发布:带来多项新的语言特性,改进Multiplatform/Native支持

Kotlin 的最新版本引入了许多新的语言特性,包括用于开放范围的…<操作符、扩展正则表达式等。此外,它还改进了 Kotlin Multiplatform 和 Kotlin/Native 支持。


Kotlin 1.9 稳定了与枚举类关联的 entries 属性,它会返回所定义的枚举常量的所有值的列表。entries 弃用了 values(),它不再每次分配一个新数组,而是采用了预分配的值列表,提升了性能。


另一个小的语言特性是新引入了用于表示开放范围的…<操作符。JetBrains 表示,这个新语法可以让不包括上限的情况看起来更清晰。


在 Kotlin 1.9 中,正则表达式变得更加灵活,这要归功于一个新的函数 group。该函数可以按名称检索正则表达式组。如下所示,可以用几个命名组定义正则表达式:


val regex = """\b(?<city>[A-Za-z\s]+),\s(?<state>[A-Z]{2}):\s(?<areaCode>[0-9]{3})\b""".toRegex()
复制代码


然后使用组名来访问匹配的值:


val match = regex.find(input)!!println(match.groups["city"]?.value)// Austinprintln(match.groups["state"]?.value)// TXprintln(match.groups["areaCode"]?.value)
复制代码


Kotlin 1.9 还改进了对 Kotlin/Native 和 Kotlin Multiplatform 的支持。


在 Kotlin/Native 中,现在可以预览自定义内存分配器了,其目的是提高 Kotlin/Native 内存管理器的运行时性能。自定义分配器将系统内存划分为多个页,并允许按顺序单独进行清理。使用编译器选项-Xallocator= Custom 可以启用自定义内存分配器。


Objective-C/Swift 互操作性也得到了改善,这要归功于新引入的 Objective-C/Swift 对象释放策略。现在,对象释放会在适当的时候在主线程上进行,减少了内存泄漏的机会。


Kotlin 1.9 的其他新特性还包括:可以为 iOS 模拟器测试配置独立的 iOS 模式;可以跨 Kotlin JVM 和 Kotlin/Native 对链接问题进行统一处理。特别是,当存在链接问题时,构建将不再失败。


再来看下 Kotlin Multiform。它包括 Gradle 配置缓存预览,以及改进 Android 目标支持,为谷歌新开发的一个 Gradle 插件铺平了道路。


最后,关于 Kotlin 1.9,值得一提的是,它包含面向 JVM 的新的 K2 编译器的 Beta 版本,旨在提供更好的性能,加快语言特性开发,并为多平台对象提供更好的架构。在 Kotlin 2.0 中,K2 将成为稳定版本,并成为默认的编译器。


以下是 Kotlin 1.9 的详细变更信息全部官方声明。


Kotlin 1.9.0 版本现已发布,适用于 JVM 的 K2 编译器目前处于测试版阶段。 这个版本包含新的语言功能以及针对 Kotlin Multiplatform 和 Kotlin/Native 的改进。


以下是此版本的一些亮点:


  • 新的 Kotlin K2 编译器更新

  • 枚举类值函数的稳定替换

  • 开放范围的稳定 ..< 运算符

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

  • 用于创建父目录的新路径实用函数

  • Kotlin Multiplatform 中的 Gradle 配置缓存预览

  • Kotlin Multiplatform 中对 Android 目标支持的更改

  • Kotlin/Native 中自定义内存分配器的预览

  • Kotlin/Native 中的库链接

  • Kotlin/Wasm 中的大小相关优化


有关完整的更改列表,请参阅 Kotlin 1.9.0 最新变化或 GitHub 上的版本说明:


https://github.com/JetBrains/kotlin/releases/tag/v1.9.0


适用于 JVM 的新 Kotlin K2 编译器进入测试版阶段


JetBrains 的 Kotlin 团队持续稳定新的 K2 编译器,我们很高兴地宣布,在我们迈向 Kotlin 2.0 版本的旅程中,适用于 JVM 的新 Kotlin K2 编译器达到了测试版里程碑。 编译器已经过彻底测试,成功编译了 Kotlin 团队用于质量保证的大量项目。


K2 编译器旨在带来重大性能改进,加快新语言功能的开发,统一 Kotlin 支持的所有平台,并为多平台项目提供更好的架构。


我们在促进与其他流行编译器插件的兼容性方面取得了巨大进步。 对 Kotlin Symbol Processing (KSP) 和 Jetpack Compose 的支持即将推出,预计很快集成 K2 支持。 我们邀请您在 Kotlin/JVM 项目上测试 K2,并在我们的问题跟踪器中分享您的宝贵反馈。 您的意见将帮助我们完善 K2,使其在 Kotlin 2.0 中成为默认的稳定编译器。


我们的目标还不止于此。 我们希望通过 K2 编译器实现同样高质量的多平台支持。 这一愿景与我们在 Kotlin Multiplatform 稳定性方面的持续努力相符合。 我们的目标是在 Kotlin Multiplatform 稳定版本发布的同时,在 K2 中实现对多平台项目的完全测试版品质支持。


我们热切期待您的反馈,同时,我们也将在这段精彩的开发旅程中继续前进。 Kotlin 2.0 的未来将由我们共同塑造。


有关如何启用 K2 编译器的更多信息,请参阅在项目中试用 K2 编译器。


如何安装 Kotlin 1.9.0


如果您已经在使用 IntelliJ IDEA 2022.3.3 或 2023.1.1,IDE 会自动建议将 Kotlin 更新到 1.9.0。 您也可以按照这些说明手动更新:


https://kotlinlang.org/docs/releases.html#update-to-a-new-release


IntelliJ IDEA 2023.2 将内置 Kotlin 1.9.0 插件。


对于 Android Studio Giraffe (223) 和 Hedgehog (231),Kotlin 1.9.0 插件将随即将推出的 Android Studio 更新一起提供。 如果需要命令行编译器,请从 GitHub 版本页面下载:


https://github.com/JetBrains/kotlin/releases/tag/v1.9.0


更多文章和视频


  • “Kotlin 1.9.0 最新变化”文档:

https://kotlinlang.org/docs/whatsnew19.html


  • Kotlin 1.9.0 最新变化 YouTube 视频

https://youtu.be/fvwTZc-dxsM


  • K2 编译器将在 Kotlin 2.0 中进入稳定状态

https://blog.jetbrains.com/zh-hans/kotlin/2023/02/k2-kotlin-2-0/


  • Kotlin EAP Champion

https://blog.jetbrains.com/kotlin/2022/11/eap-champions/


相关阅读:


浅谈 Kotlin 编程 01. 初识 Kotlin 和入门示例

从 HelloWorld 看 Java 与 Kotlin

Meta 将百万行代码从 Java 移植到 Kotlin

又一巨头从 Java 迁移到 Kotlin !

2023-08-03 14:372865

评论

发布
暂无评论
发现更多内容

虎符推出AMM流动性资金池 支持现货专区做市赚收益

区块链前沿News

流动性 虎符 Hoo 虎符交易所 AMM

龙头整机厂商宝德加入,共建龙蜥社区开源新生态

OpenAnolis小助手

Linux 开源 合作伙伴

HBase的 rowkey 设计原则

编程江湖

HBase 架构

工商银行实时大数据平台建设历程及展望

Apache Flink

大数据 flink 编程 实时计算

有一群青年人,用热爱连接起科技与智慧生活的“双向奔赴”

最新动态

初识MASA Blazor

MASA技术团队

C# .net 微软 后端 blazor

内网是什么意思?指什么网?内网需要做等保测评吗?

行云管家

安全 内网 等保测评

🏆【Alibaba中间件技术系列】「Nacos技术专题」配置中心加载原理和配置实时更新原理分析(中)

码界西柚

nacos 配置中心 Alibaba 1月日更 Apache alibaba

从 Flink Forward Asia 2021,看 Flink 未来开启新篇章

Apache Flink

大数据 flink 编程 实时计算

MyBatis的功能架构是怎样的

编程江湖

mybatis

Alink、Tensorflow on Flink 在京东的应用

Apache Flink

大数据 flink 编程 实时计算 Alink

Redis OM .NET Redis对象映射框架

MASA技术团队

C# .net 微软 后端 redis'

数据安全产品之堡垒机详细介绍-行云管家

行云管家

网络安全 防火墙 数据安全 堡垒机

大数据开发之Flink + TiDB

@零度

flink 大数据开发

Flink CDC 系列 - Flink MongoDB CDC 在 XTransfer 的生产实践

Apache Flink

大数据 flink 编程 实时计算 IT

销量之王,去年程序员最爱看的技术书就是它!

博文视点Broadview

针对 jQuery 的优化方法有哪些

编程江湖

架构训练营 week6 作业

红莲疾风

「架构实战营」

教程直播第7期|如何对 OceanBase 进行 SQL 诊断和调优

OceanBase 数据库

oceanbase OceanBase 开源 OceanBase 社区版 OceanBase教程

WorkPlus移动数字化平台赋能新型智慧城市建设

BeeWorks

「元宇宙十万个为什么」:为什么元宇宙值得投资?

BeeWorks

Flink 大规模作业调度性能优化

Apache Flink

大数据 flink 编程 实时计算

netty系列之:可以自动通知执行结果的Future,有见过吗?

程序那些事

Java Netty 程序那些事

足球、篮球、花样滑冰、乒乓球四大运动的动作识别通用方案开源了

百度大脑

人工智能

mark: mac 开启chrome webrtc 日志

webrtc developer

chrome WebRTC

技术升级!国内公有云厂商首个支持保留消息功能

百度开发者中心

物联网

大咖集结,共创生态|AIOps社区专家团正式集结出道

云智慧AIOps社区

开源项目 开源社区 智能运维 开发者社区 社区治理

Pravega Flink Connector Table API 进阶功能探秘

Apache Flink

大数据 flink 编程 实时计算 Pravega

免费下载!FFA 系列专刊|《Flink CDC 新一代数据集成框架》电子书

Apache Flink

大数据 flink 编程 实时计算 IT

Apache Flink ML 2.0.0 发布公告

Apache Flink

大数据 flink 编程 实时计算

女生不适合当程序员?XTransfer这位程序员妈妈绝了!生娃半年内升职加薪

XTransfer技术

技术人 程序媛 XTransfer

Kotlin 1.9.0 发布:带来多项新的语言特性,改进Multiplatform/Native支持_架构/框架_平川_InfoQ精选文章