【问题标题】:Using Android service context for Room database为 Room 数据库使用 Android 服务上下文
【发布时间】:2018-02-11 15:46:36
【问题描述】:

我正在开发一个同时使用 Firebase MessagingRoom 数据库 的应用。

这就是数据库的初始化方式

public static AppDatabase getInstance(final Context appContext) {
    if (INSTANCE == null) {
        INSTANCE = Room.databaseBuilder(appContext, AppDatabase.class, "dbname.db")
                // prepopulate the database after onCreate was called
                .addCallback(rdc)
                .build();
    }
    return INSTANCE;
}

MainActivity 的某个地方,第一次调用AppDatabase 并实例化了数据库,一切正常,花花公子!

现在问题开始于用户kill应用程序...

为了简单起见,可以将这个应用程序想象成 Whatsapp...应用程序已被终止,但正在侦听消息的 service (MyFirebaseMessagingService) 仍在运行(应该如此)。

当一条新消息到达并且MyFirebaseMessagingService 尝试通过调用AppDatabase.getInstance() 将其保存到数据库时,将发生崩溃,因为最初的context 引用已不再存在,因为该应用程序已创建数据库。被杀了。

搜索如何解决这个问题我了解到每个服务 this 实际上都是从 context 派生的,所以我立即尝试使用 MyFirebaseMessagingService 上下文来初始化数据库,但是,MyFirebaseMessagingService::onCreate 你真正可以访问的地方在第一条消息到达之前,服务上下文不会被触发

我能想到的唯一解决方案是创建一个全新的服务,bindService() 将它添加到 MainActivity,并使用该新服务上下文创建 AppDatabase 实例......但这似乎完全是多余的。

所以我的问题是,如何初始化房间数据库,使MyFirebaseMessagingService 即使应用程序被杀死也仍然可以使用它?

【问题讨论】:

  • 您可以在服务中访问 getApplicationContext(),您尝试过吗?应在创建任何服务、活动或广播接收器之前创建应用程序实例。
  • 您找到解决方案了吗?
  • 基于服务的 context.getApplicationContext() 为空。它正在崩溃。任何其他建议的解决方案。

标签: android firebase firebase-cloud-messaging android-room


【解决方案1】:

getApplicationContext() 在构造函数中不可用。但它在onStartCommand() 函数中可用。我认为这是在服务中构建/打开数据库的好地方。

【讨论】:

    【解决方案2】:

    由于FirebaseMessagingService 是我们应该在那里拥有getApplicationContext() 的服务,您应该使用它来创建您的分贝实例并执行必要的操作, 其他选项是创建服务或编写自定义广播接收器。

    【讨论】:

      【解决方案3】:

      首先:从系统上下文 (NOTIFICATION_SERVICE) 中,您尝试使用使用应用上下文访问或创建数据库的 Room。 但是在那一刻应用程序上下文可能为空。也许只是因为该应用程序被杀死了。 所以你得到了一个很好的崩溃。

      其次,一些日志会很好。随着崩溃。它可能会阻止人们猜测。

      第三:(再次猜测)也许你应该试试工作经理。类似于:您收到数据 > 开始工作。将可靠地运行,并且不必在那一刻正确运行。 一个很好的起点here

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2023-02-24
        • 1970-01-01
        • 2017-12-09
        • 1970-01-01
        • 2022-01-07
        • 1970-01-01
        相关资源
        最近更新 更多