Причина: java.lang.NoClassDefFoundError: Ошибка разрешения: Lcom / google / android / gms / common / util / Function; - PullRequest
0 голосов
/ 09 ноября 2018

Я получаю эту ошибку:

Caused by: java.lang.NoClassDefFoundError: Failed resolution of: Lcom/google/android/gms/common/util/Function;  

Вот полный вывод:

2018-11-09 18:33:22.546 24224-24224/com.test.notes.notes E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.test.notes.notes, PID: 24224
    java.lang.RuntimeException: Internal error in Firestore (0.6.6-dev).
        at com.google.android.gms.internal.firebase-firestore.zzkj.run(Unknown Source)
        at android.os.Handler.handleCallback(Handler.java:751)
        at android.os.Handler.dispatchMessage(Handler.java:95)
        at android.os.Looper.loop(Looper.java:241)
        at android.app.ActivityThread.main(ActivityThread.java:6274)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776)
     Caused by: java.lang.NoClassDefFoundError: Failed resolution of: Lcom/google/android/gms/common/util/Function;
        at com.google.android.gms.internal.firebase-firestore.zzfu.zzd(Unknown Source)
        at com.google.android.gms.internal.firebase-firestore.zzeg.<init>(Unknown Source)
        at com.google.android.gms.internal.firebase-firestore.zzcj.zza(Unknown Source)
        at com.google.android.gms.internal.firebase-firestore.zzcl.run(Unknown Source)
        at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:428)
        at java.util.concurrent.FutureTask.run(FutureTask.java:237)
        at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:272)
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607)
        at com.google.android.gms.internal.firebase-firestore.zzkg$zza.run(Unknown Source)
        at java.lang.Thread.run(Thread.java:761)
     Caused by: java.lang.ClassNotFoundException: Didn't find class "com.google.android.gms.common.util.Function" on path: DexPathList[[zip file "/data/app/com.test.notes.notes-1/base.apk", zip file "/data/app/com.test.notes.notes-1/split_lib_dependencies_apk.apk", zip file "/data/app/com.test.notes.notes-1/split_lib_slice_0_apk.apk", zip file "/data/app/com.test.notes.notes-1/split_lib_slice_1_apk.apk", zip file "/data/app/com.test.notes.notes-1/split_lib_slice_2_apk.apk", zip file "/data/app/com.test.notes.notes-1/split_lib_slice_3_apk.apk", zip file "/data/app/com.test.notes.notes-1/split_lib_slice_4_apk.apk", zip file "/data/app/com.test.notes.notes-1/split_lib_slice_5_apk.apk", zip file "/data/app/com.test.notes.notes-1/split_lib_slice_6_apk.apk", zip file "/data/app/com.test.notes.notes-1/split_lib_slice_7_apk.apk", zip file "/data/app/com.test.notes.notes-1/split_lib_slice_8_apk.apk", zip file "/data/app/com.test.notes.notes-1/split_lib_slice_9_apk.apk"],nativeLibraryDirectories=[/data/app/com.test.notes.notes-1/lib/arm64, /system/lib64, /vendor/lib64]]
        at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:380)
        at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
        at com.google.android.gms.internal.firebase-firestore.zzfu.zzd(Unknown Source) 
        at com.google.android.gms.internal.firebase-firestore.zzeg.<init>(Unknown Source) 
        at com.google.android.gms.internal.firebase-firestore.zzcj.zza(Unknown Source) 
        at com.google.android.gms.internal.firebase-firestore.zzcl.run(Unknown Source) 
        at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:428) 
        at java.util.concurrent.FutureTask.run(FutureTask.java:237) 
        at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:272) 
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1133) 
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:607) 
        at com.google.android.gms.internal.firebase-firestore.zzkg$zza.run(Unknown Source) 
        at java.lang.Thread.run(Thread.java:761) 
        Suppressed: java.io.IOException: No original dex files found for dex location /data/app/com.test.notes.notes-1/split_lib_slice_7_apk.apk
        at dalvik.system.DexFile.openDexFileNative(Native Method)
        at dalvik.system.DexFile.openDexFile(DexFile.java:367)
        at dalvik.system.DexFile.<init>(DexFile.java:112)
        at dalvik.system.DexFile.<init>(DexFile.java:77)
        at dalvik.system.DexPathList.loadDexFile(DexPathList.java:359)
        at dalvik.system.DexPathList.makeElements(DexPathList.java:323)
        at dalvik.system.DexPathList.makeDexElements(DexPathList.java:263)
        at dalvik.system.DexPathList.<init>(DexPathList.java:126)
        at dalvik.system.BaseDexClassLoader.<init>(BaseDexClassLoader.java:48)
        at dalvik.system.PathClassLoader.<init>(PathClassLoader.java:64)
        at com.android.internal.os.PathClassLoaderFactory.createClassLoader(PathClassLoaderFactory.java:43)
        at android.app.ApplicationLoaders.getClassLoader(ApplicationLoaders.java:58)
        at android.app.LoadedApk.createOrUpdateClassLoaderLocked(LoadedApk.java:541)
