Android的Message机制(简单小结)

对于Android的Message机制主要涉及到三个主要的类,分别是Handler、Message、Looper;首先对每个类做一个简单介绍;然后再介绍所谓的Android的Message机制是如何实现的,最后给了一个示例。

一、介绍三个相关的类

1、 Handler主要有两个用途:首先是可以定时处理或者分发消息,其次是可以添加一个执行的行为在其它线程中执行,

对于Handler中的方法,可以选择你关心的操作去覆盖它,处理具体的业务操作,常见的就是对消息的处理可以覆盖public voidhandleMessage(参数)方法,可以根据参数选择对此消息是否需要做出处理,这个和具体的参数有关。例如下代码:

[java] view plaincopyprint?

  1. Handler mHandler = new Handler() {
  2. @Override public void handleMessage(Message msg) {//覆盖handleMessage方法
  3. switch (msg.what) {//根据收到的消息的what类型处理
  4. case BUMP_MSG:
  5. Log.v("handler", "Handler===="+msg.arg1);//打印收到的消息
  6. break;
  7. default:
  8. super.handleMessage(msg);//这里最好对不需要或者不关心的消息抛给父类,避免丢失消息
  9. break;
  10. }
  11. }
  12. };

2、 消息android.os.Message

android.os.Message是定义一个Messge包含必要的描述和属性数据,并且此对象可以被发送给android.os.Handler处理。属性字段:arg1、arg2、what、obj、replyTo等;其中arg1和arg2是用来存放整型数据的;what是用来保存消息标示的;obj是Object类型的任意对象;replyTo是消息管理器,会关联到一个handler,handler就是处理其中的消息。通常对Message对象不是直接new出来的,只要调用handler中的obtainMessage方法来直接获得Message对象。

3、 Looper类主要用于一个线程循环获取消息队列中的消息。

Looper的作用主要是负责管理消息队列,负责消息的出列和入列操作。

二、Android的Message机制是如何实现?

1、为什么要使用Message机制主要是为了保证线程之间操作安全,同时不需要关心具体的消息接收者,使消息本身和线程剥离开,这样就可以方便的实现定时、异步等操作。

2、Message机制原理示意图:

Activity   <--------------->  EHandler<----->  Looper<----->  MessageQueue

IntentReceiver <----->  EHandler <----->  Looper<----->  MessageQueue

图 1

3、 如何实现?(具体描述上图的消息流的过程)

实现Message机制需要Handler、Message、Looper三个之间的互相作用来实现;当线程A需要发消息给线程B的时候,线程B要用自己的Looper实例化Handler类,就是构造handler对象时,把当前线程的Looper传给Handler构造函数,handler本身会保存对Looper的引用,handler构造好以后,就可以用handler的obtainMessage方法实例化Message对象,只要把要传的数据给Handler,Handler就会构造Message对象,并且把Message对象添加到消息队列里面。然后就可以调用handler的sendMessage方法把Message对象发送出去,Looper就把消息放到消息队列中;最后当Looper知道消息队列不为空时候,就会循环的从消息队列中取消息,取出消息就会调用刚才实例化好的Handler对象的handleMessage方法取处理消息,整个Message过程就是这样。(如图1所示)

三、下面介绍一个关于Message机制的简单的示例,具体的代码如下:

1、 下面是一个新起的一个线程发消息的示例

handler本身不仅可以发送消息,还可以用post的方式添加一个实现Runnable接口的匿名对象到消息队列中,在目标收到消息后就可以回调的方式在自己的线程中执行run的方法体,这就是handler两种典型的使用方式!

