引起:java.lang.NoClassDefFoundError:使用引导类加载器找不到类;没有堆栈跟踪可用

问题描述 投票:12回答:11

我尝试使用OkHttp和Picasso(following this answer)对我从Firebase存储下载的图像进行磁盘缓存。现在,该应用程序提供例外和崩溃。我看过这些帖子:post 1post 2但我没有找到任何相关的解决方案。我也试图清理和重建项目,但没有运气。

这是build.gradle:

apply plugin: 'com.android.application'

android {
    compileSdkVersion 25
    buildToolsVersion "25.0.2"
    defaultConfig {
        applicationId "social.com.networking.social.media.app"
        minSdkVersion 16
        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'
            multiDexEnabled true
        }
    }
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
        exclude group: 'com.android.support', module: 'support-annotations'
    })
    compile 'com.android.support:appcompat-v7:25.1.0'
    compile 'com.android.support:design:25.1.0'
    compile 'br.com.mauker.materialsearchview:materialsearchview:1.2.0'
    compile 'com.alirezaafkar:toolbar:1.1.1'
    compile 'com.github.mancj:MaterialSearchBar:0.3.5'
    compile 'com.squareup.picasso:picasso:2.5.2'
    compile 'com.nineoldandroids:library:2.4.0'
    compile 'com.daimajia.slider:library:1.1.5@aar'
    compile 'com.google.code.gson:gson:2.6.2'
    compile 'com.google.firebase:firebase-core:10.0.1'
    compile 'com.google.firebase:firebase-ads:10.0.1'
    compile 'com.google.firebase:firebase-messaging:10.0.1'
    compile "com.google.firebase:firebase-auth:10.0.1"
    compile 'com.google.firebase:firebase-storage:10.0.1'
    compile 'com.google.firebase:firebase-crash:10.0.1'
    compile 'com.squareup.okhttp3:okhttp:3.2.0'
    compile 'com.jakewharton.picasso:picasso2-okhttp3-downloader:1.0.2'
    compile 'com.android.support:multidex:1.0.1'

    compile 'org.parceler:parceler-api:1.1.6'
    annotationProcessor 'org.parceler:parceler:1.1.6'


    testCompile 'junit:junit:4.12'
}
apply plugin: 'com.google.gms.google-services'

完整Stacktrace:

Process: social.com.networking.social.media.app, PID: 28258
java.lang.NoClassDefFoundError: Failed resolution of: Lcom/squareup/okhttp/OkHttpClient;
at com.squareup.picasso.OkHttpDownloader.defaultOkHttpClient(OkHttpDownloader.java:31)
at com.squareup.picasso.OkHttpDownloader.<init>(OkHttpDownloader.java:76)
at com.squareup.picasso.OkHttpDownloader.<init>(OkHttpDownloader.java:65)
at social.com.networkingsocialmediaapp.Global.onCreate(Global.java:17)
at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1018)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4991)
at android.app.ActivityThread.-wrap1(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1555)
at android.os.Handler.dispatchMessage(Handler.java:111)
at android.os.Looper.loop(Looper.java:207)
at android.app.ActivityThread.main(ActivityThread.java:5776)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:679)

Caused by: java.lang.ClassNotFoundException: Didn't find class "com.squareup.okhttp.OkHttpClient" on path: DexPathList[[zip file "/data/app/social.com.networking.social.media.app-2/base.apk"],nativeLibraryDirectories=[/data/app/social.com.networking.social.media.app-2/lib/arm64, /vendor/lib64, /system/lib64]]
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.squareup.picasso.OkHttpDownloader.defaultOkHttpClient(OkHttpDownloader.java:31)
at com.squareup.picasso.OkHttpDownloader.<init>(OkHttpDownloader.java:76)
at com.squareup.picasso.OkHttpDownloader.<init>(OkHttpDownloader.java:65)
at social.com.networkingsocialmediaapp.Global.onCreate(Global.java:17)
at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1018)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4991)
at android.app.ActivityThread.-wrap1(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1555)
at android.os.Handler.dispatchMessage(Handler.java:111)
at android.os.Looper.loop(Looper.java:207)
at android.app.ActivityThread.main(ActivityThread.java:5776)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:679)

