确保首先调用FirebaseApp.initializeApp(Context)函数。

4

这可能和其他已经存在的问题非常相似,但我不知道这里出了什么问题。提前感谢您的帮助。

build.gradle(项目)

        // Top-level build file where you can add configuration options common to all sub-projects/modules.

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:2.3.3'
        classpath 'com.google.gms:google-services:3.1.0'

        // NOTE: Do not place your application dependencies here; they belong
        // in the individual module build.gradle files
    }
}

allprojects {
    repositories {
        jcenter()
        maven {
            url "https://maven.google.com" // Google's Maven repository
        }
    }
}

task clean(type: Delete) {
    delete rootProject.buildDir
}

build.gradle(module)

    apply plugin: 'com.android.application'

android {
    compileSdkVersion 25
    buildToolsVersion "25.0.3"
    defaultConfig {
        applicationId "com.bustracker.usc.myapplication"
        minSdkVersion 21
        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'
        }
    }
}

dependencies {
    compile fileTree(include: ['*.jar'], dir: 'libs')
    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.3.1'
    compile 'com.android.support.constraint:constraint-layout:1.0.0-alpha7'
    compile 'com.google.android.gms:play-services-maps:10.2.6'
    compile 'com.google.android.gms:play-services-location:10.2.6'
    compile 'com.google.firebase:firebase-database:10.2.6'
    testCompile 'junit:junit:4.12'
}

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

MainActivity.java

@Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        FirebaseApp.initializeApp(this);
        requestWindowFeature(Window.FEATURE_NO_TITLE);
        setContentView(R.layout.activity_main);

        firebaseDatabase = FirebaseDatabase.getInstance();
        mRootReference = firebaseDatabase.getReference();
        mheadingReference = mRootReference.child("users");

错误:

FATAL EXCEPTION: main
                                                 Process: com.bustracker.sample.myapplication, PID: 2658
                                                 java.lang.RuntimeException: Unable to start activity ComponentInfo{com.bustracker.sample.myapplication/com.bustracker.sample.myapplication.MainActivity}: java.lang.IllegalStateException: Default FirebaseApp is not initialized in this process com.bustracker.sample.myapplication. Make sure to call FirebaseApp.initializeApp(Context) first.
                                                     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2665)
                                                     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2726)
                                                     at android.app.ActivityThread.-wrap12(ActivityThread.java)
                                                     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1477)
                                                     at android.os.Handler.dispatchMessage(Handler.java:102)
                                                     at android.os.Looper.loop(Looper.java:154)
                                                     at android.app.ActivityThread.main(ActivityThread.java:6119)
                                                     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.IllegalStateException: Default FirebaseApp is not initialized in this process com.bustracker.sample.myapplication. Make sure to call FirebaseApp.initializeApp(Context) first.
                                                     at com.google.firebase.FirebaseApp.getInstance(Unknown Source)
                                                     at com.google.firebase.database.FirebaseDatabase.getInstance(Unknown Source)
                                                     at com.bustracker.sample.myapplication.MainActivity.onCreate(MainActivity.java:53)
                                                     at android.app.Activity.performCreate(Activity.java:6679)
                                                     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1118)
                                                     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2618)
                                                     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2726) 
                                                     at android.app.ActivityThread.-wrap12(ActivityThread.java) 
                                                     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1477) 
                                                     at android.os.Handler.dispatchMessage(Handler.java:102) 
                                                     at android.os.Looper.loop(Looper.java:154) 
                                                     at android.app.ActivityThread.main(ActivityThread.java:6119) 
                                                     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

这可能与其他问题非常相似,但我真的不知道这里出了什么问题。感谢您提前的帮助。


如果有任何错误,请分享您的错误。 - Dharmishtha
@Dharmishtha,编辑了详细信息以显示错误。谢谢。 - Romar Jhon Maulana
4个回答

12

对我来说,所有给出的解决方案都没有起作用。只有这个起了作用。 只需要将我的 Google 服务从 4.1.0 降级到 4.0.0

dependencies {
    classpath 'com.android.tools.build:gradle:3.3.0-alpha08'
    classpath 'com.google.gms:google-services:4.0.0'
    /*classpath 'com.google.gms:google-services:4.1.0' <-- this was the problem */
}

所以如果你更新了谷歌服务,请尝试降级或更改到旧版本。 希望能帮助其他人。


这个临时解决方案起了作用!4.2.0和4.1.0版本都出现了相同的错误。4.0.0版本运行良好。除非访问其他Firebase项目,否则不需要调用FirebaseApp.initializeApp()! - Always Lucky
有点令人失望的是,Firebase插件在Android Studio中自动生成的Gradle依赖配置会导致这个问题。在搜索解决方法后,这种解决方法似乎是我找到的最简单(也是唯一)的方法。 - John
4.2.0版本已经为我解决了这个问题。 - user1838169

8

根据文档:

如文档所述:

任何FirebaseApp初始化都必须在应用程序的主进程中进行。在主进程以外的进程中使用Firebase不受支持,可能会导致与资源争用相关的问题。

您需要在活动之外进行初始化。

例如,在清单中添加一个应用程序类:

      <applicaton
       android:name="MyApplication"
       

那么就这样做:
public class MyApplication extends Application {
  @Override
public void onCreate() {
    super.onCreate();
   FirebaseApp.initializeApp(this);
}

从活动中删除初始化,你需要在应用程序类中初始化它,这是基类。
关于应用程序的编辑:
全局应用程序状态维护的基类。您可以通过创建子类并将其完全限定名称指定为AndroidManifest.xml标签中的“android:name”属性来提供自己的实现。应用程序类或应用程序类的子类在为应用程序/包创建进程时比任何其他类都要实例化。
有用的链接:https://developer.android.com/reference/android/app/Application.html

这是指我应该在这个类中编写保存/检索数据的代码吗? - Romar Jhon Maulana
请注意编辑可能有助于更好地理解。您仍然需要像往常一样在活动中检索和保存数据,只是初始化工作在应用程序的基类中完成。 - Peter Haddad
当我将其初始化为基类后,这意味着什么?我现在可以在需要id时随时使用它吗? - Romar Jhon Maulana
是的,我已经阅读了它。我尝试了上面的建议,但仍然遇到问题,也许是我的清单文件有问题?我无法将其转换为聊天,因为我对此很陌生(还没有声望)。 - Romar Jhon Maulana
你从活动中删除了初始化吗?你创建了一个继承自“Application”的类,并将其添加到清单文件中,在类内部添加了初始化吗? - Peter Haddad
显示剩余7条评论

5

对我而言,只需要确保在我的app.gradle中初始化了google-services插件:

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

我甚至不需要调用FirebaseApp.initializeApp(Context)。也许这会对某些人有所帮助。


0
我不知道为什么这对我起作用,但是移除


tools:node="replace" 

从我的AndroidManifest.xml中改进了崩溃,从立即崩溃变成了其他一些问题导致的崩溃。希望能帮到某些人。


请修正您最后一行的语法,“从立即到从其他某些事物”没有意义。 - Akaisteph7

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接