ChatGPT解决这个技术问题 Extra ChatGPT

Android-错误:任务':app:transformClassesWithDexForRelease'的执行失败

问题是当我切换到 debug 模式时我能够运行我的应用程序,但是当我切换到 release 模式时它会失败。

例外:

**FAILURE: Build failed with an exception.**
> Execution failed for task ':app:transformClassesWithDexForRelease'.
> com.android.build.api.transform.TransformException: com.android.ide.common.process.ProcessException: java.util.concurrent.ExecutionException: com.android.ide.common.process.ProcessException: org.gradle.process.internal.ExecException: Process 'command '/Library/Java/JavaVirtualMachines/jdk1.8.0_65.jdk/Contents/Home/bin/java'' finished with non-zero exit value 1

当我使用 stacktrace 运行 gradle build 命令时,这就是我得到的

./gradlew app:transformClassesWithDexForRelease --stacktrace

> com.android.build.api.transform.TransformException: com.android.ide.common.process.ProcessException: java.util.concurrent.ExecutionException: com.android.ide.common.process.ProcessException: org.gradle.process.internal.ExecException: Process 'command '/Library/Java/JavaVirtualMachines/jdk1.8.0_73.jdk/Contents/Home/bin/java'' finished with non-zero exit value 1

*Exception is:*