[java] view plaincopyprint?

  1. class NoLooperThread extends Thread {
  2. private EventHandler mNoLooperThreadHandler;
  3. public void run() {
  4. Looper   myLooper, mainLooper;
  5. myLooper= Looper.myLooper();   //获得自己的Looper
  6. mainLooper= Looper.getMainLooper();    //获得自己的main的looper
  7. String obj;
  8. if (myLooper == null) {
  9. mNoLooperThreadHandler = new EventHandler(mainLooper);
  10. obj= "NoLooperThread has no looper andhandleMessage function executed in main thread!";
  11. }else
  12. {
  13. mNoLooperThreadHandler = new EventHandler(myLooper);
  14. obj= "This is from NoLooperThread self andhandleMessage function executed in NoLooperThread!";
  15. }
  16. mNoLooperThreadHandler.removeMessages(0);    //清空消息队列
  17. if (false == postRunnable) {
  18. Message m = mNoLooperThreadHandler.obtainMessage(2, 1, 1, obj);    //生成消息对象
  19. mNoLooperThreadHandler.sendMessage(m);   //发送消息
  20. Log.e(sTag, "NoLooperThread id:" + this.getId());
  21. }else {
  22. mNoLooperThreadHandler.post(new Runnable() {    //添加一个Runnable接口的实现到消息队列,此Runnable接口的实现不在此                                  线程中执行,会在接收的线程中执行。
  23. public void run() {
  24. tv.setText("update UI through handler post runnalbe mechanism!");
  25. noLooerThread.stop();
  26. }
  27. });
  28. }
  29. }

2、下面是一个定时循环发消息的示例,如下代码:

详细的解释参考代码的注释

Handler handler = new Handler() {    //创建处理对象handler

publicvoid handleMessage(Message msg) {

switch (msg.what) {

caseMES: {

final int N = mCallbacks.beginBroadcast();    //Copy一份回调list,并且标记一个状态

for (int i = 0; i <N; i++) {

try {

mCallbacks.getBroadcastItem(i).getValue(mMediaPlayer01.getCurrentPosition());           //遍历所有回调接口                                                                      }catch (Exception e) {

e.printStackTrace();

}

}

mCallbacks.finishBroadcast();     //完成后状态复位

sendMessageDelayed(obtainMessage(MES),1 * 1000);

}

break;

default:

super.handleMessage(msg);

}

}

};

NOTE:     整个hadleMessage方法相当一个嵌套的循环

四、总结:

所谓的消息机制其实很简单,实现这种机制需要只需要四步:

1、实例化Looper(因为实例化Handler时需要一个looper);

2、实例化Handler,这里需要覆盖handleMessage方法,处理收到的消息;

3、 实例化Message对象,调用已经实例化好的handler对象的obtainMessage方法,把数据传给obtainMessage方法,obtainMessage方法就会实例化一个Message对象。(这里也可以发送实现Runnable接口的对象);

4、调用Handler的sendMessage方法把实例化好的Message对象发送出去。

对每个线程过程都是一样的,只要按照上面的四个步骤来就可以发送和接收消息了。

时间: 2024-12-24 21:18:45

Android的Message机制(简单小结)的相关文章

Android的Message机制

对于Android的Message机制主要涉及到三个主要的类,分别是Handler.Message.Looper:首先对每个类做一个简单介绍:然后再介绍所谓的Android的Message机制是如何实现的,最后给了一个示例. 一.介绍三个相关的类 1. Handler主要有两个用途:首先是可以定时处理或者分发消息,其次是可以添加一个执行的行为在其它线程中执行, 对于Handler中的方法,可以选择你关心的操作去覆盖它,处理具体的业务操作,常见的就是对消息的处理可以覆盖public voidhan

Android Message机制

[java] view plaincopyprint? 网上以文档形式流传,不知道原文在哪,感谢原作者了! ================简单调整了下格式就共享了=============================================== 对于Android的Message机制主要涉及到三个主要的类,分别是Handler.Message.Looper:首先对每个类做一个简单介绍:然后再介绍所谓的Android的Message机制是如何实现的,最后给了一个示例. 一.介绍三个相

Android的消息机制以及Message/MessageQueue/Handler/Looper

概览 * Message:消息.消息里面可包含简单数据.Object和Bundle,还可以包含一个Runnable(实际上可看做回调). * MessageQueue:消息队列,供Looper线程消费消息. * Looper:用于循环处理Message,一个Thread结合一个Looper来实现消息循环处理.Android App的主线程包含了Looper. * Handler:负责向当前Looper线程发送Message,并实现如何处理消息的回调,回调可放到Callback接口的实现中,也可以

Android Handler处理机制 ( 三 ) ——Handler,Message,Looper,MessageQueue

在android中提供了一种异步回调机制Handler,使用它,我们可以在完成一个很长时间的任务后做出相应的通知 handler基本使用: 在主线程中,使用handler很简单,new一个Handler对象实现其handleMessage方法,在handleMessage中 提供收到消息后相应的处理方法即可,这里不对handler使用进行详细说明,在看本博文前,读者应该先掌握handler的基本使用,我这里主要深入描述handler的内部机制 .现在我们首先就有一个问题,我们使用myThread

Android的消息处理机制——Looper,Handler和Message浅析

题外话: 说来有些惭愧,对于这三者的初步认识居然是在背面试题的时候.那个时候自己接触Android的时间还不长,学习的书籍也就是比较适合入门的<疯狂Android讲义>,当然在学到Handler这一部分的时候,书中也是有提到一些简单示例,后来在工作中需要用到这个MessageQueue的时候才开始真正琢磨了一下这三者的联系.如果想要对这三者好好理解一番,个人还是比较推荐<深入理解Android卷Ⅰ>.以下对这三者之间的恩怨纠葛的介绍和分析也是参考这本书的相关章节,算是一篇读书笔记吧

【转】android的消息处理机制(图+源码分析)——Looper,Handler,Message

原文地址:http://www.cnblogs.com/codingmyworld/archive/2011/09/12/2174255.html#!comments 作为一个大三的预备程序员,我学习android的一大乐趣是可以通过源码学习google大牛们的设计思想.android源码中包含了大量的设计模式,除此以外,android sdk还精心为我们设计了各种helper类,对于和我一样渴望水平得到进阶的人来说,都太值得一读了.这不,前几天为了了解android的消息处理机制,我看了Loo

android的消息处理机制——Looper,Handler,Message

这篇文章有一半是copy别人的,站在巨人的肩膀上,我们才能看得更高更远...... 在开始讨论android的消息处理机制前,先来谈谈一些基本相关的术语. 通信的同步(Synchronous):指向客户端发送请求后,必须要在服务端有回应后客户端才继续发送其它的请求,所以这时所有请求将会在服务端得到同步,直到服务端返回请求. 通信的异步(Asynchronous):指客户端在发送请求后,不必等待服务端的回应就可以发送下一个请求. 所谓同步调用,就是在一个函数或方法调用时,没有得到结果之前,该调用就

android线程消息传递机制——Looper,Handler,Message

android线程消息传递机制——Looper,Handler,Message 在引入这些概念之前,我们先了解一下引入这些机制的背景. 出于性能优化的考虑,Android的UI操作并不是线程安全的(如果你不懂什么是线程安全,可以阅读一下<一起探究多进程与多线程>里的数据安全与可重入),这意味着如果有多个线程同时操作某个UI组件,可能导致线程安全问题.为了解决这个问题,Android制定了一条简单的规则:只允许UI线程修改Activity里的UI组件.这个UI线程也通常被我们称为主线程. 在此引

Java简单模拟Android中Handler-Message机制

在Android中主线程与子线程的通信十分重要,Google工程师为我们提供了Handler-Message机制来解决他们之间的交互问题.今天,我们就来简单理解Handler-Message机制的原理,在Java中简单模拟该机制.代码示例Github地址HandlerDemo 首先,看一下简单流程图(不太专业) 由上图可知,流程中主要相关类有Handler.Message.MessageQueue.Looper:下面,我们就围绕它们来简单分析该流程图: 1.我们一般在主线程创建Handler,接