Intereting Posts
Настройка TextView TextAppeareance Programmatically в android Как отправлять / получать push-уведомления от ионного мобильного приложения? Как отлаживать, какие тревоги AlarmManager запускаются из вашего приложения? Ошибка при запуске run-android -variant = release (Task 'installReleaseDebug' не найден в корневом проекте 'gnosisapp'.) Как вставить значения double и float в sqlite? Расширяемый экран заголовка индикатора списка просмотров? Почему Android webview показывает «Далее» на клавиатуре, только если type = «number», а не с типом = «текст»? OnItemSelectedListener в фрагменте, который использует настраиваемый адаптер Мои представления сбрасываются при изменении ориентации Приложение для конкретного уникального устройства Как исключить конкретные ресурсы из-за зависимостей AAR? Как найти UUID устройства последовательного порта Bluetooth? Как предотвратить события щелчка на теле документа (возможно, ошибка в Кордове?) Установить состояние BottomSheetDialogFragment для расширенного Android: как включить / отключить Wi-Fi или подключение к Интернету программно

Почему зависимости могут быть включены только в выпуски?

Начиная с совершенно нового проекта Android Studio 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-анализатор отладки

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

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

Анализатор APK выпускает сборку

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

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

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

Solutions Collecting From Web of "Почему зависимости могут быть включены только в выпуски?"

Проблема заключалась в том, что в кэш новой сборки была какая-то коррупция. Проблема. Очистка кеша сборки устранена.

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