スレッド内のメッセージの処理に問題があります。私の実行方法は次のようになります
public void run() {
Looper.prepareLooper();
parserHandler = new Handler {
public void handleMessage(Message msg) {
Log.i("","id from message: "+msg.getData.getString("id"));
// handle message
this.wait();
}
}
}
次のように、このスレッドにメッセージを送信するアクティビティがいくつかあります。
Message parserMessage = new Message();
Bundle data = new Bundle();
data.putString("id", realId);
data.putString("callingClass", "CategoryList");
parserMessage.setData(data);
parserMessage.what = PARSE_CATEGORIES_OR_PRODUCTS;
parserHandler = parser.getParserHandler();
synchronized (parserHandler) {
parserHandler.notify();
Log.i("","message ID: " + parserMessage.getData().getString("id"));
}
parserHandler.sendMessage(parserMessage);
問題は、run-method が「id from message: null」をログに記録することですが、「メッセージ ID」にはログ ステートメントに値があります。メッセージがスレッドに送信されるときにデータが「失われる」のはなぜですか? 通知と何か関係がありますか?ご協力いただきありがとうございます