アプリがバックグラウンドで実行されていないときに、テスト中に問題が発生します。私はそれにc2dmメッセージをブロードキャストし、それを受信しました。サービスはAsyncTaskを実行してサーバーからデータを取得します。「onPostExecute」で失敗し、MessageQueueエラーが発生するまで、すべて問題ありません。
デッドスレッドのハンドラーにメッセージを送信する
アプリがバックグラウンドで実行されている場合はすべて正常に動作しますが、そうでない場合は失敗します。どういうわけかそれを起こさなければなりませんか?ありがとう!
更新:これが私のAsyncTaskのスニペットです:
private class getNewMessages extends AsyncTask<Void, Void, Boolean> {
private Context gContext;
private String gToken;
private int gNewMessages;
public getNewMessages(Context context, String token) {
super();
gContext = context;
gToken = token;
}
protected Boolean doInBackground(Void... args) {
gNewMessages = data.serverNewMessagesGet(gContext, gToken);
return true;
}
protected void onPostExecute(Boolean result) {
Log.d(common.DEBUG_TAG, "retrieved " + gNewMessages + " new messages");
// notify user, etc...
}
}
更新#2:エラースタックトレース
Handler{4585c038} sending message to a Handler on a dead thread
java.lang.RuntimeException: Handler{4585c038} sending message to a Handler on a dead thread
at android.os.MessageQueue.enqueueMessage(MessageQueue.java:184)
at android.os.Handler.sendMessageAtTime(Handler.java:457)
at android.os.Handler.sendMessageDelayed(Handler.java:430)
at android.os.Handler.sendMessage(Handler.java:367)
at android.os.Message.sendToTarget(Message.java:348)
at android.os.AsyncTask$3.done(AsyncTask.java:214)
at java.util.concurrent.FutureTask$Sync.innerSet(FutureTask.java:252)
at java.util.concurrent.FutureTask.set(FutureTask.java:112)
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:310)
at java.util.concurrent.FutureTask.run(FutureTask.java:137)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1068)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:561)
at java.lang.Thread.run(Thread.java:1096)