title | author | date | source_url | reward_title | reward_wechat | reward_alipay | tags | categories | translator | translator_url |
---|---|---|---|---|---|---|---|---|---|---|
Kotlin 1.1.60 is out |
Dmitry Jemerov |
2017-11-13 14:07:00 -0800 |
Have a nice Kotlin! |
官方动态 |
pye52 |
我们很高兴宣布Kotlin 1.1.60的发布,这是针对Kotlin 1.1一个bug修正和工具更新的新版本。包含以下更新:
- 为Kotlin / JS增量编译添加实验性支持
- 向JSR-305自定义可空注解支持添加新的特性
- 修复Parcelable生成器中的大量bug,并为其提供了IDE的支持
- 改善了Gradle的增量构建
- 在IntelliJ插件中引入新的检查,性能改进和bug修复
此更新与2016.3至2017.3的所有IntelliJ IDEA版本以及Android Studio 2.3,3.0和3.1 Canary兼容。 可以在更新日志中看到完整的更新列表。 同时要感谢我们的代码贡献者,他们的pr已合并到该版本中:龟井俊明,Kirish Rakhman,Paul Merlin,Raluca Sauciuc,Yoshinori Isogai,Andrey Mischenko,Francesco Vasco,Jonathan Leitschuh,Denis Grachev和pivotal-vladimir。
在1.1.60版本中,Kotlin / JS Gradle项目将实验性地支持增量编译,对于微小的局部变更,只需数秒而非几分钟的完整构建,这可以显着减少开发过程中的构建时间。
默认情况下它是禁用的,你可以在gradle.properties
或local.properties
中设置kotlin.incremental.js = true
来启用。
欢迎使用,若遇到任何问题,请向Kotlin issue tracker反馈。
在Kotlin 1.1.50 中利用类型限定符别名和默认参数实现的扩展——JSR-305可空性注解得到了进一步的改善,其中的bug在该版本中得到修复。
现在JSR-305默认类型限定符可以通过ElementType.Type
来强制被注释的所有类型的用法,及其参数,基类和通配符类型:
@Nonnull(when = When.MAYBE)
@TypeQualifierDefault({ElementType.TYPE_USE})
public @interface NullableApi {
}
@NullableApi
interface Foo<T extends Bar> { // Upper bound T : Bar? in Kotlin
List<String> baz(List<? extends Qux> qux);
// in Kotlin: fun baz(qux: List<out Qux?>?): List<String?>?
}
提供类型限定符别名和类型限定符默认注释的代码库维护者现在可以通过@UnderMigration
来控制注释的迁移状态。该注释发布在新的工件kotlin-annotations-jvm
中,因此需要在gradle中添加一个新的依赖compile "org.jetbrains.kotlin:kotlin-annotations-jvm:1.1.60
。
@UnderMigration(status = ...)
(取值范围为:MigrationStatus.STRICT
、MigrationStatus.WARN
、MigrationStatus.IGNORE
)指定编译器在处理被注释的API的错误用法时的行为:报告错误,提示警告或直接忽略。
注意:在当前版本编译的代码中无法保证MigrationStatus.STRICT
的表现,因此该值当前是实验性的,但在之后的Kotlin版本中会正常作用。 Kotlin 1.2.x或Kotlin 1.3中的检查将很可能更加严格。
出于某种原因,当代码库的用户需要使用与维护者提供的不同的迁移状态时,可以通过将下列其中之一的编译器标记传递给可空性检查:
-Xjsr305 = {strict | warn | ignore}
现在只影响没有标记@UnderMigration
状态的注释-Xjsr305=under-migration:{strict|warn|ignore}
将覆写所有@UnderMigration
注释的行为-Xjsr305=@<fq.name>:{strict|warn|ignore}
将复写限定名称为fq.name的迁移状态
strict
模式也是实验性的,无法保证Kotlin 1.1.60所编译的源代码在将来的版本中仍能通过编译。
这些标志可以被合并,例如,-Xjsr305=ignore -Xjsr305=under-migration:ignore -Xjsr305=@org.library.MyNullable:warn
将使编译器忽略所有可空性注释,以及org.library.MyNullable
,但后者同时会有一个警告。
本版本修复了Kotlin 1.1.4(参考标准)中实验性Parcelable生成器的大量已知问题,并以diagnostics
和quick fixes
的形式提供了IDE支持,通过@Parcelize注释以利用该功能。
在Kotlin 1.1.60下,Gradle项目下test
代码集中的Kotlin代码会在main
集发生更改时重新编译。
此外,我们修复了一些bug使得新版的检查更加可靠,以便确保在JVM target,编译器插件配置和其他选项发生改动后,就会重新编译代码。
新版本在Kotlin IntelliJ IDEA插件中带来了许多改进:
- 用Kotlin DSL创建一个Gradle项目的新项目向导
- 当类型不匹配时通过quick fix在
Iterable
,Sequence
和Array
之间互相转换 - 通过quick fix在类型参数需要时智能指定
- 大量的bug修复及性能改进
若需要更新插件,请执行Tools | Kotlin | Configure Kotlin Plugin Updates 并点击“Check for updates now”按钮(对于Android Studio 3.1,从Plug Repository独立的渠道中更新)。同时注意要在Maven和Gradle构建脚本中更新编译器和标准库的版本。 像往常一样,如果在新版本中遇到任何问题,欢迎您在论坛上寻求帮助,在Slack上(获取邀请),或者在issue tracker中报告问题。
请尽情享受Kotlin!