android - Firebase runloop (3.0.0) 中的未捕获异常

标签 android firebase

我使用的是最新的 firebase(9.0.2): build.gradle:

dependencies {
     ...
     compile "com.google.firebase:firebase-database:9.0.2"
     compile 'com.google.firebase:firebase-auth:9.0.2'
}
apply plugin: 'com.google.gms.google-services'

项目build.gradle

classpath 'com.google.gms:google-services:3.0.0'

一段时间后,应用程序开始崩溃并出现此异常:

  Fatal Exception: java.lang.RuntimeException: Uncaught exception in Firebase runloop (3.0.0). Please report to support@firebase.com
       at com.google.android.gms.internal.zzadp$1$1.run(Unknown Source)
       at android.os.Handler.handleCallback(Handler.java:739)
       at android.os.Handler.dispatchMessage(Handler.java:95)
       at android.os.Looper.loop(Looper.java:135)
       at android.app.ActivityThread.main(ActivityThread.java:5274)
       at java.lang.reflect.Method.invoke(Method.java)
       at java.lang.reflect.Method.invoke(Method.java:372)
       at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:909)
       at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:704)
Caused by java.lang.AssertionError: hardAssert failed: 
       at com.google.android.gms.internal.zzaiv.zzb(Unknown Source)
       at com.google.android.gms.internal.zzaiv.zzaN(Unknown Source)
       at com.google.android.gms.internal.zzagh.zzb(Unknown Source)
       at com.google.android.gms.internal.zzagh.<init>(Unknown Source)
       at com.google.android.gms.internal.zzaga.<init>(Unknown Source)
       at com.google.android.gms.internal.zzaga.<init>(Unknown Source)
       at com.google.android.gms.internal.zzadp.zza(Unknown Source)
       at com.google.android.gms.internal.zzaeu.zzic(Unknown Source)
       at com.google.android.gms.internal.zzafc.zzRy(Unknown Source)
       at com.google.android.gms.internal.zzafc.zza(Unknown Source)
       at com.google.android.gms.internal.zzafc$1.run(Unknown Source)
       at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:422)
       at java.util.concurrent.FutureTask.run(FutureTask.java:237)
       at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:152)
       at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:265)
       at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1112)
       at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:587)
       at java.lang.Thread.run(Thread.java:818)

在应用程序的 onCreate 中我有:

@Override
    public void onCreate() {
    ...
    FirebaseDatabase.getInstance().setPersistenceEnabled(true);
}

我们还为 Firebase 创建了从 Activity (同一进程中的所有 Activity )/fragment 调用的单例帮助程序类:

 private FirebaseHelper() {
        mFirebaseRef = FirebaseDatabase.getInstance().getReference();
        mFirebaseAuth = FirebaseAuth.getInstance();
        mFirebaseAuth.addAuthStateListener(this);
        authentication();
    }

    public static synchronized FirebaseHelper getInstance() {
        if (mInstance == null || mInstance.getFirebaseRef() == null) {
            mInstance = new FirebaseHelper();
        }
        return mInstance;
    }

图书馆:

dependencies {
    testCompile 'junit:junit:4.12'
    compile('com.crashlytics.sdk.android:crashlytics:2.5.6@aar') {
        transitive = true;
    }
    compile 'com.google.code.gson:gson:2.6.2'
    compile 'com.android.support:support-v4:23.4.0'
    compile 'com.android.support:support-v13:23.4.0'
    compile 'com.android.support:appcompat-v7:23.4.0'
    compile 'com.android.support:design:23.4.0'
    compile 'com.android.support:support-annotations:23.4.0'
    compile 'com.android.support:gridlayout-v7:23.4.0'
    compile 'com.google.android.gms:play-services-base:9.0.2'
    compile 'com.google.android.gms:play-services-maps:9.0.2'
    compile 'com.google.android.gms:play-services-location:9.0.2'
    compile 'com.google.android.gms:play-services-appindexing:9.0.2'
    compile 'com.google.android.gms:play-services-analytics:9.0.2'
    compile 'com.google.firebase:firebase-messaging:9.0.2'
    compile 'com.facebook.android:facebook-android-sdk:4.11.0'
    compile 'de.greenrobot:eventbus:2.4.0'
    compile 'com.amazonaws:aws-android-sdk-core:2.2.12'
    compile 'com.amazonaws:aws-android-sdk-cognito:2.2.12'
    compile 'com.amazonaws:aws-android-sdk-s3:2.2.12'
    compile 'com.android.support:multidex:1.0.1'
    compile 'com.squareup.retrofit2:retrofit:2.0.2'
    compile 'com.squareup.retrofit2:converter-gson:2.0.2'
    compile 'com.squareup.retrofit2:adapter-rxjava:2.0.2'
    compile 'io.reactivex:rxandroid:1.2.0'
    compile 'io.reactivex:rxjava:1.1.5'
    compile 'com.squareup.okhttp3:logging-interceptor:3.3.1'
    compile 'com.github.curioustechizen.android-ago:library:1.3.0'
    compile 'com.cedarsoftware:json-io:4.4.0'
    compile 'com.timehop.stickyheadersrecyclerview:library:0.4.3@aar'
    compile 'joda-time:joda-time:2.9.3'
    compile 'com.facebook.fresco:fresco:0.10.0'
    compile 'com.facebook.fresco:imagepipeline-okhttp3:0.10.0'
    compile 'com.google.firebase:firebase-core:9.0.2'
    compile 'com.google.firebase:firebase-invites:9.0.2'
    compile 'com.google.firebase:firebase-database:9.0.1'
    compile 'com.google.firebase:firebase-auth:9.0.1'
    compile 'com.github.jd-alexander:LikeButton:0.2.0'

    debugCompile 'com.squareup.leakcanary:leakcanary-android:1.4-beta2'
    releaseCompile 'com.squareup.leakcanary:leakcanary-android-no-op:1.4-beta2'
    androidTestCompile 'junit:junit:4.12'
    androidTestCompile 'com.android.support:support-annotations:23.4.0'
    androidTestCompile 'com.android.support.test:runner:0.5'
    androidTestCompile 'com.android.support.test:rules:0.5'
    compile files('libs/core-3.2.1.jar')
}

最佳答案

更新:正如 Kristijan 在评论中提到的那样,事实证明还有另一个原因会导致此症状。我们发现了一个错误,如果您有一个带有整数端点的 startAt() 或 endAt() 调用,例如startAt(10),它可以触发这种缓存损坏。此错误将在下一个版本的 SDK 中修复。同时,您可以使用非整数端点,例如startAt(10.001),作为解决方法。

这些症状与 Firebase 实时数据库的已知限制相匹配,如果您在 Android 应用的多个进程中启用了持久性,该限制会阻止它工作。

请注意,任何 Application.onCreate() 代码都会为多进程 android 应用中的每个进程运行,因此如果您的应用是多进程的,则您正在初始化启用了持久性的 Firebase 数据库在多个进程中,这可能会导致我们的离线缓存损坏和您报告的 hardAssert 错误。

请记住,有时您的应用可能在您没有意识到的情况下是多进程的。例如,如果您使用的是 firebase-crash,它目前会创建一个后台进程以更可靠地报告崩溃,因此如果您使用 firebase-crash,您现在就有了一个多进程应用程序。其他第 3 方库可能有类似的行为。

要进行测试,您可以将代码添加到您的 Application.onCreate() 中,例如:

System.out.println('INITIALIZING APP FROM PID: ' + android.os.Process.myPid());

如果您看到在 logcat 中记录了两次(使用两个不同的 PID),这意味着您的应用正在运行多个进程并且您达到了我提到的限制。

作为解决方法,您可以:

  1. 修改您的应用,使其仅使用一个进程。
  2. 从您的 Application 类中删除您的 setPersistenceEnabled() 代码,并将其放在只会在您的主进程中执行的某个地方。

请注意,一旦遇到 hardAssert 错误,您可能需要清除应用数据以消除它,因为该错误表明离线缓存已进入无效状态,因此要修复它,您必须彻底清除它。

在即将发布的版本中,我们增加了对这种情况的更好检测,因此您会收到更好的错误消息。此外,firebase-crash 将来会避免产生第二个进程,这可能会降低这成为问题的可能性。

关于android - Firebase runloop (3.0.0) 中的未捕获异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49443371/

相关文章:

javascript - 检查访问者是否使用带有 HTML 的 Android 手机?

android - 如何检测JPG是否是RGB(或CMYK)格式?

java - Android项目中私有(private)变量使用getter和setter时

java - Android Firebase setValue() 权限被拒绝

android - Gmail Composer Jelly Bean 的 ActivityNotFoundException 异常

Android:如果更改系统字体大小,应用程序会崩溃

firebase 应用程序注册错误 => 找不到与包名称匹配的客户端

angular - 如何结束 ng serve 或 firebase serve

android - Admob 甚至在测试设备上转换真实广告。这是正常的吗?

firebase - 最佳实践 : Angularfire database structure for 10, 000+ 字符串