血的教训:一例错误 com.android.builder.core.JackToolchain$ToolchainException: Jack compilation exception
一个Android Studio比较老的工程(com.android.tools.build:gradle:2.3.3),因为要使用RxJava和RxAndroid,就把Java8支持加上了,然后提示要使能Jack。就把Jack使能了,完整的配置如下:
...
jackOptions {
enabled true
}
...
...
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
...
然后就正常使用RxJava了,由于启用了Java8的支持,Android Studio开始不断的引诱我使用lambda,然后我就使用了,但是也没有出现任何异常,我用的就更大胆了。一个不小心的改动,导致了这个错误,我再也找不到了
org.gradle.api.tasks.TaskExecutionException: Execution failed for task ':app:transformJackWithJackForDebug'.
at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeActions(ExecuteActionsTaskExecuter.java:103)
最后将com.android.tools.build:gradle换成3.2.1版本,再按照官方教程将jack去掉,就提示出了问题所在,就是我将一个父类中的一个变量不小心加了一个private导致的,Jack没有直接报出具体的变量找不到,而是报出一个非常不解的错误。
在尝试将一个旧版AndroidStudio工程升级以支持Java8和使用RxJava及RxAndroid时,遇到了JackToolchain$ToolchainException错误。通过调整Gradle版本并修复代码中不当的访问修饰符,成功解决了这一复杂问题。

1352

被折叠的 条评论
为什么被折叠?



