我使用的是最新的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创建了从活动(同一流程中的所有活动)/片段调用的单例助手类:
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')
}
8条答案
按热度按时间3phpmpom1#
**更新:**正如Kristijan在评论中提到的,这个症状还有另一个原因。我们发现了一个bug,如果你用整数端点调用startAt()或endAt(),例如startAt(10),它会触发这种缓存损坏。这个bug将在SDK的下一个版本中得到修复。同时,你可以使用非整数端点,例如startAt(10.001),作为一个解决方案。
这些症状与Firebase Realtime Database的已知限制相匹配,如果您在Android应用程序的多个进程中启用了持久性,则该限制会阻止Firebase Realtime Database工作。
请注意,任何
Application.onCreate()
代码都将为多进程Android应用中的每个进程运行,因此,如果您的应用是多进程的,您将在多个进程中启用持久性来初始化Firebase Database,这可能会导致离线缓存损坏和您报告的hardAssert错误。请记住,有时你的应用可能是多进程的,而你却没有意识到。例如,如果你使用firebase-crash,它会创建一个后台进程,以便更可靠地报告崩溃,所以如果你使用firebase-crash,你现在就有了一个多进程的应用。其他第三方库可能有类似的行为。
要进行测试,您可以向Application.onCreate()中添加代码,如下所示:
如果您在logcat中看到记录了两次(使用两个不同的PID),这意味着您的应用程序正在使用多个进程运行,并且您遇到了我提到的限制。
作为解决方法,您可以:
1.修改你的应用,使其仅使用单个进程。
1.从Application类中删除
setPersistenceEnabled()
代码,并将其放在仅在主进程中执行的位置。请注意,一旦遇到hardAssert错误,您可能需要清除应用数据以消除该错误,因为该错误指示离线缓存已进入无效状态,因此要修复该错误,您必须完全清除它。
在即将发布的版本中,我们增加了对这种情况的更好的检测,所以你会得到更好的错误消息。另外,firebase-crash将在未来避免产生第二个进程,这可能会使这不太可能成为一个问题。
qnzebej02#
我知道这是一个老职位,我面对这个问题,经过一些研究,我升级我的等级为:***implementation 'com.google.firebase:firebase-database:18.0.1'***这有助于错误消失。使用最新的库。这解决了我的问题。
csga3l583#
我们在
9.0.2
和9.2.0
版本上也遇到了同样的问题。经过几个小时的调查,我们发现重现这个问题的一种方法是使用固定的endAt
和startAt
参数进行查询。让我用一个示例代码来解释一下:...
因此,固定的
endAt
参数将在第三次启动时崩溃应用。我假设查询被缓存到磁盘,然后如果我们从本地缓存多次(三次)重新创建相同的查询,则会在某个时间点损坏。另一方面,如果endAt
不固定,例如当前时间(以米利斯为单位),则一切都按预期运行。startAt
查询参数也是如此。ulmd4ohb4#
我也面临同样的问题;在某个时间点之后,应用程序在每次启动时都会崩溃。目前我已经禁用了这个数据库持久性。
FirebaseDatabase.getInstance().setPersistenceEnabled(true)
。我现在没看到这种奇怪的撞击!
希望Firebase团队尽快解决此问题。
ttisahbt5#
此问题已在版本9.6中得到修复。请查看发行说明。
然而,当我们启用离线功能时,我们的应用仍然需要互联网连接。否则,将永远不会调用(至少)写回调。
k10s72fa6#
只是为了记录在案:
我们通过删除以下行来求解
Uncaught exception in Firebase runloop (3.0.0)
API描述:
如果设置为true,则表示Firebase应在应用处于后台时自动关闭数据库连接。默认情况下禁用。
(可能是因为我们错过了正确使用此功能的一些配置,但在未启用资源管理后,应用程序按预期运行)
mzmfm0qo7#
这个错误不是来自firebase,我只是通过解决程序中未捕获的NullPointerException来修复我的错误。因为当它在当前使用firebase库时抛出Exception时,它会误导firebaseAssertionError。您需要仔细调试您的项目来解决这个问题。这似乎是编译器问题。但是,您应该尝试降级您的Android Gradle插件以匹配预期的firebase库版本。
llmtgqce8#
我有这个问题,这个方法的工作,如果安装是新的,这个方法的工作,如果把代码如何:
但如果在其他设备上测试,您需要卸载应用程序