在新的 Android Studio 3.1 上构建时出错

Posted

技术标签:

【中文标题】在新的 Android Studio 3.1 上构建时出错【英文标题】:Error when building on new Android Studio 3.1 【发布时间】:2018-09-05 15:14:26 【问题描述】:

我在尝试构建项目时将 android Studio 更新到 3.1 稳定版并收到此错误。起初DataBinding 有问题,我修复了它们,然后我发现了这个问题。

org.gradle.api.GradleException: Compilation error. See log for more details
at org.jetbrains.kotlin.gradle.tasks.TasksUtilsKt.throwGradleExceptionIfError(tasksUtils.kt:8)
at org.jetbrains.kotlin.gradle.tasks.KotlinCompile.processCompilerExitCode(Tasks.kt:415)
at org.jetbrains.kotlin.gradle.tasks.KotlinCompile.callCompiler$kotlin_gradle_plugin(Tasks.kt:389)
at org.jetbrains.kotlin.gradle.tasks.KotlinCompile.callCompiler$kotlin_gradle_plugin(Tasks.kt:251)
at org.jetbrains.kotlin.gradle.tasks.AbstractKotlinCompile.execute(Tasks.kt:215)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.gradle.internal.reflect.JavaMethod.invoke(JavaMethod.java:73)
at org.gradle.api.internal.project.taskfactory.IncrementalTaskAction.doExecute(IncrementalTaskAction.java:46)
at org.gradle.api.internal.project.taskfactory.StandardTaskAction.execute(StandardTaskAction.java:39)
at org.gradle.api.internal.project.taskfactory.StandardTaskAction.execute(StandardTaskAction.java:26)
at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter$1.run(ExecuteActionsTaskExecuter.java:121)
at org.gradle.internal.progress.DefaultBuildOperationExecutor$RunnableBuildOperationWorker.execute(DefaultBuildOperationExecutor.java:336)
at org.gradle.internal.progress.DefaultBuildOperationExecutor$RunnableBuildOperationWorker.execute(DefaultBuildOperationExecutor.java:328)
at org.gradle.internal.progress.DefaultBuildOperationExecutor.execute(DefaultBuildOperationExecutor.java:199)
at org.gradle.internal.progress.DefaultBuildOperationExecutor.run(DefaultBuildOperationExecutor.java:110)
at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeAction(ExecuteActionsTaskExecuter.java:110)
at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeActions(ExecuteActionsTaskExecuter.java:92)

[这不是错误日志的完整版本]

有人找到解决办法吗?

【问题讨论】:

发布你所有的 gradle 文件!! 是的,我在更新 android studio 后第一次也遇到了这个错误。我刚刚重建我的项目,错误就消失了。 更新您的项目构建 gradle 版本并检查。 我在第一次运行时更新,它没有帮助 你的问题解决了吗? 【参考方案1】:

这个建议取决于你的项目有多复杂(这些建议可能没有用):

Kotlin plugin更新到最新版本

删除

kapt generateStubs = true

如果使用数据绑定,在gradle.properties这一行添加android.databinding.enableV2=true

更新等级 更新构建工具

感谢我的同事找到这些事实

【讨论】:

你需要这一切。【参考方案2】:

更新您的 kotlin 版本“1.2.31” 在应用级 gradle 文件中添加以下依赖项

编译“org.jetbrains.kotlin:kotlin-stdlib”

android 
  ...

  sourceSets 
    main.java.srcDirs += 'src/main/kotlin'
  

它可能对你有帮助:)

【讨论】:

【参考方案3】:

只需签出此项目并查看 build.gradle 文件。 我刚刚为 Android Studio 3.1 更新了这个项目,遇到了和你一样的错误,但是在 build.gradle 中进行了一些更改后,现在一切正常。

https://github.com/thierryxing/Douban

主要更新:

apply plugin: 'kotlin-kapt'

dependencies 
    kapt "com.android.databinding:compiler:$gradle_version"

【讨论】:

以上是关于在新的 Android Studio 3.1 上构建时出错的主要内容,如果未能解决你的问题,请参考以下文章

Android Studio 3.1陷入“Building *** Gradle项目信息”

使用新的 M1 兼容模拟器在 Android Studio 中未检测到 Android 模拟器

Android Studio - 共享偏好无法保存在新活动中

Android开发:《Gradle Recipes for Android》阅读笔记(翻译)3.1——使用Build Types

在新的 Visual Studio Express (C++ prefrred) 项目中使用旧版 (VB6) DLL

Android Studio,在新活动中显示完整的 WebView