血的教训:一例错误 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没有直接报出具体的变量找不到
,而是报出一个非常不解的错误。