>org.gradle.api.tasks.TaskExecutionException: Execution failed for task ':app:transformClassesWithDexForRelease'.
            at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeActions(ExecuteActionsTaskExecuter.java:69)
            at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.execute(ExecuteActionsTaskExecuter.java:46)
            at org.gradle.api.internal.tasks.execution.PostExecutionAnalysisTaskExecuter.execute(PostExecutionAnalysisTaskExecuter.java:35)
            at org.gradle.api.internal.tasks.execution.SkipUpToDateTaskExecuter.execute(SkipUpToDateTaskExecuter.java:64)
            at org.gradle.api.internal.tasks.execution.ValidatingTaskExecuter.execute(ValidatingTaskExecuter.java:58)
            at org.gradle.api.internal.tasks.execution.SkipEmptySourceFilesTaskExecuter.execute(SkipEmptySourceFilesTaskExecuter.java:52)
            at org.gradle.api.internal.tasks.execution.SkipTaskWithNoActionsExecuter.execute(SkipTaskWithNoActionsExecuter.java:52)
            at org.gradle.api.internal.tasks.execution.SkipOnlyIfTaskExecuter.execute(SkipOnlyIfTaskExecuter.java:53)
            at org.gradle.api.internal.tasks.execution.ExecuteAtMostOnceTaskExecuter.execute(ExecuteAtMostOnceTaskExecuter.java:43)
            at org.gradle.execution.taskgraph.DefaultTaskGraphExecuter$EventFiringTaskWorker.execute(DefaultTaskGraphExecuter.java:203)
            at org.gradle.execution.taskgraph.DefaultTaskGraphExecuter$EventFiringTaskWorker.execute(DefaultTaskGraphExecuter.java:185)
            at org.gradle.execution.taskgraph.AbstractTaskPlanExecutor$TaskExecutorWorker.processTask(AbstractTaskPlanExecutor.java:66)
            at org.gradle.execution.taskgraph.AbstractTaskPlanExecutor$TaskExecutorWorker.run(AbstractTaskPlanExecutor.java:50)
            at org.gradle.execution.taskgraph.DefaultTaskPlanExecutor.process(DefaultTaskPlanExecutor.java:25)
            at org.gradle.execution.taskgraph.DefaultTaskGraphExecuter.execute(DefaultTaskGraphExecuter.java:110)
            at org.gradle.execution.SelectedTaskExecutionAction.execute(SelectedTaskExecutionAction.java:37)
            at org.gradle.execution.DefaultBuildExecuter.execute(DefaultBuildExecuter.java:37)
            at org.gradle.execution.DefaultBuildExecuter.access$000(DefaultBuildExecuter.java:23)
            at org.gradle.execution.DefaultBuildExecuter$1.proceed(DefaultBuildExecuter.java:43)
            at org.gradle.execution.DryRunBuildExecutionAction.execute(DryRunBuildExecutionAction.java:32)
            at org.gradle.execution.DefaultBuildExecuter.execute(DefaultBuildExecuter.java:37)
            at org.gradle.execution.DefaultBuildExecuter.execute(DefaultBuildExecuter.java:30)
            at org.gradle.initialization.DefaultGradleLauncher$4.run(DefaultGradleLauncher.java:154)
            at org.gradle.internal.Factories$1.create(Factories.java:22)
            at org.gradle.internal.progress.DefaultBuildOperationExecutor.run(DefaultBuildOperationExecutor.java:90)
            at org.gradle.internal.progress.DefaultBuildOperationExecutor.run(DefaultBuildOperationExecutor.java:52)
            at org.gradle.initialization.DefaultGradleLauncher.doBuildStages(DefaultGradleLauncher.java:151)
            at org.gradle.initialization.DefaultGradleLauncher.access$200(DefaultGradleLauncher.java:32)
            at org.gradle.initialization.DefaultGradleLauncher$1.create(DefaultGradleLauncher.java:99)
            at org.gradle.initialization.DefaultGradleLauncher$1.create(DefaultGradleLauncher.java:93)
            at org.gradle.internal.progress.DefaultBuildOperationExecutor.run(DefaultBuildOperationExecutor.java:90)
            at org.gradle.internal.progress.DefaultBuildOperationExecutor.run(DefaultBuildOperationExecutor.java:62)
            at org.gradle.initialization.DefaultGradleLauncher.doBuild(DefaultGradleLauncher.java:93)
            at org.gradle.initialization.DefaultGradleLauncher.run(DefaultGradleLauncher.java:82)
            at org.gradle.launcher.exec.InProcessBuildActionExecuter$DefaultBuildController.run(InProcessBuildActionExecuter.java:94)
            at org.gradle.tooling.internal.provider.ExecuteBuildActionRunner.run(ExecuteBuildActionRunner.java:28)
            at org.gradle.launcher.exec.ChainingBuildActionRunner.run(ChainingBuildActionRunner.java:35)
            at org.gradle.launcher.exec.InProcessBuildActionExecuter.execute(InProcessBuildActionExecuter.java:43)
            at org.gradle.launcher.exec.InProcessBuildActionExecuter.execute(InProcessBuildActionExecuter.java:28)
            at org.gradle.launcher.exec.ContinuousBuildActionExecuter.execute(ContinuousBuildActionExecuter.java:78)
            at org.gradle.launcher.exec.ContinuousBuildActionExecuter.execute(ContinuousBuildActionExecuter.java:48)
            at org.gradle.launcher.daemon.server.exec.ExecuteBuild.doBuild(ExecuteBuild.java:52)
            at org.gradle.launcher.daemon.server.exec.BuildCommandOnly.execute(BuildCommandOnly.java:36)
            at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)
            at org.gradle.launcher.daemon.server.exec.WatchForDisconnection.execute(WatchForDisconnection.java:37)
            at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)
            at org.gradle.launcher.daemon.server.exec.ResetDeprecationLogger.execute(ResetDeprecationLogger.java:26)
            at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)
            at org.gradle.launcher.daemon.server.exec.RequestStopIfSingleUsedDaemon.execute(RequestStopIfSingleUsedDaemon.java:34)
            at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)
            at org.gradle.launcher.daemon.server.exec.ForwardClientInput$2.call(ForwardClientInput.java:74)
            at org.gradle.launcher.daemon.server.exec.ForwardClientInput$2.call(ForwardClientInput.java:72)
            at org.gradle.util.Swapper.swap(Swapper.java:38)
            at org.gradle.launcher.daemon.server.exec.ForwardClientInput.execute(ForwardClientInput.java:72)
            at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)
            at org.gradle.launcher.daemon.server.health.DaemonHealthTracker.execute(DaemonHealthTracker.java:47)
            at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)
            at org.gradle.launcher.daemon.server.exec.LogToClient.doBuild(LogToClient.java:66)
            at org.gradle.launcher.daemon.server.exec.BuildCommandOnly.execute(BuildCommandOnly.java:36)
            at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)
            at org.gradle.launcher.daemon.server.exec.EstablishBuildEnvironment.doBuild(EstablishBuildEnvironment.java:72)
            at org.gradle.launcher.daemon.server.exec.BuildCommandOnly.execute(BuildCommandOnly.java:36)
            at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)
            at org.gradle.launcher.daemon.server.health.HintGCAfterBuild.execute(HintGCAfterBuild.java:41)
            at org.gradle.launcher.daemon.server.api.DaemonCommandExecution.proceed(DaemonCommandExecution.java:120)
            at org.gradle.launcher.daemon.server.exec.StartBuildOrRespondWithBusy$1.run(StartBuildOrRespondWithBusy.java:50)
            at org.gradle.launcher.daemon.server.DaemonStateCoordinator$1.run(DaemonStateCoordinator.java:246)
            at org.gradle.internal.concurrent.ExecutorPolicy$CatchAndRecordFailures.onExecute(ExecutorPolicy.java:54)
            at org.gradle.internal.concurrent.StoppableExecutorImpl$1.run(StoppableExecutorImpl.java:40)
    Caused by: java.lang.RuntimeException: com.android.build.api.transform.TransformException: com.android.ide.common.process.ProcessException: java.util.concurrent.ExecutionException: com.android.ide.common.process.ProcessException: org.gradle.process.internal.ExecException: Process 'command '/Library/Java/JavaVirtualMachines/jdk1.8.0_73.jdk/Contents/Home/bin/java'' finished with non-zero exit value 1
            at com.android.builder.profile.Recorder$Block.handleException(Recorder.java:54)
            at com.android.builder.profile.ThreadRecorder$1.record(ThreadRecorder.java:57)
            at com.android.builder.profile.ThreadRecorder$1.record(ThreadRecorder.java:47)
            at com.android.build.gradle.internal.pipeline.TransformTask.transform(TransformTask.java:173)
            at org.gradle.internal.reflect.JavaMethod.invoke(JavaMethod.java:75)
            at org.gradle.api.internal.project.taskfactory.AnnotationProcessingTaskFactory$IncrementalTaskAction.doExecute(AnnotationProcessingTaskFactory.java:244)
            at org.gradle.api.internal.project.taskfactory.AnnotationProcessingTaskFactory$StandardTaskAction.execute(AnnotationProcessingTaskFactory.java:220)
            at org.gradle.api.internal.project.taskfactory.AnnotationProcessingTaskFactory$IncrementalTaskAction.execute(AnnotationProcessingTaskFactory.java:231)
            at org.gradle.api.internal.project.taskfactory.AnnotationProcessingTaskFactory$StandardTaskAction.execute(AnnotationProcessingTaskFactory.java:209)
            at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeAction(ExecuteActionsTaskExecuter.java:80)
            at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter.executeActions(ExecuteActionsTaskExecuter.java:61)
            ... 68 more
    Caused by: com.android.build.api.transform.TransformException: com.android.ide.common.process.ProcessException: java.util.concurrent.ExecutionException: com.android.ide.common.process.ProcessException: org.gradle.process.internal.ExecException: Process 'command '/Library/Java/JavaVirtualMachines/jdk1.8.0_73.jdk/Contents/Home/bin/java'' finished with non-zero exit value 1
            at com.android.build.gradle.internal.transforms.DexTransform.transform(DexTransform.java:422)
            at com.android.build.gradle.internal.pipeline.TransformTask$3.call(TransformTask.java:178)
            at com.android.build.gradle.internal.pipeline.TransformTask$3.call(TransformTask.java:174)
            at com.android.builder.profile.ThreadRecorder$1.record(ThreadRecorder.java:55)
            ... 77 more
    Caused by: com.android.ide.common.process.ProcessException: java.util.concurrent.ExecutionException: com.android.ide.common.process.ProcessException: org.gradle.process.internal.ExecException: Process 'command '/Library/Java/JavaVirtualMachines/jdk1.8.0_73.jdk/Contents/Home/bin/java'' finished with non-zero exit value 1
            at com.android.builder.core.AndroidBuilder.runDexer(AndroidBuilder.java:1472)
            at com.android.builder.core.AndroidBuilder.convertByteCode(AndroidBuilder.java:1389)
            at com.android.build.gradle.internal.transforms.DexTransform.transform(DexTransform.java:250)
            ... 80 more
    Caused by: java.util.concurrent.ExecutionException: com.android.ide.common.process.ProcessException: org.gradle.process.internal.ExecException: Process 'command '/Library/Java/JavaVirtualMachines/jdk1.8.0_73.jdk/Contents/Home/bin/java'' finished with non-zero exit value 1
            at com.android.builder.core.AndroidBuilder.runDexer(AndroidBuilder.java:1456)
            ... 82 more
    Caused by: com.android.ide.common.process.ProcessException: org.gradle.process.internal.ExecException: Process 'command '/Library/Java/JavaVirtualMachines/jdk1.8.0_73.jdk/Contents/Home/bin/java'' finished with non-zero exit value 1
            at com.android.build.gradle.internal.process.GradleProcessResult.assertNormalExitValue(GradleProcessResult.java:43)
            at com.android.builder.core.AndroidBuilder$2.call(AndroidBuilder.java:1464)
            at com.android.builder.core.AndroidBuilder$2.call(AndroidBuilder.java:1456)
    Caused by: org.gradle.process.internal.ExecException: Process 'command '/Library/Java/JavaVirtualMachines/jdk1.8.0_73.jdk/Contents/Home/bin/java'' finished with non-zero exit value 1
            at org.gradle.process.internal.DefaultExecHandle$ExecResultImpl.assertNormalExitValue(DefaultExecHandle.java:367)
            at com.android.build.gradle.internal.process.GradleProcessResult.assertNormalExitValue(GradleProcessResult.java:41)
            ... 2 more

