web-dev-qa-db-ja.com

原因:Java.lang.NoClassDefFoundError:ブートクラスローダーを使用してクラスが見つかりません。利用可能なスタックトレースはありません

Firebaseストレージからダウンロードした画像のディスクキャッシングにOkHttpとPicasso( この回答に続く )を使用してみました。現在、アプリは例外とクラッシュを提供します。私はこれらの投稿を見ました: 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'

フルスタックトレース

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:Redmanが言ったようにMultiDexを有効にしましたが、それでも同じエラーが発生します。これによると: developer.Android.com/studio/build/multidex.html#keep 、ベースAPKで必要なクラスを決定する必要があります。どのクラスが必要かを判断するにはどうすればよいですか?

14
Shubham Shukla

Android Studio 2.3以降では、コードに影響する可能性のあるInstant Runがあります。

Instant Runを無効にします

ファイル->設定->ビルド、実行、展開->インスタント実行

私の場合、Android Studioから実行すると完璧に機能しましたが、他のソースからインストールするとクラッシュしました

58
Kishore Jethava

1)携帯からアプリを親切にアンインストールします

2)Android studioからアプリを再インストールします

3)98%で動作します

9
Kulasekar

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'
 }
7
Manohar Reddy

プロジェクトのビルドフォルダーを削除してから、アプリケーションを削除して実行します。これは私のためにトリックをしました...

3
Rezaul Karim

USBケーブルを使用してデバイス上でコードをコンパイルしますが、*。apkファイルを使用してインストールしようとしたときに壊れていたため、オプションファイル->設定->ビルドのチェックを外しました、実行、展開->インスタント実行が、*。apkファイルで正常に動作し、USBインストールで壊れ始めると、OKを押してもエラーメッセージがattachecイメージにあります動作しません。もう一度インストールしようとすると、同じエラーメッセージが表示されます。

enter image description here

2
Shamim Ahmad

プロジェクトから。gradleフォルダーを削除してみてください。

1
Zon

問題に対する別の「答え」を見つけました。 Android St​​udio 3.3.2を使用して同じエラーメッセージが表示されていました。すべてのブレークポイントをクリアすることにしました。ブレークポイントダイアログには、Java例外ブレークポイントと例外ブレークポイントの2つの「永続的な」オプションがあります。おそらく偶然に両方をチェックしてもらいました。それらと他のブレークポイントをクリアすると、デバッグモードで実行できます。デバッグが実行されたので、それらがチェックされていない限り、ブレークポイントを追加できます!

0
Wild Will

私もこの問題を抱えていましたが、インスタントランをオフにすることはまだできません。\HDB Android\built-cache。このバグに遭遇した他の人々を助けることができれば幸いです。

0
hepeng

(これは古い質問ですが、同様の問題の解決策を求めてここに来ました。)

検討すべき別の答えがありますbefore上記の他のすべての提案を使い果たします:ClassNotFoundException:YourParcelableClassエラーは問題ではないかもしれません。実際にはそうではないかもしれません- a問題。

Parcelableとして渡され、WebViewでHTMLとしてレンダリングされるさまざまなコンテンツの画面を表示するアプリがあります。コードをクリーンアップし、チェックインし、クリーンな新しいツリーをチェックアウトし、携帯電話でアプリをアンインストールして再インストールするまで、うまくいきました。空白の画面が表示され始めました。ログのClassNotFoundExceptionは、コンテンツが正しく非整列化されていないことを意味していることは明らかです。

少なくともインスタントラン、_rm -rf .gradle_、プロジェクトのクリーン、キャッシュの無効化と再起動などを無効にしてから1時間後、私はそれがわかるまで、ますます健全性を疑うログを追加し始めましたI wasIntent.getParcelableExtra();からコンテンツを取得空白の画面は無関係であるように見えました! (まだ理由はわかりませんが、WebView.loadData()は動作を停止し、WebView.loadDataWithBaseURL()に置き換える必要がありました。)

うまくいけば、他の誰かが1時間の愚かさを救うことを願っています。クラスの名前でClassNotFoundExceptionが表示される場合は、オブジェクトがまだ正しく非整列化されているかどうかを確認してください。彼らかもしれない!

0
kuhrusty

私にとって、この問題はInstant Runを無効にするによって解決されました

[設定]-> [ビルド、実行、展開]-> [インスタント実行]->オプションを無効にするだけです。

そしてアプリを再起動します

0
Mayuresh Satao