2018-11-09 18:33:22.546 24224-24224/com.test.notes.notes E/AndroidRuntime:     at android.app.LoadedApk.getClassLoader(LoadedApk.java:574)
        at android.app.ActivityThread.getTopLevelResources(ActivityThread.java:1900)
        at android.app.LoadedApk.getResources(LoadedApk.java:787)
        at android.app.ContextImpl.<init>(ContextImpl.java:2038)
        at android.app.ContextImpl.createAppContext(ContextImpl.java:1983)
        at android.app.ActivityThread.handleBindApplication(ActivityThread.java:5439)
        at android.app.ActivityThread.-wrap2(ActivityThread.java)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1576)
        at android.os.Handler.dispatchMessage(Handler.java:102)
        at android.os.Looper.loop(Looper.java:241)
        at android.app.ActivityThread.main(ActivityThread.java:6274)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776)

И я думаю, что мой build.gradle необходим, так что вот мой build.gradle (Project: test):

apply plugin: 'com.android.application'
apply plugin: 'io.fabric'

android {
    compileSdkVersion 27
    buildToolsVersion '28.0.3'
    defaultConfig {
        applicationId "com.test.notes.notes"
        minSdkVersion 16
        targetSdkVersion 27
        versionCode 17
        versionName "5.1.0"
        testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
        vectorDrawables.useSupportLibrary = true
    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
    lintOptions {
        checkReleaseBuilds false
    }
    aaptOptions {
        cruncherEnabled = false
    }
}

dependencies {
    implementation fileTree(dir: 'libs', include: ['*.jar'])
    implementation 'com.android.support:appcompat-v7:27.0.2'
    implementation 'com.android.support:design:27.0.2'
    implementation 'com.android.support:cardview-v7:27.0.2'
    implementation 'com.android.support.constraint:constraint-layout:1.1.3'
    implementation 'com.android.support:support-v4:27.0.2'
    implementation 'com.android.support:support-vector-drawable:27.0.2'

    implementation 'com.google.firebase:firebase-firestore:15.0.0'
    implementation 'com.firebaseui:firebase-ui-firestore:3.1.1'

    api 'com.joooonho:selectableroundedimageview:1.0.1'
    api 'com.github.bumptech.glide:glide:3.7.0'

    testImplementation 'junit:junit:4.12'
    androidTestImplementation 'com.android.support.test:runner:1.0.2'
    androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2'

    api 'com.google.firebase:firebase-core:16.0.5'
    api 'com.google.firebase:firebase-firestore:15.0.0'
    api 'com.google.firebase:firebase-storage:16.0.4'
    api 'com.google.firebase:firebase-auth:16.0.5'

    api 'com.crashlytics.sdk.android:crashlytics:2.9.5'
}

apply plugin: 'com.google.gms.google-services'

С этой ошибкой приложение вылетает.
Я думаю, что может быть что-то не так с Firebase SDK, но не можете понять это?
Пожалуйста, помогите мне исправить это. Давно не нашел способа это исправить. :(

EDIT:
После обновил все до последней версии и добавил:

multiDexEnabled true  

... все отлично работает. Но теперь у меня есть проблема, почему я окончательно понизил версию. Пожалуйста, посмотрите на мой вопрос: я не получил ответ:
Обновление кода после firebase 16.0. + Update

Когда я смогу это исправить, все будет хорошо.

1 Ответ

0 голосов
/ 09 ноября 2018

Я вижу целую кучу проблем в вашем build.gradle.

Первая категория проблем заключается в том, что большинство ваших зависимостей устарели.

  • Библиотеки поддержки Android API 27 включены в 27.1.1, а не в 27.0.2.
  • firebase-firestore 17.1.2, а не 15.0.0.
  • firebase-ui-firestore на 4.2.1, а не на 2.1.1.
  • glide на 4.8.0, а не 3.7.0.

Версии зависимостей должны быть в целом актуальными, но абсолютно должны быть актуальными, если они от Google. В противном случае вы получите именно тот тип ошибки, который у вас есть.

Вторая проблема заключается в том, что вы реализуете firebase-firestore дважды, один раз с implementation и снова с api. Удалите одно или другое.

Полезный совет: если зависимость выделена желтым цветом, означает, что она устарела! Нажмите на текст, нажмите Alt + Введите и выберите параметр обновить его до последней версии.

...