最近Android项目开发中碰到一个异常,折腾了许久才找到问题的根源。
Google、百度搜索前两页内容浏览了一遍,总结了几种方案:
1、升级更新buildToolsVersion 到最新版本
2、升级Android Studio 2.2.2版本,JDK 1.8版本
3、配置JAVA_HOME路径
-
android {
-
compileSdkVersion 24
-
buildToolsVersion "24.0.2"
-
defaultConfig {
-
applicationId "com.mycompany.appname"
-
minSdkVersion 17
-
targetSdkVersion 24
-
versionCode 1
-
versionName "1.0"
-
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
-
-
jackOptions {
-
enabled true
-
}
-
}
-
buildTypes {
-
release {
-
minifyEnabled false
-
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
-
}
-
}
-
compileOptions {
-
sourceCompatibility JavaVersion.VERSION_1_8
-
targetCompatibility JavaVersion.VERSION_1_8
-
}
-
}
然并卵,以上方案并没有解决Error:Execution failed for task ':app:compileDebugJavaWithJavac' 这个异常
直到不经意间看到一篇博客以下一段内容
初始一看好像和我遇到的问题并没有什么关联,不过现在没什么头绪就抱着死马当活马医的觉悟尝试一下
果然,奇迹并没有发生,不过仔细看了错误信息
Task 'compileDebug' is ambiguous in root project
分析一下:ambiguous是模棱两可的意思 再看后面还有一大串compileDebugXXXX,于是灵光一闪
查看更详细的信息,在Android studio的Terminal窗口执行gradlew compileDebug --stacktrace
提示错误为:
org.gradle.execution.TaskSelectionException: Task ‘compileDebug’ is ambiguous in root project ‘NJCitizenCardApp’. Candidates are: ‘compileDebugAidl’, ‘compileDebugAndroidTestAidl’, ‘compileDebugAndroidTestJavaWithJavac’, ‘compileDebugAndroidTestNdk’, ‘compileDebugAndroidTestRend
erscript’, ‘compileDebugAndroidTestShaders’, ‘compileDebugAndroidTestSources’, ‘compileDebugJavaWithJavac’, ‘compileDebugNdk’, ‘compileDebugRenderscript’, ‘compileDebugShaders’, ‘compileDebugSources’, ‘compileDebugUnitTestJavaWithJavac’, ‘compileDebugUnitTestSources’.
at org.gradle.execution.TaskSelector.getSelection(TaskSelector.java:116)
at org.gradle.execution.TaskSelector.getSelection(TaskSelector.java:81)
at org.gradle.execution.commandline.CommandLineTaskParser.parseTasks(CommandLineTaskParser.java:42)
at org.gradle.execution.TaskNameResolvingBuildConfigurationAction.configure(TaskNameResolvingBuildConfigurationAction.java:44)
at org.gradle.execution.DefaultBuildConfigurationActionExecuter.configure(DefaultBuildConfigurationActionExecuter.java:48)
把命令gradlew compileDebug --stacktrace 改成 gradlew compileDebugJavaWithJavac
见证奇迹的时候到了
最后终于定位了错误,原来是使用Android Realm数据库时给非法数据类型添加了@PrimaryKey注解导致异常。
@PrimaryKey注解说明
①字段必须是String、 integer、byte、short、 int、long 以及它们的封装类Byte, Short, Integer, and Long
②使用了该注解之后可以使用copyToRealmOrUpdate()方法,通过主键查询它的对象,如果查询到了,则更新它,否则新建一个对象来代替。
③使用了该注解将默认设置@index注解
④使用了该注解之后,创建和更新数据将会慢一点,查询数据会快一点。
@Required
数据不能为null
@Ignore
忽略,即该字段不被存储到本地
@Index
为这个字段添加一个搜索引擎,这将使插入数据变慢、数据增大,但是查询会变快。建议在需要优化读取性能的情况下使用。
虽然Android Studio报的是同一个异常,但是每个人造成异常的根源可能各不相同,掌握解决问题的思路比解决问题的方法更重要。