1

Firebase Crash Reporting と Firebase Remote Config を使用しています。両方のバージョンは 9.8.0 です。

ほとんどのデバイスで、セットアップは完全に機能します (私は、クラッシュ レポートのセットアップに従いました)。しかし、ごく一部のデバイス (実際には発生率が最も高いクラッシュ) では、アプリケーションの onCreate メソッドで Remote Config を初期化しようとするとクラッシュします。

java.lang.RuntimeException: Unable to create application com.company.application.AppApplication: java.lang.IllegalStateException: Default FirebaseApp is not initialized in this process com.company.application. Make sure to call FirebaseApp.initializeApp(Context) first.
    at android.app.ActivityThread.handleBindApplication(ActivityThread.java:6429)
    at android.app.ActivityThread.access$1800(ActivityThread.java:229)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1887)
    at android.os.Handler.dispatchMessage(Handler.java:102)
    at android.os.Looper.loop(Looper.java:148)
    at android.app.ActivityThread.main(ActivityThread.java:7329)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1230)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1120)
Caused by: java.lang.IllegalStateException: Default FirebaseApp is not initialized in this process com.company.application. Make sure to call FirebaseApp.initializeApp(Context) first.
    at com.google.firebase.a.d(Unknown Source)
    at com.google.firebase.b.a.a(Unknown Source)
    at com.company.application.d.a.a(SourceFile:21)
    at com.company.application.AppApplication.onCreate(SourceFile:76)
    at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:1037)
    at android.app.ActivityThread.handleBindApplication(ActivityThread.java:6426)
    ... 8 more
4

2 に答える 2

4

バージョン 10.0.0 より前では、Firebase Crash によってアプリに という名前の追加プロセスが作成されましたbackground_crash。クラスのインスタンスAppApplicationが作成され、アプリ内のプロセスごとに実行されますbackground_crash

アプリケーション クラスで Firebase サービスの初期化を実行する場合は、background_crash で初期化が実行されないようにガードを追加する必要があります。それを行う方法は次のとおりです。

    if (!FirebaseApp.getApps(this).isEmpty()) {
        // Not in crash process.  Do your Remote Config init here.
    }

もう 1 つの解決策は、Firebase の最新バージョン 10.0.1 にアップグレードすることです。

この回答が有効であると仮定すると、デバイスにインストールされている Google Play Services のバージョンが要因であり、失敗したデバイスのバージョンが古い場合を除き、一部のデバイスでのみエラーが発生する理由を説明できません。

于 2017-01-09T20:46:10.453 に答える