java - 为什么依赖关系只包含在发布版本中?

标签 java android android-gradle-plugin

从一个全新的 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

如果我使用 Android Studio 的 APK 分析器分析 app-debug.apk,我发现 APK 中没有包含我的两个依赖项中的任何内容,除了对 GsonBuilder:

APK Analyzer of Debug Build

我从命令行构建 (gradle clean assembleDebug) 得到了相同的结果。

但是,release 构建显示包含依赖项的 APK:

APK Analyzer of Release Build

如果我切换到这些 Artifact 的旧版本(com.google.code.gson:gson:2.3com.squareup.okhttp3:okhttp:3.2.0 ),它们会在 debug 构建中正确显示。问题是每个 Artifact ,所以如果我包括旧的 Gson 和新的 OkHttp,我的 debug 构建包含 Gson 类而不是 OkHttp 类。

因此,回顾一下:对于这些特定工​​件的这些特定版本,对于 debug 构建, Artifact 的内容不会添加到我的 APK 中。

问题是:为什么?

最佳答案

问题是 the new build cache 中的某种损坏.清除构建缓存可以解决问题。

我提交了 an issue关于这个,虽然因为我没有破坏构建缓存的可重现场景,这个问题的实用性可能有限。

关于java - 为什么依赖关系只包含在发布版本中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41188354/

相关文章:

java - 调用 Java/Scala 方法的最早方法是什么?

java - 使用 TableColumnModelListener 时如何知道哪些列已调整大小

Java - 从 OneDrive 公共(public)文件夹下载

java - 如果我在项目中使用的库已停止使用,会发生什么情况,我的应用程序会崩溃吗?

android - 有没有办法在 Android Gradle 项目中只运行一组特定的仪器测试?

java - HTTPS - Web 请求和响应是否已加密?

java - 启动 3d 派对应用程序后崩溃,该应用程序崩溃后

android - 权限拒绝 : receiving Intent { act=com. google.android.c2dm.intent.REGISTRATION

android - DexArchiveBuilderException : Failed to process/xxx/. gradle/caches/transforms-1/files-1.1/play-services-location-11.2.2.aar

android - 升级到 android studio 花栗鼠后,应用程序未安装在模拟器中