【发布时间】:2011-09-06 09:10:12
【问题描述】:
我正在使用 C2DM 服务,当我收到消息时,在显示 Toast 消息时,我还会收到“向死线程上的处理程序发送消息”的错误,我想在其中查看到达的消息。使用代码:
@Override
protected void onMessage(Context context, Intent intent) {
Log.e("C2DM", "Message: arived");
Bundle extras = intent.getExtras();
if (extras != null) {
//Toast.makeText(this.getApplicationContext(), (CharSequence) extras.get("payload"), Toast.LENGTH_LONG).show();
}
}
onMessage 方法用于扩展C2DMBaseReceiver 的类。 Toast 消息从不显示。
这里有什么错误?有灵魂吗?
编辑:
09-06 08:59:02.135: WARN/MessageQueue(5654): Handler{44e65658} sending message to a Handler on a dead thread
09-06 08:59:02.135: WARN/MessageQueue(5654): java.lang.RuntimeException: Handler{44e65658} sending message to a Handler on a dead thread
09-06 08:59:02.135: WARN/MessageQueue(5654): at android.os.MessageQueue.enqueueMessage(MessageQueue.java:179)
09-06 08:59:02.135: WARN/MessageQueue(5654): at android.os.Handler.sendMessageAtTime(Handler.java:457)
09-06 08:59:02.135: WARN/MessageQueue(5654): at android.os.Handler.sendMessageDelayed(Handler.java:430)
09-06 08:59:02.135: WARN/MessageQueue(5654): at android.os.Handler.post(Handler.java:248)
09-06 08:59:02.135: WARN/MessageQueue(5654): at android.widget.Toast$TN.hide(Toast.java:344)
09-06 08:59:02.135: WARN/MessageQueue(5654): at android.app.ITransientNotification$Stub.onTransact(ITransientNotification.java:55)
09-06 08:59:02.135: WARN/MessageQueue(5654): at android.os.Binder.execTransact(Binder.java:288)
09-06 08:59:02.135: WARN/MessageQueue(5654): at dalvik.system.NativeStart.run(Native Method)
【问题讨论】:
-
我也遇到了同样的问题,你有没有找到解决办法?
-
我已从 Toast 消息移动到通知栏,并显示我从服务器获得的消息。我无法将它作为 Toast 运行。目标是在您的应用和委托人中谨慎使用上下文
标签: android android-c2dm toast