今天遇到一个奇怪的问题,使用安卓Handler消息发送数据进行处理,结果拿到的msg.arg1竟然偶尔变0,不是每次都是0,是偶发性的,我的代码是类似于这样的:
...
case HandlerMsgId:
System.out.println("编号1消息:"+msg.arg1);
new Thread(new Runnable() {
@Override
public void run() {
System.out.println("编号2消息:"+msg.arg1);
}
}).start();
msg.arg1设置发送的值为1,输出结果有时候是这样的:
编号1消息:1
编号2消息:1
上面这个结果是期望的结果,但是有时候却是这样的:
编号1消息:1
编号2消息:0
子线程中的 msg.arg1竟然变成了0!
通过查看源码分析发现了问题的原因,原来是因为当执行Handler消息的主线程执行完handleMessage(android.os.Message msg)后会对msg对象进行回收利用,把msg持有的变量重置了,因为子线程的创建执行有一定延迟,这个重置执行在子线程执行完毕之前,引发了线程不安全导致的问题,源码分析如下:
查看Looper.class可以看到有这样一段代码:
public static void loop() {
final Looper me = myLooper();