2016-01-15 25 views
6

So che questa domanda è stata già posta ma non riesco a trovare una risposta adatta al mio problema tra le soluzioni disponibili. Spero che voi ragazzi potete aiutarmi.Gradle - DexException: più file dex definiscono

L'eccezione indica che Multiple dex files defined e ho provato diversi modi comuni per risolvere questo problema. Sfortunatamente, questo non ha aiutato.

* What went wrong: 
Execution failed for task ':app:transformClassesWithDexForDebug'. 
> com.android.build.api.transform.TransformException: com.android.ide.common.process.ProcessException: org.gradle.process.internal.ExecException: Process 'command '/Library/Java/JavaVirtualMachines/jdk1.7.0_79.jdk/Contents/Home/bin/java'' finished with non-zero exit value 2 



Cause: com.android.dex.DexException: Multiple dex files define Lnet/jcip/annotations/GuardedBy; 
     UNEXPECTED TOP-LEVEL EXCEPTION: 
     com.android.dex.DexException: Multiple dex files define Lnet/jcip/annotations/GuardedBy; 
      at com.android.dx.merge.DexMerger.readSortableTypes(DexMerger.java:579) 
      at com.android.dx.merge.DexMerger.getSortedTypes(DexMerger.java:535) 
      at com.android.dx.merge.DexMerger.mergeClassDefs(DexMerger.java:517) 
      at com.android.dx.merge.DexMerger.mergeDexes(DexMerger.java:164) 
      at com.android.dx.merge.DexMerger.merge(DexMerger.java:188) 
      at com.android.dx.command.dexer.Main.mergeLibraryDexBuffers(Main.java:504) 
      at com.android.dx.command.dexer.Main.runMonoDex(Main.java:334) 
      at com.android.dx.command.dexer.Main.run(Main.java:277) 
      at com.android.dx.command.dexer.Main.main(Main.java:245) 
      at com.android.dx.command.Main.main(Main.java:106) 
  1. ho cercato di pulire e rigenerare il progetto.

    • Build -> Clean Progetto
    • Build -> Ricostruisci Progetto
  2. Poi ho cercato di invalidare cache e riavviare.

    • File -> Disattiva cache e Restart
  3. Ho anche eseguire questo comando per capire le duplicazioni di dipendenze:

    ./gradlew q Dipendenze app: le dipendenze --configuration compile --stacktrace

e qui è l'uscita. Come puoi vedere non ci sono duplicazioni.

+--- com.jakewharton.hugo:hugo-annotations:1.2.1 
+--- com.google.code.findbugs:annotations:3.0.1 
| +--- net.jcip:jcip-annotations:1.0 
| \--- com.google.code.findbugs:jsr305:3.0.1 
+--- com.michaelpardo:activeandroid:3.1.0-SNAPSHOT 
+--- com.android.support:appcompat-v7:23.1.1 
+--- com.crashlytics.sdk.android:crashlytics:2.3.0 
| +--- com.crashlytics.sdk.android:crashlytics-core:2.3.0 
| | \--- io.fabric.sdk.android:fabric:1.3.1 
| +--- io.fabric.sdk.android:fabric:1.3.1 
| \--- com.crashlytics.sdk.android:beta:1.1.2 
|   \--- io.fabric.sdk.android:fabric:1.2.0 -> 1.3.1 
+--- com.greenhalolabs:emailautocompletetextview:1.3.0 
+--- com.facebook.android:facebook-android-sdk:4.2.0 
| \--- com.parse.bolts:bolts-android:1.2.0 
+--- com.android.support:cardview-v7:23.1.1 
+--- com.jakewharton.hugo:hugo-runtime:1.2.0 
| +--- com.jakewharton.hugo:hugo-annotations:1.2.0 -> 1.2.1 
| \--- org.aspectj:aspectjrt:1.8.5 
+--- joda-time:joda-time:2.0 
+--- io.keen:keen-client-api-android:2.1.2 
+--- com.googlecode.libphonenumber:libphonenumber:6.3.1 
+--- net.simonvt.menudrawer:menudrawer:3.0.6 
+--- com.squareup:otto:1.3.0 
+--- com.google.android.gms:play-services-base:8.4.0 
| \--- com.google.android.gms:play-services-basement:8.4.0 
+--- com.google.android.gms:play-services-analytics:8.4.0 
+--- com.google.android.gms:play-services-gcm:8.4.0 
| \--- com.google.android.gms:play-services-measurement:8.4.0 
+--- com.jeremyfeinstein.slidingmenu:library:1.3 
+--- com.android.support:support-v4:23.1.1 
| \--- com.android.support:support-annotations:23.1.1 
+--- com.jakewharton.timber:timber:3.1.0 
+--- com.viewpagerindicator:library:2.4.1 
+--- com.ouralabs:ouralabs:2.7.0 
+--- com.android.support.test.espresso:espresso-idling-resource:2.2.1 
+--- project :domain 
| \--- joda-time:joda-time:2.0 
\--- project :remote 
    +--- com.squareup.retrofit:retrofit:1.6.0 
    | \--- com.google.code.gson:gson:2.2.4 
    +--- com.squareup.okhttp:okhttp:2.4.0 
    | \--- com.squareup.okio:okio:1.4.0 
    \--- com.squareup.okhttp:okhttp-urlconnection:2.4.0 
  1. Ho anche letto che il multiDexEnabled true ma sono sicuro che non mi superare il limite dei metodi. Questo problema è apparso istantaneamente e senza aggiungere alcuna libreria. Non riesco nemmeno a assemblare le vecchie versioni di produzione del codice. Sono in produzione e assolutamente compilabili.