我在用

Android Studio 2.0 测试版 6

Java 版本:Java(TM) SE 运行时环境(内部版本 1.8.0_73-b02)

Gradle 版本:com.android.tools.build:gradle:2.0.0-beta6

我启用了 Multidex

我的 build.gradle 文件

apply plugin: 'com.android.application'
apply plugin: 'com.getkeepsafe.dexcount'

android {

    def VERSION_CODE = 52
    def VERSION_NAME = "1.0"
    compileSdkVersion 23
    buildToolsVersion '23.0.2'

    defaultConfig {
        applicationId "com.example.app"
        manifestPlaceholders = [appName: "Personal App"]
        minSdkVersion 14
        targetSdkVersion 23
        renderscriptTargetApi 19
        renderscriptSupportModeEnabled true
        versionCode VERSION_CODE
        versionName VERSION_NAME

        // Enabling multidex support.
        multiDexEnabled true
    }

    compileOptions {
        sourceCompatibility JavaVersion.VERSION_1_7
        targetCompatibility JavaVersion.VERSION_1_7
        encoding = 'UTF-8'
    }

    signingConfigs {
        livekeystore {
            storeFile file('../key.jks')
            keyAlias 'livekeystore'
            keyPassword '123asd'
            storePassword '123asd'
        }
    }


    buildTypes {
        release {
            minifyEnabled true
            shrinkResources true
            zipAlignEnabled true
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt'
            signingConfig signingConfigs.burgerking

            manifestPlaceholders = [googleMapsKey: "@string/release_google_map_key", appNameSuffix: ""]
        }

        debug {
            applicationIdSuffix '.dev'
            debuggable true
            minifyEnabled false
            shrinkResources false
            zipAlignEnabled false

            manifestPlaceholders = [googleMapsKey: "@string/debug_google_map_key", appNameSuffix: ' (Dev-' + VERSION_CODE + ')']

        }
    }

    dexOptions {
        incremental true
        javaMaxHeapSize "4g" // 2g should be also OK
    }

    useLibrary 'org.apache.http.legacy'

}

