gpt4 book ai didi

intellij-idea - IntelliJ 中 Kotlin 代码的大量编译时间

转载 作者:IT老高 更新时间:2023-10-28 13:36:22 29 4
gpt4 key购买 nike

我已经在我的 Windows 10 计算机上使用 Kotlin 和最新版本的 Eclipse 2 个月了,没有出现任何性能问题。现在我想在最近的 OSX 电脑。两台电脑硬件不错,不会限制我的测试。

我的问题是每次我的Kotlin代码有修改,编译时间在8秒35秒之间。我对极简代码进行了测试:

class TestKotlin {
var a = 1
}

如果我更改了变量“a”,因此需要重新编译,最好的情况下总是需要 8 秒才能完成编译。

由于我想进行包含大量小函数和编译的实时编码 session ,因此这种延迟意义重大。观看者需要等待很长时间才能看到每次编译的结果,他们从逻辑上期待 IntelliJ 工具的良好性能。

在同一个项目中,我尝试做同一种Java类(只有一个属性)并修改它的属性以触发编译,耗时不到 1 秒编译。

我尝试在命令行中手动编译代码:

kotlinc hello.kt -include-runtime -d hello.jar
java -jar hello.jar

我有一些不错的编译时间,即使它接近 3 秒

当我在 IntelliJ 编译 Kotlin 代码时查看“消息”屏幕时,我可以看到:

Information:Kotlin: Kotlin JPS plugin version 1.0.6-release-127
Information:Kotlin: Using kotlin-home = /Users/myUsername/Library/Application Support/IntelliJIdea2016.3/Kotlin/kotlinc

它在所有编译时间都停在这里,然后几乎立即执行下一步:

Information:Kotlin: Kotlin Compiler version 1.0.6-release-127
Information:17/01/17 11:38 - Compilation completed successfully in 11s 639ms

也许 IntelliJ 的配置有问题或类似的东西。我很难寻找可以提高性能的东西,但没有任何帮助...

如果有人能帮助我在 Intellij 中像在 Eclipse 中一样使用 Kotlin 进行一些实际的编译,我将不胜感激!

最佳答案

这似乎类似于问题 KT-15491 .

为确保您的情况也是如此,请尝试执行以下简单的 Kotlin 程序:

import java.io.File
import kotlin.system.measureNanoTime

fun main(args: Array<String>) {
val elapsedNs = measureNanoTime { File.createTempFile("tmp", "", null).deleteOnExit() }
println(elapsedNs.toDouble() / 1000000000)
}

如果打印的耗时明显大于几分之一秒,那就是原因。

此问题不仅影响 Kotlin 编译器,还影响每个尝试创建临时文件或执行涉及 SecureRandom 类的任何其他操作的 JVM 程序。

我在 Windows 7 笔记本上的每个 JPS 版本都经历过同样的减速。我已尝试使用此 question 中描述的安全提供商订单的解决方法它有帮助。

关于intellij-idea - IntelliJ 中 Kotlin 代码的大量编译时间,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41696760/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com