gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-02 07:43:47 24 4
gpt4 key购买 nike

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

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。我仔细检查了我是否发送了正确的 what 值以及相关数据。我在想,当我在处理程序中处理消息时,它在发送者部分中被覆盖。因为obtainMessage是从全局消息池中获取消息的。因此,在检查 msg.what 后,消息的数据部分在发送者中发生了更改,并且我收到了 ClassCastException。

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

最佳答案

消息只能在调用回收方法后才能重用。这是在handleMessage 方法运行后由Handler/Looper 为您完成的。

关于java - Android 消息/处理程序机制 - 安全吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11217425/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com