【发布时间】: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