Handler用来处理线程间通信,也可以用来延迟处理某些事件或者循环执行某些功能。
Handler发送消息有两种方式:post(Runnable r)和sendMessage(Message msg),源码如下:
public final boolean post(Runnable r)
{
return sendMessageDelayed(getPostMessage(r), 0);
}
public final boolean sendMessage(Message msg)
{
return sendMessageDelayed(msg, 0);
}
从源码可以看出post()和sendMessage()都是调用的sendMessageDelayed()方法,两种方式发送的消息都发送到同一个队列里,只不过post()调用sendMessageDelayed()方法时的参数Message是通过方法getPostMessage(Runnable r)得到的,getPostMessage()方法如下:
private static Message getPostMessage(Runnable r) {
Message m = Message.obtain();
m.callback = r;
return m;
}
消息分发机制:
分发消息的源码如下:
public void dispatchMessage(Message msg) {
if (msg.callback != null) {
handleCallback(msg);
} else {
if (mCallback != null) {
if (mCallback.handleMessage(msg)) {
return;
}
}
handleMessage(msg);
}
}
private static void handleCallback(Message message) {
message.callback.run();
}
从源码中看到,如果msg中的callback不为null,就直接执行handleCallback(msg)方法,而不会执行Handler的成员变量mCallBack里实现的消息处理方法,也不会执行Handler的子类里实现的handlerMessage()消息处理方法。message的成员变量callback即Runnable接口的实现实例。从getPostMessage(Runnable r)方法可知,只要r不为null,message的成员变量callback也不会为null 。所以当以post(Runnable r)方式发送消息时,只要r不为null,就由r自己来处理消息;而通过sendMessage(Message msg)方式来发送消息时,如果msg中callback为空,则通过mCallback里实现的消息处理方法或者Handler自身实现的handleMessage()方法来处理消息。
所以,通过Handler实现循环执行某些功能有两种方式:
1. 在Runnable的实例中r中再次post发送该r实例;
2. 在Handler的子类中重写handleMessage(msg)方法,在该方法中以this.sendMessage(Message msg2)的方法再次发送消息(特别注意,不能直接将msg当作参数传给该方——msg != msg2),然后用该子类的实例用sendMessage()方式发送消息childHandler.sendMessage(msg) (消息中callback必须为nulll)。