IntentService的onHandleIntent(Intent)方法获取到了null参数。

27

我正在使用IntentService在Android上运行我的应用程序的后台服务。奇怪的是,我收到了很多崩溃报告,其中传递给onHandleIntent的意图为null。我甚至不确定这是如何可能的,似乎非常奇怪。有人能提供为什么会发生这种情况的建议吗?

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);                         

编辑: 我现在意识到可能在错误地使用IntentService。当我启动服务时,我从onHandleIntent()中启动一些工作线程,这些线程甚至在onHandleIntent()返回后仍然继续运行,并通过绑定服务并调用成员函数/回调与线程通信。 我将研究使用更好的方式来实现此目的,同时我仍然不明白传递的Intent为什么为空。我只能怀疑Android系统正在以某种奇怪的方式自行调用onHandleIntent并传递空Intent。有人能解释一下为什么Android系统会这样调用吗?


你能展示一下如何将数据传递给extra吗? - Marco Acierno
你是否重写了 onStartCommand() 方法?如果是,你是否返回了 START_STICKY - CommonsWare
请参见https://dev59.com/Dmoy5IYBdhLWcg3wo_gn?rq=1。 - David Wasser
5
我正在使用一个IntentService,它明确警告不要覆盖onStartCommand方法(我没有覆盖)。因此,我不确定这些内容如何相关,因为我无法指定STICKYness。 - phininity
@phininity 除了完全忽略事件(因为意图或其操作为空),我们还能做些什么呢?你在这方面有发现什么吗? - Sufian
2个回答

18
请参阅Android文档:IntentService.onStartCommand

[The intent]如果服务正在重新启动且之前返回的不是START_STICKY_COMPATIBILITY,则可能为null。

可以使用IntentService.setIntentRedelivery在某种程度上控制重启行为。


0

我在onHandleIntent中也得到了空的Intent。原因是我在该Intent中传递了可包含对象。我不明白原因,但在不传递可包含对象后,我让它正常工作了。


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