【发布时间】:2016-09-16 22:53:20
【问题描述】:
我不断听到关于即时运行的讨论,好像它的状态很好,但是我和我的团队经常遇到该功能的重大问题,以及因此而降低的编码体验。
在即时运行之前,我们的干净构建大约需要 1 分 30 秒,之后我们会得到大约 25 秒或偶尔 40 秒的构建。虽然即时运行确实有时确实将构建时间减少到了 6-12 秒,但在其他时候,它导致我们陷入疯狂的长时间构建,我们已经看到需要长达 13 分钟的时间,这在很大程度上抵消了增量编译的任何收益。
似乎在大多数情况下,小的更改仍需要 40 秒。有时是 6 秒,但这种情况很少见。
感觉很像即时运行降低了我们持续高效工作的能力。以下是我们的一些应用特定配置:
Android Studio 2.1.1、Android 插件 2.1
multiDexEnabled true
dexOptions {
preDexLibraries true
javaMaxHeapSize "4g"
maxProcessCount 4
incremental true
dexInProcess true
}
org.gradle.daemon=true
org.gradle.parallel=true
org.gradle.jvmargs=-Xmx6g -XX:MaxPermSize=512m
是我们做错了什么,还是有人找到了解决办法?
编辑:一些开发人员似乎遇到了这个问题。我正在跟踪 a bug here. 请随意加注星标并加入讨论。
【问题讨论】:
-
这不是一个答案,但我们决定推迟使用即时运行功能,直到他们解决了一些明显的问题。我们遇到了不一致的问题,它们显然与高效的开发理念相矛盾。
-
"...好像状态很好"。欢迎来到 Android Studio PR 的世界。 AS 团队发布了尚未准备好迎接黄金时段的新功能,并相信开发人员会“习惯它”——Instant Run 也不例外(请原谅双关语)。我的经验是,随着每个版本的发布,AS 似乎越来越差......
-
ADT 的执行速度比 Studio 更快(在构建 apk 和加载项目方面),在每个版本中添加更多功能使 android studio 成为 memory eater。
-
我发现整个 gradle 的移动要好得多。我的构建获得了很大的灵活性,并且整体构建时间显着减少。我对 AndroidStudio / IntelliJ 可以随心所欲地消耗内存感到满意。这就是 IDE 如此快速的原因。现在内存太便宜了。在过去的 5 年里,我所有的电脑都至少有 16GB 的内存。
标签: android android-gradle-plugin android-build android-instant-run