repositories {
    maven { url 'https://mint.splunk.com/gradle/' }
    maven { url "http://dl.bintray.com/populov/maven" }
    mavenCentral()
}

buildscript {
    repositories {
        mavenCentral()
    }

    dependencies {
        classpath 'com.getkeepsafe.dexcount:dexcount-gradle-plugin:0.4.2'
        classpath 'com.newrelic.agent.android:agent-gradle-plugin:4.244.0'
    }
}


dependencies {
    compile 'com.google.code.gson:gson:2.4'
    compile 'com.android.support:appcompat-v7:23.2.0'
    compile 'com.android.support:recyclerview-v7:23.2.0'
    compile 'com.android.support:cardview-v7:23.2.0'
    compile 'com.android.support:design:23.2.0'
    compile 'com.android.support:multidex:1.0.1'
    compile 'com.google.android.gms:play-services-base:8.4.0'
    compile 'com.google.android.gms:play-services-location:8.4.0'
    compile 'com.google.android.gms:play-services-analytics:8.4.0'
    compile 'com.google.android.gms:play-services-maps:8.4.0'
    compile 'com.google.android.gms:play-services-ads:8.4.0'
    compile 'com.googlecode.libphonenumber:libphonenumber:7.0.5'
    compile 'com.facebook.android:facebook-android-sdk:4.1.1'
    compile 'de.greenrobot:eventbus:2.4.0'
    compile 'com.viewpagerindicator:library:2.4.1@aar'
    compile 'com.nineoldandroids:library:2.4.0'
    compile 'com.squareup.picasso:picasso:2.5.2'
    compile 'com.squareup:pollexor:2.0.2'
    compile 'com.makeramen:roundedimageview:2.1.0'
    compile 'com.mcxiaoke.volley:library:1.0.16@aar'
    compile files('libs/now-auth-api.jar')
    compile 'com.jakewharton:butterknife:5.1.2'
    compile 'com.github.ksoichiro:android-observablescrollview:1.2.0'
    compile 'io.card:android-sdk:5.3.0'
    compile 'com.appboy:android-sdk-ui:1.10.3'
    testCompile 'junit:junit:4.11'
    testCompile('org.mockito:mockito-core:1.9.5') {
        exclude group: 'org.hamcrest'
    }
    testCompile('org.powermock:powermock-module-junit4:1.5') {
        exclude group: 'org.hamcrest'
    }
    testCompile('org.powermock:powermock-api-mockito:1.6.2') {
        exclude group: 'org.hamcrest'
    }

    compile 'me.grantland:autofittextview:0.2.1'

}

如果我从中删除 minifyEnabled true,我似乎能够让我的发布版本正常工作。为什么会这样,有没有其他方法可以解决

