[英]Gradle project - can build but not run it
My Android project consist of 3 build.gradle
files: 我的Android项目包含3个
build.gradle
文件:
Projects 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
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')
}
and Facebook SDK: 和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'
}
I am able to build the project but not to run it. 我能够构建该项目,但无法运行它。 The exception is:
例外是:
> 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
Something is duplicated but I don't know what. 某些东西重复了,但我不知道。 Have you got any ideas why it does not run?
您有任何想法为什么它不运行吗?
The problem seems to be that first 2 modules are included TWICE in my DEX 问题似乎是我的DEX中包括TWICE的前两个模块
settings.gradle include ':androidImageCachemaster' include ':facebookSDK'
settings.gradle包括':androidImageCachemaster'包括':facebookSDK'
and then 接着
¸¸dependencies { compile project(':facebookSDK') compile project(':androidImageCachemaster')
¸¸依赖项{编译项目(':facebookSDK')编译项目(':androidImageCachemaster')
Here is the screen shot 这是屏幕截图
Is there a function called DiskCache in the file: com.android.dx.command.Main.main 文件中是否存在一个名为DiskCache的函数:com.android.dx.command.Main.main
This seems to be conflicting with a function in the facebook sdk. 这似乎与facebook sdk中的功能冲突。 Try to rename your funciton
尝试重命名您的功能
UPDATED------- 更新 - - - -
Try this instead in your build.grade. 请在build.grade中尝试此操作。 This should compile the dependency but exclude it from the final build:
这应该编译依赖项,但将其从最终版本中排除:
android {
compileSdkVersion x
buildToolsVersion "x"
packagingOptions {
exclude 'support-v4'
}
...
}
build.gradle
: build.gradle
: // Top-level build file where you can add configuration options common to all sub-projects/modules.
buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:1.1.3'
}
}
allprojects {
repositories {
jcenter()
}
}
Download the Facebook for Android Gradle library here: https://developers.facebook.com/docs/android . 在此处下载适用于Android的Facebook Gradle库: https : //developers.facebook.com/docs/android 。
Import it as a module to your own project. 将其作为模块导入到您自己的项目中。
It will add it as a module. 它将添加为模块。 So add to your own
build.gradle
, compile project(':facebook-android-sdk-4.0.1')
as a dependency. 因此,添加到您自己的
build.gradle
,将compile project(':facebook-android-sdk-4.0.1')
作为依赖项进行compile project(':facebook-android-sdk-4.0.1')
。
app/build.gradle
: app/build.gradle
: Download the Facebook for Android Gradle library here: https://developers.facebook.com/docs/android . 在此处下载适用于Android的Facebook Gradle库: https : //developers.facebook.com/docs/android 。
apply plugin: 'com.android.application' // changed to application
android {
compileSdkVersion 22 // <-- updated
buildToolsVersion "22.0.1" // <-- updated
defaultConfig {
minSdkVersion 11 // <-- updated
targetSdkVersion 22 // <-- updated
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt'
}
}
}
dependencies {
compile 'com.android.support:support-v4:22.0.0' // <-- updated
compile files('libs/CWAC-AdapterWrapper.jar')
// compile project(':facebook-android-sdk-4.0.1') // <-- something like this
}
The answer to the problem was this: My project included these 2 modules twice: 问题的答案是:我的项目两次包含这两个模块:
'androidImageCachemaster' 'androidImageCachemaster'
'facebookSDK' 'facebookSDK'
after I removed references from the project everything run smooth. 从项目中删除引用后,一切运行顺利。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.