Suppressed: java.lang.ClassNotFoundException: com.squareup.okhttp.OkHttpClient
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)
... 15 more

Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack trace available

编辑1:我已经启用MultiDex,因为雷德曼说,但它仍然给出相同的错误。根据这个:developer.android.com/studio/build/multidex.html#keep,我需要决定基地APK中哪些类是必要的。如何确定哪些类是必要的?

java android android-studio android-gradle okhttp
11个回答
58
投票

在Android Studio 2.3及更高版本中,有一些可能会影响您的代码的即时运行。

禁用Instant Run

文件 - >设置 - >构建,执行,部署 - >即时运行

在我的情况下,它从Android Studio运行时工作正常,但从其他来源安装时崩溃


0
投票

我找到了另一个问题的“答案”。我使用Android Studio 3.3.2获得了相同的错误消息。我决定清除所有断点。在断点对话框中,有两个“永久”选项,Java异常断点和异常断点。我可能偶然检查过它们。当我清除它们和其他断点时,我可以在调试模式下运行。现在调试正在运行,我可以添加断点,只要不检查它们!


-1
投票

由于库版本规范的差异可能导致运行时错误,因此也会发生此错误。始终在build.gradle中使用相同版本的库。 例如:

用这个:

implementation 'com.google.android.gms:play-services-location:11.6.0'
implementation 'com.google.android.gms:play-services-auth:11.6.0'

代替:

implementation 'com.google.android.gms:play-services-location:15.0.0'
implementation 'com.google.android.gms:play-services-auth:11.6.0'

9
投票

1)请从手机上卸载应用程序

2)立即从android studio重新安装应用程序

3)98%它将工作否则清理项目并重新安装它


7
投票

您可能需要启用multidex,请遵循此指南

https://developer.android.com/studio/build/multidex.html,用于启用multidex

  defaultConfig {

    minSdkVersion 14
    targetSdkVersion 21

    multiDexEnabled true
}

 dependencies {
     compile 'com.android.support:multidex:1.0.0'
 }

3
投票

只需删除项目的构建文件夹,然后清理并运行您的应用程序。这对我来说很有用......


2
投票

我的代码方式在使用USB线的设备上编译得很好,但是当我尝试使用* .apk文件安装它时,它正在破坏,所以我取消选中文件 - >设置 - >构建,执行,部署 - >即时运行,但现在它与* .apk文件工作正常,并开始打破USB安装,错误消息是在attachec图像,即使我按OK它不起作用,当我尝试你再次安装它时出现相同的错误消息。

enter image description here


1
投票

尝试从项目中删除.gradle文件夹。


0
投票

我也遇到了这个问题,现在仍然无法关闭即时运行。后来,我发现删除了build-cache文件夹下的所有文件,然后清理了项目。我的目录是C:\ Users \ HDB。 Android \ built-cache。我希望我能帮助遇到这个bug的其他人。


0
投票

对我来说,这个问题是通过禁用即时运行解决的

只需转到首选项 - >构建,执行,部署 - >即时运行 - >禁用该选项

并重新启动应用程序


0
投票

(我知道这是一个老问题,但我来到这里寻找类似问题的解决方案。)

在用尽所有其他建议之前,我有一个不同的答案需要考虑:ClassNotFoundException:YourParcelableClass错误可能不是问题。事实上,这可能不是问题。

我有一个应用程序,它显示各种内容的屏幕,它作为Parcelable传入并在WebView中呈现为HTML;它工作得很好,直到我清理代码,检查它,签出一个干净的新树,并在我的手机上卸载并重新安装该应用程序。我开始变空白了;很明显,日志中的ClassNotFoundException意味着我的内容没有被正确解组。

在禁用Instant Run,rm -rf .gradle,Clean Project,Invalidate Caches和Restart等等至少一个小时之后,我开始添加越来越严谨的日志记录,直到我发现我从Intent.getParcelableExtra()获取我的内容;空白屏幕似乎无关! (我仍然不知道为什么,但WebView.loadData()已停止工作,不得不用WebView.loadDataWithBaseURL()取代。)

希望这可以节省别人一小时的愚蠢。如果您看到带有类名称的ClassNotFoundException,请检查您的对象是否仍在正确解组;他们可能会!

© www.soinside.com 2019 - 2024. All rights reserved.