你能发布你的应用程序的 build.gradle 文件吗?
@Harisewak 我已经更新了问题,请立即查看
是的@Sheraz 你是对的,将 minifyEnabled 切换为 false 可以解决问题。我在 doc 中读到:'您必须启用 minifyEnabled 才能打开代码收缩,然后使用 shrinkResources 才能打开资源收缩。如果您尚未使用 minifyEnabled,请确保在添加 shrinkResources 之前使其正常工作,因为您可能必须编辑您的 proguard-rules.pro 文件以确保您使用反射等访问的任何方法都列为保留规则文件” (tools.android.com/tech-docs/new-build-system/resource-shrinking)。看看是不是这种情况。
@Harisewak 如果我使用调试运行任务,它仍然无法解决问题,然后我收到此错误Uncaught translation error: com.android.dx.cf.code.SimException: com.android.dx.rop.cst.CstMethodRef cannot be cast to com.android.dx.rop.cst.CstInterfaceMethodRef
我的项目也有同样的问题。如果我使用 com.android.tools.build:gradle:1.3.0,我可以编译。一旦我使用 2.0.0,它就会给我同样的问题

A
Andrii Abramov

我只修复了这段代码。

本地属性

org.gradle.jvmargs=-XX\:MaxHeapSize\=512m -Xmx512m

你应该在gradle上做这个改变

defaultConfig {
    applicationId "yourProjectPackage"
    minSdkVersion 15
    versionCode 1
    versionName "1.0"
    targetSdkVersion 23

    multiDexEnabled true //important
}

“local.properties”是文件名还是配置值?它位于项目内的哪个位置(例如:在哪个文件夹中)?
local.properties 文件位于项目的根级别。如果您对 multiDex 有疑问--> developer.android.com/studio/build/multidex.html
我刚刚在我的 build.gradle 中插入了 multiDexEnabled true ,魔法就完成了。谢谢你。
我不知道这一切意味着什么,但它对我有用!
在 API <21 上,没有从 MultiDexApplication 扩展 Application 类的 multiDexEnabled 将导致 NoClassDefFoundError
A
AgataB

如果您在应用程序的 defaultConfig 中设置 multiDexEnabled = true,您将获得所需的结果。

defaultConfig {
    minSdkVersion 14
    targetSdkVersion 22
    multiDexEnabled = true
}

这不是允许 Multidex 的唯一步骤。无论如何,只有在看到 DexException 时才需要它。 developer.android.com/studio/build/multidex.html
F
Faysal Ahmed

对我来说,在我从项目中删除 jar 文件后,问题就解决了。我的项目中的一个 jar 文件似乎使用的是旧版本的 google play services


与jackrabbit-standalone-2.12.2.jar 相同的问题。如果我将它添加到项目中,那么问题就会出现。
@MikeOx我更新了一些Android工具,结果我得到了几个jar文件的两个版本,例如mockable-android-24.jar和mockable-android-25.jar。删除旧的为我修复了这些构建错误。
但我没有使用任何 jar 文件,那么为什么我会遇到这个问题
您能否提供有关此解决方案的更多详细信息
@IvanMilisavljevic 您现在可以使用 Gradle,而不是 JAR 文件。 developers.google.com/android/guides/setup#split
A
Ahmad Aghazadeh

我也收到了同样的错误:

错误:任务“:app:transformClassesWithDexForDebug”执行失败。 com.android.build.api.transform.TransformException:java.lang.RuntimeException:com.android.ide.common.process.ProcessException:java.util.concurrent.ExecutionException:com.android.ide.common.process.ProcessException: org.gradle.process.internal.ExecException: Process 'command 'C:\Program Files\Java\jdk1.8.0_60\bin\java.exe'' 以非零退出值 1 结束

好吧,我通过以下步骤解决了这个问题:

