Android消息/处理程序机制 - 安全吗?

时间:2012-06-26 23:36:37

标签: java android handler messaging

我正在使用蓝牙进行数据通信,但这只是一个注释,并非直接附在我的问题上。远程设备向我发送每毫秒5到10个字节的数据包。我正在对它们进行分类并通过消息发送到主要活动。 发件人:

Bundle bundle = new Bundle();
Message msg;
if(something)
{
    bundle.putSerializable("data", aObject);
    msg = myHandler.obtainMessage(1);
}
else
{
    bundle.putSerializable("data", bObject);
    msg = myHandler.obtainMessage(2);
}
msg.setData(bundle);
mHandler.sendMessage(msg);

在处理程序中;

switch (msg.what)
{
    // aObject
    case 1:
        AObject aObject = (AObject) message.getData().get("data");
        break;
// bObject
    case 2:
        BObject bObject = (BObject) message.getData().get("data");
        break;
    ...//There are 15 cases like that
}

过了一段时间我得到了ClassCastException。我仔细检查了我发送了正确的带有相关数据的值。我在想,当我在处理程序中处理消息时,它在发送方部分被覆盖。因为obtainMessage从全局消息池中获取消息。因此,在检查msg.what之后,消息的数据部分在发送方中被更改,我得到了ClassCastException。

我的问题是;我的想法是对的吗?

1 个答案:

答案 0 :(得分:2)

只有在调用了recycle方法后才能重用消息。在handleMessage方法运行之后,由Handler / Looper为您完成。