build.gradle del modulo:

dependencies { 
    apply plugin: 'idea' 

    compile "com.michaelpardo:activeandroid:${rootProject.ext.activeandroid}" 
    compile(group: 'com.google.code.findbugs', name: 'annotations', version: "${rootProject.ext.findbugs}") { 
     exclude(group: 'net.jcip', module: 'jcip-annotations') 
    } 
    compile(group: 'com.android.support', name: 'appcompat-v7', version: "${rootProject.ext.supportv4}") { 
     exclude(group: 'com.android.support', module: 'support-v4') 
    } 
    compile(group: 'com.crashlytics.sdk.android', name: 'crashlytics', version: "${rootProject.ext.crashlytics}") { 
     exclude(group: 'com.crashlytics.sdk.android', module: 'answers') 
    } 
    compile "com.greenhalolabs:emailautocompletetextview:${rootProject.ext.emailautocomplete}" 
    compile(group: 'com.facebook.android', name: 'facebook-android-sdk', version: "${rootProject.ext.facebook}") { 
     exclude(group: 'com.android.support', module: 'support-v4') 
    } 
    compile "com.android.support:cardview-v7:${rootProject.ext.supportv4}" 
    compile "com.jakewharton.hugo:hugo-runtime:${rootProject.ext.hugo}" 
    compile "joda-time:joda-time:${rootProject.ext.jodatime}" 
    compile "io.keen:keen-client-api-android:${rootProject.ext.keen}" 
    compile "com.googlecode.libphonenumber:libphonenumber:${rootProject.ext.libphonenumber}" 
    compile "net.simonvt.menudrawer:menudrawer:${rootProject.ext.menudrawer}" 
    compile "com.squareup:otto:${rootProject.ext.otto}" 
    compile(group: 'com.google.android.gms', name: 'play-services-base', version: "${rootProject.ext.playservices}") { 
     exclude(group: 'com.android.support', module: 'support-v4') 
    } 
    compile(group: 'com.google.android.gms', name: 'play-services-analytics', version: "${rootProject.ext.playservices}") { 
     exclude(group: 'com.google.android.gms', module: 'play-services-basement') 
    } 
    compile(group: 'com.google.android.gms', name: 'play-services-gcm', version: "${rootProject.ext.playservices}") { 
     exclude(group: 'com.google.android.gms', module: 'play-services-base') 
     exclude(group: 'com.google.android.gms', module: 'play-services-basement') 
    } 
    compile "com.jeremyfeinstein.slidingmenu:library:${rootProject.ext.slidingmenu}" 
    compile "com.android.support:support-v4:${rootProject.ext.supportv4}" 
    compile "com.jakewharton.timber:timber:${rootProject.ext.timber}" 
    compile "com.viewpagerindicator:library:${rootProject.ext.viewpagerindicator}" 
    compile "com.ouralabs:ouralabs:${rootProject.ext.ouralabs}" 
    compile "com.android.support.test.espresso:espresso-idling-resource:$rootProject.ext.espressoVersion" 

    compile project(':domain') 
    compile(project(':remote')) { 
     exclude module: 'domain' 
    } 

    // Local Unit testing 
    testCompile "junit:junit:$rootProject.ext.junit" 
    testCompile "org.mockito:mockito-all:$rootProject.ext.mockitoVersion" 
    testCompile "org.hamcrest:hamcrest-all:$rootProject.ext.hamcrestVersion" 

    // Instrumentation Testing 
    androidTestCompile "com.android.support.test.espresso:espresso-core:$rootProject.ext.espressoVersion" 
    androidTestCompile "com.android.support.test.espresso:espresso-contrib:$rootProject.ext.espressoVersion" 
    androidTestCompile "com.android.support.test.espresso:espresso-intents:$rootProject.ext.espressoVersion" 
    androidTestCompile "com.android.support.test.uiautomator:uiautomator-v18:$rootProject.ext.uiautomator" 
    androidTestCompile "com.android.support.test:runner:$rootProject.ext.runnerVersion" 
    androidTestCompile "com.android.support.test:rules:$rootProject.ext.runnerVersion" 
    androidTestCompile "org.mockito:mockito-core:$rootProject.ext.mockitoVersion" 
    androidTestCompile "com.google.dexmaker:dexmaker:$rootProject.ext.dexmaker" 
    androidTestCompile "com.google.dexmaker:dexmaker-mockito:$rootProject.ext.dexmaker" 
} 