打开您应用的 build.gradle(不是项目根目录中的那个)并添加: android { //snippet //将其添加到您现有的 'android' 块中 dexOptions { javaMaxHeapSize "4g" } //snip } 再次尝试构建。

注意:4g 是 4 GB,这是 dex 操作的最大堆大小。


拯救了我的一天!干杯!
最好的......我已经漫游了几个小时......谢谢!
R
Ruchir Baronia

不需要 MULTIDEX,我重复,不需要 MULTIDEX

让我详细说明一下:Multidex 基本上是 Android 附带的一个工具,如果将其设置为 true,则具有超过 64,000 个方法的应用程序能够使用稍微改变的构建过程进行编译。但是,如果您的错误如下所示,您只需要使用 multidex:

编写输出时遇到问题:字段引用过多:131000;最大值为 65536。您可以尝试使用 --multi-dex 选项。

或者像这样

转换为 Dalvik 格式失败:无法执行 dex:方法 ID 不在 [0, 0xffff] 中:65536

但这里不是这样!这里的问题(至少对我而言)是由您的 build.gradle 文件的依赖项引起的。

解决方案:利用特定的依赖项——不要只导入整个依赖项!

例如,如果您需要位置的 Play Services 依赖项,则只需为位置导入它。

做:

compile 'com.google.android.gms:play-services-location:11.0.4'

不:

compile 'com.google.android.gms:play-services'

可能导致此问题的另一个问题可能是您正在使用的某种外部库,即引用您的依赖项的先前版本。在这种情况下,请按照以下步骤操作:

转到 SDK 管理器,并为您的依赖项安装任何更新确保您的 build.gradle 文件显示最新版本。要获取最新版本,请使用此链接:https://developers.google.com/android/guides/setup 编辑您的库(或安装更新版本,如果存在),以引用最新版本

我知道这个问题很老,但我需要得到这个答案,因为无缘无故地使用 multidex 可能会导致您的应用出现 ANR!仅当您确定需要它并且了解它是什么时才使用 multidex。

我自己花了几个小时试图在没有 multidex 的情况下解决这个问题,我只是想分享我的发现——希望这会有所帮助


杰出的!完美运行!
你怎么知道是哪个特定的依赖导致了问题?我添加了 com.facebook.android:audience-network-sdk:4.+,从那时起我无法构建。
你救了我的一天!
这么愚蠢的答案。如果你有很多依赖项,无论如何你都需要多 dex。只需添加 kotlin 库、几个 google 服务 (com.google.android.gms:play-services-*:*)、firebase 服务、crashlytics、gson、androidx(支持库)、cardview、recyclerview、android.material:material。没有MULTI DEX是不可能的(你喜欢capslock吗?我不喜欢,所以下次请不要在这里回答这样的问题......)
有些身体在这里很聪明!没错!,它不是multidex错误,multidex错误是不同的,它可能来自某些依赖项。 @user155,RUCHIR 不对您的依赖问题负责!我喜欢大写锁 :)
M
Mohammedsalim Shivani

在应用级别 gradle 的 defaultConfig 中添加 multiDexEnabled true

defaultConfig {
    applicationId "your application id"
    minSdkVersion 16
    targetSdkVersion 25
    versionCode 1
    versionName "1.0"
    testInstrumentationRunner"android.support.test.runner.AndroidJUnitRunner"
    multiDexEnabled true
}

P
Prokash Sarkar

我在我的应用程序中遇到了类似的问题。这就是我所做的。 1.add this for build.gradle in module: app

multiDexEnabled = true

所以代码会是这样的:

    android {
    compileSdkVersion 25
    buildToolsVersion "25.0.2"
    defaultConfig {
        applicationId "com.example..."
        minSdkVersion 17
        targetSdkVersion 25
        versionCode 1
        versionName "1.0"
        multiDexEnabled = true
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
    }

    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
}

这对我有用。希望这对您也有帮助 :)

在同一个项目中,我也在使用 Firebase。因此,启用 multiDexEnabled 会导致 Firebase 中 Pre Lollipop 设备 的另一个问题。未识别某些 FireBase 类。 (无法获取提供程序 com.google.firebase.provider)。
解释了解决方法here.


minifyEnable true 给了我例外-以下是我的问题,stackoverflow.com/questions/51720018/…请帮助我。
K
Kalaivanan

将 Google Play 服务从 7.5 升级到 9.0 时出现此错误

有以下错误:

compile 'com.google.android.gms:play-services:9.0.0'

当我改为

compile 'com.google.android.gms:play-services:7.5.0'

没有错误。尝试这个


谢谢我已更改版本以编译“com.google.android.gms:play-services:8.4.0”我认为 volley 使用了一些与 play-services 不兼容的旧 Google play 服务:>9.0
这就是我的解决方案。问题是几个第三方模块引用了不同版本的播放服务,那么如何期望这些版本一直保持同步呢?非常奇怪的建筑细节。
你不应该使用这个。请有选择地编译这些库。 developers.google.com/android/guides/setup#split
在哪里改变......以上的变化?你能告诉我文件名吗?
d
devDeejay

更新到Android 3.4后,我开始收到错误,尝试了上述所有解决方案。

问题的根本原因是,更新 Android Studio 启用了 Instant Run。

因此,您可以尝试的解决方案之一是禁用 Instant Run,如果它为您启用,则可以解决我的问题。


我遇到过同样的问题。禁用 Instant Run 并再次启用它对我有用。
也解决了我的问题。请注意 - Instant Run 很有用,所以我希望很快会有更好的修复
Aaaaarg 他们总是在更新时启用它,它总是会导致很多问题。
Jep,这也是我在将 Firebase 放入项目后出现问题的原因,禁用 Instant Run 终于让我构建它,谢谢!
禁用即时运行对我有用。没有再次收到错误。
C
Community

好吧,我相信这个问题已经回答并且已经被接受了。但我会写下我所面临的以及我是如何解决它的。

我也收到了同样的错误:

错误:任务“:app:transformClassesWithDexForDebug”执行失败。 com.android.build.api.transform.TransformException:java.lang.RuntimeException:com.android.ide.common.process.ProcessException:java.util.concurrent.ExecutionException:com.android.ide.common.process.ProcessException: org.gradle.process.internal.ExecException: Process 'command 'C:\Program Files\Java\jdk1.8.0_60\bin\java.exe'' 以非零退出值 1 结束

