android - Android Studio 构建失败 - 任务:app:dexBuilderDebug FAILED
问题描述
我收到错误消息Files under the "build" folder are generated and should not be editing。这是详细的构建输出(我只发布开头和结尾,因为它太长了)
AGPBI: {"kind":"error","text":"Type com.example.currencyconversion.BuildConfig is defined multiple times: /Users/eimanalwahhabi/Desktop/CurrencyConversion/app/build/intermediates/javac/debug/classes/com/example/currencyconversion/BuildConfig.class, /Users/eimanalwahhabi/Desktop/CurrencyConversion/app/build/intermediates/javac/debug/classes/com/example/currencyconversion/BuildConfig 2.class","sources":[{"file":"/Users/eimanalwahhabi/Desktop/CurrencyConversion/app/build/intermediates/javac/debug/classes/com/example/currencyconversion/BuildConfig.class"}],"tool":"D8"}
org.gradle.workers.WorkerExecutionException: There was a failure while executing work items
at org.gradle.workers.internal.DefaultWorkerExecutor.workerExecutionException(DefaultWorkerExecutor.java:264)
at org.gradle.workers.internal.DefaultWorkerExecutor.await(DefaultWorkerExecutor.java:246)
at com.android.build.gradle.internal.tasks.DexArchiveBuilderTaskDelegate.doProcess(DexArchiveBuilderTaskDelegate.kt:280)
at com.android.build.gradle.internal.tasks.DexArchiveBuilderTask.doTaskAction(DexArchiveBuilderTask.kt:282)
at com.android.build.gradle.internal.tasks.NewIncrementalTask$taskAction$$inlined$recordTaskAction$1.invoke(AndroidVariantTask.kt:73)
at com.android.build.gradle.internal.tasks.NewIncrementalTask$taskAction$$inlined$recordTaskAction$1.invoke(AndroidVariantTask.kt:34)
at com.android.build.gradle.internal.tasks.Blocks.recordSpan(Blocks.java:91)
at com.android.build.gradle.internal.tasks.NewIncrementalTask.taskAction(NewIncrementalTask.kt:34)
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:104)
at org.gradle.api.internal.project.taskfactory.IncrementalInputsTaskAction.doExecute(IncrementalInputsTaskAction.java:32)
at org.gradle.api.internal.project.taskfactory.StandardTaskAction.execute(StandardTaskAction.java:42)
at org.gradle.api.internal.project.taskfactory.AbstractIncrementalTaskAction.execute(AbstractIncrementalTaskAction.java:25)
at org.gradle.api.internal.project.taskfactory.StandardTaskAction.execute(StandardTaskAction.java:28)
at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter$3.run(ExecuteActionsTaskExecuter.java:569)
at org.gradle.internal.operations.DefaultBuildOperationExecutor$RunnableBuildOperationWorker.execute(DefaultBuildOperationExecutor.java:395)
at org.gradle.internal.operations.DefaultBuildOperationExecutor$RunnableBuildOperationWorker.execute(DefaultBuildOperationExecutor.java:387)
at org.gradle.internal.operations.DefaultBuildOperationExecutor$1.execute(DefaultBuildOperationExecutor.java:157)
at org.gradle.internal.operations.DefaultBuildOperationExecutor.execute(DefaultBuildOperationExecutor.java:242)
at org.gradle.internal.operations.DefaultBuildOperationExecutor.execute(DefaultBuildOperationExecutor.java:150)
at org.gradle.internal.operations.DefaultBuildOperationExecutor.run(DefaultBuildOperationExecutor.java:84)
at org.gradle.internal.operations.DelegatingBuildOperationExecutor.run(DelegatingBuildOperationExecutor.java:31)
at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeAction(ExecuteActionsTaskExecuter.java:554)
at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeActions(ExecuteActionsTaskExecuter.java:537)
at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.access$300(ExecuteActionsTaskExecuter.java:108)
at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter$TaskExecution.executeWithPreviousOutputFiles(ExecuteActionsTaskExecuter.java:278)
at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter$TaskExecution.execute(ExecuteActionsTaskExecuter.java:267)
at org.gradle.internal.execution.steps.ExecuteStep.lambda$execute$0(ExecuteStep.java:32)
.
.
.
.
Caused by: org.gradle.tooling.BuildException: Failed to process: /Users/eimanalwahhabi/Desktop/CurrencyConversion/app/build/intermediates/javac/debug/classes
Caused by: com.android.builder.dexing.DexArchiveBuilderException: Failed to process: /Users/eimanalwahhabi/Desktop/CurrencyConversion/app/build/intermediates/javac/debug/classes
Caused by: com.android.builder.dexing.DexArchiveBuilderException: Error while dexing.
Caused by: com.android.tools.r8.CompilationFailedException: Compilation failed to complete, origin: /Users/eimanalwahhabi/Desktop/CurrencyConversion/app/build/intermediates/javac/debug/classes/com/example/currencyconversion/BuildConfig.class
Caused by: com.android.tools.r8.utils.b: Type com.example.currencyconversion.BuildConfig is defined multiple times: /Users/eimanalwahhabi/Desktop/CurrencyConversion/app/build/intermediates/javac/debug/classes/com/example/currencyconversion/BuildConfig.class, /Users/eimanalwahhabi/Desktop/CurrencyConversion/app/build/intermediates/javac/debug/classes/com/example/currencyconversion/BuildConfig 2.class
Execution failed for task ':app:dexBuilderDebug'.
> There was a failure while executing work items
> A failure occurred while executing com.android.build.gradle.internal.dexing.DexWorkAction
> Failed to process: /Users/eimanalwahhabi/Desktop/CurrencyConversion/app/build/intermediates/javac/debug/classes
这是我尝试运行应用程序时汇总的构建输出:
Type com.example.currencyconversion.BuildConfig is defined multiple times: /Users/eimanalwahhabi/Desktop/CurrencyConversion/app/build/intermediates/javac/debug/classes/com/example/currencyconversion/BuildConfig.class, /Users/eimanalwahhabi/Desktop/CurrencyConversion/app/build/intermediates/javac/debug/classes/com/example/currencyconversion/BuildConfig 2.class
这是构建输出错误的图片:构建输出错误
这是我的 buildConfig.class
package com.example.currencyconversion;
public final class BuildConfig {
public static final boolean DEBUG = Boolean.parseBoolean("true");
public static final String APPLICATION_ID = "com.example.currencyconversion";
public static final String BUILD_TYPE = "debug";
public static final int VERSION_CODE = 1;
public static final String VERSION_NAME = "1.0";
public BuildConfig() {
}
}
这是模块 build.gradle。你可以在这里看到我试图通过添加 Multidex 依赖来解决这个问题,但它仍然没有工作。
plugins {
id 'com.android.application'
}
android {
compileSdkVersion 29
defaultConfig {
applicationId "com.example.currencyconversion"
minSdkVersion 29
targetSdkVersion 29
versionCode 1
versionName "1.0"
multiDexEnabled true
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
}
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation 'androidx.appcompat:appcompat:1.2.0'
implementation 'com.google.android.material:material:1.2.1'
implementation 'androidx.constraintlayout:constraintlayout:2.0.2'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'androidx.test.ext:junit:1.1.2'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.3.0'
implementation 'com.squareup.retrofit2:retrofit:2.7.1'
implementation 'com.squareup.retrofit2:converter-gson:2.1.0'
implementation 'com.squareup.okhttp3:logging-interceptor:3.4.1'
implementation 'com.google.code.gson:gson:2.6.2'
implementation 'com.android.support:multidex:1.0.3'
这是项目 build.gradle:
// Top-level build file where you can add configuration options common to all sub-projects/modules.
buildscript {
repositories {
google()
jcenter()
}
dependencies {
classpath "com.android.tools.build:gradle:4.1.0"
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
allprojects {
repositories {
google()
jcenter()
}
}
task clean(type: Delete) {
delete rootProject.buildDir
}
解决方案
我设法通过运行干净的构建来修复它
推荐阅读
- python - gdal_array 导入错误 Red Hat linux
- php - 如何使用 Laravel 进行平衡?
- c++ - 优化 openCL 中的分支 for 循环
- javascript - 反应路由器 v4 浏览器历史记录不适用于代码拆分
- ms-word - 两个word文档在同一个窗口
- html - a:hover:not() 执行只响应 .active 类?
- keras - Keras非法指令4
- java - com.mysql.jdbc.exceptions.jdbc4.CommunicationsException:通信链接失败和 BeanEntityManager 错误
- git - 将工作副本还原为较旧的提交?
- vb.net - 为什么在这个循环中声明的值类型会保留上一次迭代的值?