【问题标题】:IntentService's onHandleIntent(Intent) gets null argumentIntentService 的 onHandleIntent(Intent) 获取空参数
【发布时间】:2014-04-14 02:41:16
【问题描述】:

我正在使用 IntentService 在 android 上为我的应用程序运行后台服务。奇怪的是,我收到很多崩溃报告,其中传递给 onHandleIntent 的意图为空。我什至不确定这是怎么可能的,而且看起来非常奇怪。谁能说明为什么会发生这种情况?

STACK_TRACE

java.lang.NullPointerException
    at com.example.MyService.onHandleIntent(MyService.java:466)
    at android.app.IntentService$ServiceHandler.handleMessage(IntentService.java:65)
    at android.os.Handler.dispatchMessage(Handler.java:102)
    at android.os.Looper.loop(Looper.java:136)
    at android.os.HandlerThread.run(HandlerThread.java:61)

我的服务文件中的第 466 行出现空指针异常:

465 protected void onHandleIntent(Intent intent) {
466                Bundle data = intent.getExtras();   

服务启动为:

serviceIntent = new Intent(this, MyService.class);
serviceIntent.putExtra("ip", ip);
serviceIntent.putExtra("port", port);
startService(serviceIntent);                         

编辑: 我现在意识到我可能在滥用 IntentServices。当我启动服务时,我从 onHandleIntent() 启动一些工作线程,即使在 onHandleIntent() 返回后它们也会继续运行。并通过绑定到服务和调用成员函数/回调与线程进行通信。 为此,我将考虑使用更好的方式来使用服务,同时我仍然不明白传递的意图是如何为空的。我只能怀疑 Android 系统自己调用 onHandleIntent 的意图是空的,这看起来仍然很奇怪。有人能解释一下为什么android系统会这样调用它吗?

【问题讨论】:

  • 你能展示你如何将数据传递给额外的吗?
  • 您是否覆盖了onStartCommand()?如果是这样,您是否返回START_STICKY
  • 我正在使用一个 IntentService ,它明确警告不要覆盖 onStartCommand (我没有覆盖它)。所以不确定这些是如何相关的,因为我不能以一种或另一种方式指定 STICKYness。
  • @phininity 除了完全忽略事件(因为意图或其操作为空),我们还能做什么?你在这方面有什么发现吗?

标签: android android-intent android-service android-intentservice


【解决方案1】:

请参阅Android documentation for IntentService.onStartCommand

如果服务在其进程消失后重新启动,并且它之前返回了除 START_STICKY_COMPATIBILITY 之外的任何内容,则 [意图] 可能为 null。

IntentService.setIntentRedelivery可以在一定程度上控制重启行为

【讨论】:

    【解决方案2】:

    我在onHandleIntent 中也得到了 null Intent。原因是我在那个意图中传递了可包裹的对象。我无法理解原因,但在没有传递可包裹对象后我得到了它。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多