我没有幸运地应用所有设置并获得了成功。但是当我再次尝试调试项目时。这次我得到了三个错误(包括上面):

错误:Java HotSpot(TM) 64 位服务器 VM 警告:CodeCache 已满。编译器已被禁用。

错误:Java HotSpot(TM) 64 位服务器 VM 警告:尝试使用 -XX:ReservedCodeCacheSize= 增加代码缓存大小

那我做了什么?我只是去Android Studio:

文件 > 使缓存无效/重新启动.. > 使缓存无效并重新启动

快速解决!

额外说明:

我在 Gradle 控制台中发现的内容:

:app:incrementalDebugTasks :app:prePackageMarkerForDebug :app:fastDeployDebugExtractor :app:generateDebugInstantRunAppInfo :app:transformClassesWithDexForDebug 要在进程中运行 dex,Gradle 守护进程需要更大的堆。它目前大约有 910 MB。要加快构建速度,请将 Gradle 守护程序的最大堆大小增加到 2048 MB 以上。为此,请在项目 gradle.properties 中设置 org.gradle.jvmargs=-Xmx2048M。有关更多信息,请参阅 https://docs.gradle.org/current/userguide/build_environment.html :app:transformClassesWithDexForDebug FAILED

在 Oracle 博客上阅读有关它的更多信息Here


S
Selim Özbudak

我刚刚将这段代码写入 gradle.properties,现在可以了

org.gradle.jvmargs=-XX:MaxHeapSize\=2048m -Xmx2048m

J
Jonathon Ogden

删除 gradle 中的 jar 文件 同步它 复制该 jar 并同步它

这对我有用。


您能更具体地说明哪些 jar 文件吗?是我们项目 gradle/wrapper 中的 jar 文件吗?
不知道人们提到“罐子”是什么意思。这说明不了什么。
S
Satan Pandeya

它仅使用特定服务对我有用。

例如,而不是使用:

compile 'com.google.android.gms:play-services:10.0.1'

我用了:

com.google.android.gms:play-services-places:10.0.1


同样在这里。我通过用 compile 'com.google.android.gms:play-services-location:10.2.0' 替换 compile 'com.google.android.gms:play-services:10.2.0' 解决了这个问题
C
Crime_Master_GoGo

解决方案 1:build.gradle 中:

defaultConfig {
    multiDexEnabled true
}

清理您的项目并重建。

解决方案 2:local.properties 中添加,

org.gradle.jvmargs=-XX\:MaxHeapSize\=512m -Xmx512m

溶胶 3

compile 'com.android.support:multidex:1.0.1'

否则在您的应用程序中添加所有 3 个。


K
KostasKol

我知道这是一个老问题,但仍然如此。每次这种情况发生在我身上,都是因为我已经包含了所有的播放服务库。只需在 build.gradle(module) 文件中将 play-services:xxx 更改为 play-service-:xxx


c
chancyWu

只需将 multiDexEnabled 设置为 true 即可。

    defaultConfig 
    {
        multiDexEnabled true     
    }

L
Leos Literak

我有同样的问题。有一天,该程序运行良好,而以下却不是。我在 Github 上查看了我所做的更改。对我来说,问题出在依赖项中的 build.gradle (Module:app) 上:

compile 'com.android.tools.build:gradle:2.1.2'

这条线是导致问题的线。更改后,应用程序再次正常运行


不工作任何其他机会>
改成什么?
我删除了它(我现在正在检查它)并且它一直在工作
M
Mark

我已将 jdk 更新为 1.8.0_74,将 Android-studio 更新为 2.1 preview 1 并添加到应用程序文件

@Override
protected void attachBaseContext(Context base) {
    super.attachBaseContext(base);
    MultiDex.install(this);
}

G
Ganesh P

将此行添加到您的 build.gradle

 defaultConfig {
    ............
    aaptOptions.cruncherEnabled = false
    aaptOptions.useNewCruncher = false
    compileOptions.encoding = 'ISO-8859-1'
    multiDexEnabled true
}

您在此处添加了哪个“行”?
B
Braj Bhushan Singh

在 DefaultConfig 添加 multiDexEnabled = true

    defaultConfig {
    applicationId "com.test"
    minSdkVersion 16
    targetSdkVersion 25
    versionCode 1
    versionName "1.0"
    multiDexEnabled = true
    testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
}

k
kriztho

因此,我的问题并没有通过添加 multiDexEnabled 标志得到解决。在收到错误消息之前它实际上就在那里。

为我解决该错误的是确保我使用的是所有播放服务库的相同版本。在一个库中,我有 11.8.0,但在使用该库的应用程序中,我使用的是 11.6.0,这种差异是导致错误消息的原因。