UPDATE

ho controllato il progetto per GuardedBy. Sembra duplicazione?

enter image description here

+0

Succede perché si aggiungono più classi net/jcip/annotations/GuardedBy. Controlla i tuoi file jar. –

+0

@GabrieleMariotti ma come escludere questa duplicazione? Puoi scrivere una risposta, per favore? – Val

+0

Sto cercando di capire il tuo problema. Prima di tutto controlla se stai usando questi jar nella cartella libs o se li stai prendendo da altre librerie. Il problema potrebbe essere che si sta utilizzando una versione diversa della stessa classe. –

risposta

1

Sembra hugo-annotations è incluso due volte. È una dipendenza di hugo-runtime e aggiunta da qualche altra parte. Prova a escludere dal hugo-runtime

compile("com.jakewharton.hugo:hugo-runtime:${rootProject.ext.hugo}") { 
    exclude(group: 'com.jakewharton.hugo' module: 'hugo-annotations') 
} 

Anche perché l'errore è dovuto alla libreria JSR può avere bisogno di escluderlo dal findbugs dipendenza.

compile(group: 'com.google.code.findbugs', name: 'annotations', version: "${rootProject.ext.findbugs}") { 
    exclude(group: 'net.jcip', module: 'jcip-annotations') 
    exclude(group: 'com.google.code.findbugs', module: 'jsr305') 
} 

Edit:

C'è un'opzione nucleare se davvero non può trovare, ma non sono sicuro se sarebbe rompere qualcos'altro o è delle migliori pratiche. Questo rimuove completamente il jsr305 dal classpath.

dependencies { 
    ... 
} 
configurations.all*.exclude module: 'jsr305' 
+0

Sfortunatamente, ho la stessa eccezione. Grazie per la risposta. – Val

+0

Puoi provare la modifica ma ciò potrebbe avere effetti negativi sugli strumenti quando vengono eseguiti i findbug – JBirdVegas

0

Controlla i file jar. È possibile espandere i file in Project Explorer. Se ha percorso non necessario e BuildConfig, si dovrebbe verificare DexException.