java - Gradle 项目 - 可以构建但不能运行它

标签 java android gradle

我的 Android 项目由 3 个 build.gradle 文件组成:

项目build.gradle:

// Top-level build file where you can add configuration options common to all sub-projects/modules.
buildscript {
    repositories {
//        mavenLocal()
        jcenter()
    }
    dependencies {
//        classpath 'com.android.tools.build:gradle:1.1.0'
        classpath 'com.android.tools.build:gradle:1.1.3'
    }
}

allprojects {
    repositories {
        jcenter()
    }
}

MYAPP build.gradle

apply plugin: 'com.android.library'
android {
    dexOptions {
        preDexLibraries = false
    }

    compileSdkVersion 17
    buildToolsVersion "21.1.1"

    defaultConfig {
        minSdkVersion 8
        targetSdkVersion 17
    }

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

dependencies {
    compile 'com.android.support:support-v4:18.0.0'
    compile files('libs/CWAC-AdapterWrapper.jar')
}

和 Facebook SDK:

apply plugin: 'com.android.library'

android {
    dexOptions {
        preDexLibraries = false
    }
    compileSdkVersion 8
    buildToolsVersion "21.1.1"

    defaultConfig {
        minSdkVersion 8
        targetSdkVersion 8
    }

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

dependencies {
    compile 'com.android.support:support-v4:18.0.0' 
}

我能够构建该项目,但无法运行它。异常(exception)是:

> Note: Some input files use or override a deprecated API. Note:
> Recompile with -Xlint:deprecation for details. Note: Some input files
> use unchecked or unsafe operations. Note: Recompile with
> -Xlint:unchecked for details. :awakenings:dexDebug UNEXPECTED TOP-LEVEL EXCEPTION: java.lang.IllegalArgumentException: already
> added: Ledu/mit/mobile/android/imagecache/DiskCache$1;    at
> com.android.dx.dex.file.ClassDefsSection.add(ClassDefsSection.java:122)
>   at com.android.dx.dex.file.DexFile.add(DexFile.java:161)    at
> com.android.dx.command.dexer.Main.processClass(Main.java:732)     at
> com.android.dx.command.dexer.Main.processFileBytes(Main.java:673)     at
> com.android.dx.command.dexer.Main.access$300(Main.java:82)    at
> com.android.dx.command.dexer.Main$1.processFileBytes(Main.java:602)
>   at
> com.android.dx.cf.direct.ClassPathOpener.processArchive(ClassPathOpener.java:284)
>   at
> com.android.dx.cf.direct.ClassPathOpener.processOne(ClassPathOpener.java:166)
>   at
> com.android.dx.cf.direct.ClassPathOpener.process(ClassPathOpener.java:144)
>   at com.android.dx.command.dexer.Main.processOne(Main.java:632)  at
> com.android.dx.command.dexer.Main.processAllFiles(Main.java:510)  at
> com.android.dx.command.dexer.Main.runMonoDex(Main.java:279)   at
> com.android.dx.command.dexer.Main.run(Main.java:245)  at
> com.android.dx.command.dexer.Main.main(Main.java:214)     at
> com.android.dx.command.Main.main(Main.java:106) UNEXPECTED TOP-LEVEL
> EXCEPTION: java.lang.IllegalArgumentException: already added:
> Lcom/facebook/AccessToken$1;  at
> com.android.dx.dex.file.ClassDefsSection.add(ClassDefsSection.java:122)
>   at com.android.dx.dex.file.DexFile.add(DexFile.java:161)    at
> com.android.dx.command.dexer.Main.processClass(Main.java:732)     at
> com.android.dx.command.dexer.Main.processFileBytes(Main.java:673)     at
> com.android.dx.command.dexer.Main.access$300(Main.java:82)    at
> com.android.dx.command.dexer.Main$1.processFileBytes(Main.java:602)
>   at
> com.android.dx.cf.direct.ClassPathOpener.processArchive(ClassPathOpener.java:284)
>   at
> com.android.dx.cf.direct.ClassPathOpener.processOne(ClassPathOpener.java:166)
>   at
> com.android.dx.cf.direct.ClassPathOpener.process(ClassPathOpener.java:144)
>   at com.android.dx.command.dexer.Main.processOne(Main.java:632)  at
> com.android.dx.command.dexer.Main.processAllFiles(Main.java:510)  at
> com.android.dx.command.dexer.Main.runMonoDex(Main.java:279)   at
> com.android.dx.command.dexer.Main.run(Main.java:245)  at
> com.android.dx.command.dexer.Main.main(Main.java:214)     at
> com.android.dx.command.Main.main(Main.java:106) 2 errors; aborting
> Error:Execution failed for task ':awakenings:dexDebug'.
> > com.android.ide.common.process.ProcessException: org.gradle.process.internal.ExecException: Process 'command
> 'C:\Program Files\Java\jdk1.8.0_20\bin\java.exe'' finished with
> non-zero exit value 1

有些东西是重复的,但我不知道是什么。您有任何想法为什么它不运行吗?

问题似乎是前 2 个模块在我的 DEX 中包含了两次

settings.gradle include ':androidImageCachemaster' include ':facebookSDK'

然后

¸¸dependencies { compile project(':facebookSDK') compile project(':androidImageCachemaster')

这是屏幕截图 enter image description here

最佳答案

文件中是否有一个名为DiskCache的函数: com.android.dx.command.Main.main

这似乎与 facebook sdk 中的功能冲突。尝试重命名您的函数

已更新------

在你的 build.grade 中试试这个。这应该编译依赖项,但将其从最终构建中排除:

android {
    compileSdkVersion x
    buildToolsVersion "x"

    packagingOptions {
        exclude 'support-v4'
    }
    ...
}

关于java - Gradle 项目 - 可以构建但不能运行它,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29633812/

相关文章:

java - hibernate 监听器异步吗?

java - 使用 java lambda 调用 kotlin 函数时,Kotlin 无法访问 kotlin.jvm.functions.Function1

Android ListView 斜体

android 在 firebase 中保存对象

android - Gradle 错误 : No value has been specified for property 'buildConfigPackageName'

java - 如何强制 Gradle 使用特定的 jar?

java - MapDB ClassNotFoundException : kotlin. jvm.internal.Intrinsics

java - 如何 "remove the gobal prefix('/api') 然后转到 lb ://"when migrate to spring cloud gateway from zuul

java - 使用 MuPDF 阅读在线 PDF 文件

安卓工作室 0.4 : Could not find method jniDir()