在上一篇android处理耗时任务_ANR中简单的介绍了一个handler的用法,现在我们来看看他的基本原理。
Handler:处理者,负责Message的发送及处理。使用Handler时,需要实现handleMessage(Message msg)方法来对特定的Message进行处理,例如更新UI等。
Message:消息,携带要传送的信息和任务,是handler机制的载体。
MessageQueue:消息队列,用来存放Handler发送过来的消息,并按照FIFO规则执行。存放Message并非实际意义的保存,而是将Message以链表的方式串联起来的,等待Looper的抽取。
Looper:消息泵,不断地从MessageQueue中抽取Message执行。因此,一个MessageQueue需要一个Looper。Thread:线程,负责调度整个消息循环,即消息循环的执行场所。
Looper和MessageQueue一一对应,创建一个Looper的同时会创建一个MessageQueue。而Handler与它们的关系,只是简单的聚集关系,当然,这些Handler也就运行在同一个线程里。本人专门画了下面的图,我想这个图已经能够简洁明了的说明他们的关系了。
class LooperThread extends Thread { public Handler mHandler; public void run() { Looper.prepare(); //Handler不带参数的默认构造函数:new Handler(),实际上是通过Looper.myLooper()来获取当前线程中的消息循环 mHandler = new Handler() { public void handleMessage(Message msg) { // process incoming messages here } }; Looper.loop(); } }
默认情况下一个线程是不存在消息循环Looper的,需要调用Looper.prepare()来给线程创建一个Looper,同时会创建一个MessageQueue,调用Looper.loop()来使消息循环起作用,从消息队列里取消息,处理消息。Looper.loop()其实就是开启了一个死循环,不停的从MessageQueue中抽取Message并分配。所以写在Looper.loop()之后的代码不会被立即执行,当调用后mHandler.getLooper().quit()后,loop才会中止,其后的代码才能得以运行。
值得一提的是,Android中很多的线程间的通信都和Handler有关:上面三个其实都和handler.post(Runnable)有关。
Activity.runOnUiThread(Runnable)如果当前线程是UI线程,那么该Runnable会立即执行,如果当前的线程不是UI线程则调用UI线程handler的post()方法将其放入UI线程的消息队列中。
View.post(Runnable)
原文地址:http://blog.csdn.net/w2865673691/article/details/46042139