2016-12-16 3 views
7

Начиная с совершенно новым Android проектом студии 2.2.3, принимая все значения по умолчанию, за исключением выбирает из AppCompat, я добавил два зависимостей в app/build.gradle:Зачем устанавливать зависимости только в выпусках?

apply plugin: 'com.android.application' 

android { 
    compileSdkVersion 25 
    buildToolsVersion "25.0.0" 
    defaultConfig { 
    applicationId "com.commonsware.myapplication" 
    minSdkVersion 15 
    targetSdkVersion 25 
    versionCode 1 
    versionName "1.0" 
    testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" 
    } 
    buildTypes { 
    release { 
     minifyEnabled false 
     proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' 
    } 
    } 
} 

dependencies { 
    compile 'com.google.code.gson:gson:2.4' 
    compile 'com.squareup.okhttp3:okhttp:3.5.0' 
    androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', { 
    exclude group: 'com.android.support', module: 'support-annotations' 
    }) 
    testCompile 'junit:junit:4.12' 
} 

Там нет никаких проблем во время компиляции, даже если я ссылка классы от Gson или OkHttp. Тем не менее, я запустить приложение из Android Studio и получить Страшный NoClassDefFoundError:

12-16 10:48:52.175 15687-15687/com.commonsware.myapplication E/AndroidRuntime: FATAL EXCEPTION: main 
    Process: com.commonsware.myapplication, PID: 15687 
    java.lang.NoClassDefFoundError: Failed resolution of: Lcom/google/gson/GsonBuilder; 
     at com.commonsware.myapplication.MainActivity.onCreate(MainActivity.java:13) 
     at android.app.Activity.performCreate(Activity.java:6251) 
     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1107) 
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2369) 
     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476) 
     at android.app.ActivityThread.-wrap11(ActivityThread.java) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344) 
     at android.os.Handler.dispatchMessage(Handler.java:102) 
     at android.os.Looper.loop(Looper.java:148) 
     at android.app.ActivityThread.main(ActivityThread.java:5417) 
     at java.lang.reflect.Method.invoke(Native Method) 
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616) 
    Caused by: java.lang.ClassNotFoundException: Didn't find class "com.google.gson.GsonBuilder" on path: DexPathList[[zip file "/data/app/com.commonsware.myapplication-1/base.apk"],nativeLibraryDirectories=[/data/app/com.commonsware.myapplication-1/lib/arm, /vendor/lib, /system/lib]] 
     at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56) 
     at java.lang.ClassLoader.loadClass(ClassLoader.java:511) 
     at java.lang.ClassLoader.loadClass(ClassLoader.java:469) 
     at com.commonsware.myapplication.MainActivity.onCreate(MainActivity.java:13)  
     at android.app.Activity.performCreate(Activity.java:6251)  
     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1107)  
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2369)  
     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2476)  
     at android.app.ActivityThread.-wrap11(ActivityThread.java)  
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1344)  
     at android.os.Handler.dispatchMessage(Handler.java:102)  
     at android.os.Looper.loop(Looper.java:148)  
     at android.app.ActivityThread.main(ActivityThread.java:5417)  
     at java.lang.reflect.Method.invoke(Native Method)  
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)  
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)  
    Suppressed: java.lang.ClassNotFoundException: com.google.gson.GsonBuilder 
     at java.lang.Class.classForName(Native Method) 
     at java.lang.BootClassLoader.findClass(ClassLoader.java:781) 
     at java.lang.BootClassLoader.loadClass(ClassLoader.java:841) 
     at java.lang.ClassLoader.loadClass(ClassLoader.java:504) 
      ... 14 more 
    Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack trace available 

Если я использую APK Analyzer Android Studio, чтобы анализировать app-debug.apk, я вижу, что ничего из моих двух зависимостей не входит в APK, за исключением ссылка на GsonBuilder:

APK Analyzer of Debug Build

я получаю те же результаты из командной строки сборки (gradle clean assembleDebug).

Однако release сборки показывает APK с зависимостями включено:

APK Analyzer of Release Build

Если переключиться на более старые версии этих артефактов (com.google.code.gson:gson:2.3 и com.squareup.okhttp3:okhttp:3.2.0), они показывают должным образом в debug строит. Проблема в артефактах, поэтому, если я включаю более старый Gson и новый OkHttp, мои сборки debug содержат классы Gson, а не OkHttp.

Итак, чтобы напомнить: для этих конкретных версий этих конкретных артефактов для построения debug содержимое артефактов не добавляется в мой APK.

Вопрос в том, почему?

ответ

4

Проблема была какая-то коррупция в the new build cache. Проблема. Очистка кеша сборки устранена.

Об этом я сообщил an issue, хотя, поскольку у меня нет воспроизводимого сценария для разложения кеша сборки, проблема может быть ограниченной.

+3

Я всегда представляю эту уникальную особенность общественных форумов - вы можете бороться с проблемой часами, но как только вы спросите ... tadaaam :) вы мгновенно находите решение самостоятельно в большинстве случаев :) –

+0

@MarcinOrlowski: In В этом случае у меня был почти полностью написан вопрос, когда вошел сборник кеша сборки. После очистки кеша выяснилась проблема, я подал этот вопрос и подумал, что я могу также поставить вопрос плюс ответ, так как я прошел через работу по написанию вопроса. :-) – CommonsWare