因此,与其将您的库更改为像以前的答案那样的特定版本,也许您想检查您是否使用相同的版本,因为 Android Studio 通过警告明确不鼓励混合版本。


K
Kush

经过大量的努力,我刚刚在凭证下方添加了我的成功

1) 应用程序-> 'proguard-rules.pro' 文件

-ignorewarnings

-keep class * {
    public private *;
}

2) 并且还添加在 app -> build.gradle 文件中

android {

        ...........................
    defaultConfig {
        ..................  

     multiDexEnabled true
    }


    buildTypes {
        debug {
            minifyEnabled true
            useProguard false
            proguardFiles getDefaultProguardFile('proguard-android.txt'),
                    'proguard-rules.pro'
        }
        release {
            minifyEnabled true
            proguardFiles getDefaultProguardFile('proguard-android.txt'),
                    'proguard-rules.pro'
        }
        innerTest {
            matchingFallbacks = ['debug', 'release']
        }

    }

...................................................
}

dependencies {
    ..................................
    implementation  'com.android.support:multidex:1.0.2'
}

v
vinod

默认情况下,Android Studio 的最大堆大小为 1280MB。如果您正在处理大型项目,或者您的系统有大量 RAM,您可以通过增加 Android Studio 进程(例如核心 IDE、Gradle 守护程序和 Kotlin 守护程序)的最大堆大小来提高性能。

如果您使用具有至少 5 GB RAM 的 64 位系统,您还可以手动调整项目的堆大小。为此,请按照下列步骤操作:

单击菜单栏中的文件 > 设置(或在 macOS 上单击 Android Studio > 首选项)。单击外观和行为 > 系统设置 > 内存设置。

更多信息请点击

https://developer.android.com/studio/intro/studio-config

https://i.stack.imgur.com/P8glf.png


N
Nazwa Asshiba

只需将 gradle(模块应用程序)中的 google play 服务从 9.xx 更改为较低版本 8.4.0 对我有用


这表明您使用的所有其他 Google Play 服务版本都不匹配。
M
MarJose

我修复了我添加到我的项目 > app > libs android volley.jar 的问题,我的问题得到了解决


您不需要 JAR 文件。 compile 'com.android.volley:volley:1.0.0' developer.android.com/training/volley/index.html
i
ismail alaoui

如果您在更新 google play services 9.8.0 后遇到问题,请将其添加到您的依赖项中:

`dependencies {
compile fileTree(include: ['*.jar'], dir: 'libs')
testCompile 'junit:junit:4.12'
compile 'com.google.firebase:firebase-messaging:9.8.0'
compile 'com.google.android.gms:play-services-maps:9.8.0'
compile 'com.google.android.gms:play-services-location:9.8.0'
compile 'com.google.firebase:firebase-database:9.8.0'
compile 'com.google.firebase:firebase-auth:9.8.0'
compile 'com.google.firebase:firebase-crash:9.8.0'
compile 'com.google.maps.android:android-maps-utils:0.4.4'
compile 'com.google.android.gms:play-services-appindexing:9.8.0'

}

P
Panduka DeSilva

这发生在我身上,即使在调试版本中,只是清除了所有模块级别和项目级别的构建文件夹,它就可以工作,是的,就像那样。


刚刚为我工作。
S
Serg Tomcat

对于那些仍在使用 VS-TACO 并遇到此问题的人。这是由于 jar 文件的版本不一致造成的。

您仍需要对 platforms\android 文件夹中的 build.gradle 文件添加更正:

 defaultConfig {
        multiDexEnabled true 
 }

 dependencies {
      compile 'com.android.support:multidex:1.0.3'
 }

如果有所有其他更改,最好在 build-extras.gradle 文件(自动链接到 build.gradle 文件)中执行所有其他更改,并删除 platforms/android 文件夹中的所有内容,但只保留 build-extras.gradle 文件。然后编译。


K
Keivan

这些答案都不适合我。我正在使用 Android Studio 3.4.1。

我能够构建该项目,但当我将其部署到移动设备时,Android Studio 显示此错误。事实证明这是“即时运行”错误。

按照这个答案:https://stackoverflow.com/a/42695197/3197467


K
Kyo Huu

我真的不知道怎么做,但是在我完成所有这些操作后,这个错误就消失了:

1

删除implementation 'com.google.android.gms:play-services:12.0.1'

并添加

implementation 'com.google.android.gms:play-services-location:12.0.1'
implementation 'com.google.android.gms:play-services-maps:12.0.1'
implementation 'com.google.android.gms:play-services-places:12.0.1'

2

更新 git、jdk、更改项目结构中的 JDK 位置

3

删除我的项目中的构建文件夹

4

清理并重建项目


关注公众号,不定期副业成功案例分享
关注公众号

不定期副业成功案例分享

领先一步获取最新的外包任务吗?

立即订阅