这篇文章主要整理内容如下:
1.Handler函数之间的调用关系;
2.Handler发消息机制
1 Handler函数之间的调用关系
点击这里查看大图
上图所示内容为Handler类几乎所有方法,个别方法基本不使用的就没列上去。图中箭头的意思是调用,比如A—->B,意思是A中会调用B,用代码来描述就是
public void A(){
...
B();
...
}
public void B(){
...
}
从图中可以看到这些方法调用特别严谨和有意思。
(1)查看post和sendMessage系列方法,你会发现最终会调用enqueueMessage方法,而enqueueMessage方法中,MessageQueue的enqueueMessage方法。
(2)查看remove和has系列方法,你会发现最终会调用MessageQueue相关的方法
总结:Handler无非就是MessageQueue的代理类,为发送、获取、处理、传递消息(Message)起到中介作用.
2 Handler发消息机制
看了上图之后,也许一脸懵懂。阅读以下叙述之后,你会豁然开朗。
抛开上图,讲点额外知识。
要运行一个Java类,JVM会先执行类中的main方法,再根据main方法调用其他函数,main方法是Java类的入口。
查找Android代码中的Activity、Broadcast等却没发现main方法,那这些Java类是怎么被执行的呢?自己没有,肯定是被别人调用执行。
上图中涉及Activity的启动,接下来我们就边谈Activity的启动边谈上图的意思进而就会谈到Handler如何发生消息,处理消息。在这里我们老是说消息消息,消息是个什么东东呢?在Android里,消息用Message类表示,这个Message类有几个重要的成员变量,也是我们常用的:
what—->int 类型
obj—->Object类型
target—->Handler类型
callback—->Runnable类型
Activity的启动
上图中展示启动一个Activity的流程,我们调用了Activity.startActivityForResult后,剩余工作都在ActvityThread中执行了。在Activity启动流程中,我们可以清晰看到,流程中也是用到了Activity与Handler的协调作用。
Handler消息发送机制图片及Handler发送消息机制原理
讲到这里,我们可以回顾刚才的“Handler消息发送机制图片”。图中可以看到ActivityThread中有个main方法。当一个Android应用程序启动后,会新建一个ActivityThread实例,并且执行了main方法,这个实例就是UI线程了。在应用程序未结束前,UI线程一直是跑着的。回顾图中main方法调用了Looper类的loop()方法。loop()方法中有个for死循环遍历MessageQueue,一旦循环到有Message实例,就调用Message的target(Handler)的dispatchMessage方法,Handler的dispatchMessage方法中又调用了Handler的handleMessage方法,然后就执行了我们重写在handleMessage方法的代码。
总结
handler消息发送流程如下。
1.UI线程(ActivityThread)执行main方法,main方法中调用了Looper的静态loop方法;
2.Looper.loop()方法中有个死循环,一直在遍历MessageQueue,一旦发现有Message就执行Message的target(Handler)的dispatchMessage方法,Handler的dispatchMessage方法中又调用了Handler的handleMessage方法;
3.由本文章开头的“Handler函数之间的调用关系图”得知,不管我们使用Handler的什么函数发Message,最后都会执行MessageQueue.enqueueMessage方法,让Message进入队列;
4.第2 步骤中的Looper.loop()中检测到有Message,就开始执行了Message中的操作了。