通过分析Activity源码,我们知道每个Activity都有一个Looper,所以主线程在接收Message是不需要调用Looper.prepare()和Looper.loop(),但是线程是不带Looper的,当线程要接收来自主线程的消息是就需要调用Looper.prepare()和Looper.loop()。以下我们将通过一个示例,讲述主线程和线程之间如何发送Message。

01 import android.app.Activity;
02 import android.os.Bundle;
03 import android.os.Handler;
04 import android.os.Message;
05 import android.widget.Toast;
06  
07 /**
08  * 这个类是主线程,它每隔两秒就发送一个Message给线程,线程收到Message后将发送一个Message给主线程,主线程收到Message后会将Message内容Toast出来。
09  * org.fneg.HandlerTestActivity.java
10  * Create at: 2012-6-4 下午9:39:19
11  * @author:feng
12  * Email:fengcunhan@gmail.com
13  *
14  */
15 public class HandlerTestActivity extends Activity {
16     private Handler uiHandler;
17     private ThreadWithLooper thread;
18     private Runnable showRunable;
19     @Override
20     public void onCreate(Bundle savedInstanceState) {
21         super.onCreate(savedInstanceState);
22         setContentView(R.layout.main);
23         uiHandler=new Handler(){
24             @Override
25             public void handleMessage(Message msg) {
26                 switch(msg.what){
27                 case Messages.MSG_HELLO:
28                      Toast.makeText(HandlerTestActivity.this, (String)msg.obj, Toast.LENGTH_SHORT).show();
29                     break;
30                      
31                 }
32             }
33         };
34         thread=new ThreadWithLooper(uiHandler);
35          
36         thread.start();
37         showRunable=new Runnable() {
38              
39             @Override
40             public void run() {
41                 //給线程发送一个Message
42                 thread.getHandler().sendEmptyMessage(Messages.MSG_HELLO);
43                 uiHandler.postDelayed(this, 2*1000);
44             }
45         };
46         uiHandler.post(showRunable);
47          
48     }
49      
50     @Override
51     protected void onStop() {
52         super.onStop();
53         uiHandler.removeCallbacks(showRunable);
54     }
55 }
01 import android.os.Handler;
02 import android.os.Looper;
03 import android.os.Message;
04  
05 /**
06  * 从线程发送消息到UI线程(主线程)
07  * org.fneg.ThreadWithLooper.java
08  * Create at: 2012-6-4 下午4:58:11
09  * @author:feng<br/>
10  * Email:fengcunhan@gmail.com
11  *
12  */
13 public class ThreadWithLooper extends Thread {
14     private Handler handler;
15      
16     private Handler uiHandler;
17      
18     public ThreadWithLooper(Handler mHandler){
19         this.uiHandler=mHandler;
20         //初始化Handler,接收到主线程发送过来的Message就回复一个Message给主线程,消息内容是 一个字符串和当前时间
21         handler =new Handler(){
22  
23             @Override
24             public void handleMessage(Message msg) {
25                 switch(msg.what){
26                 case Messages.MSG_HELLO:
27                      Message message=new Message();
28                      message.what=Messages.MSG_HELLO;
29                      message.obj="Yes!I get a hello"+System.currentTimeMillis();
30                      uiHandler.sendMessage(message);
31                     break;
32                      
33                 }
34             }
35              
36         };
37     }
38      
39     public Handler getHandler() {
40         return handler;
41     }
42  
43     public void setHandler(Handler handler) {
44         this.handler = handler;
45     }
46      
47     @Override
48     public void run() {
49         Looper.prepare();
50          
51         Looper.loop();
52     }
53      
54      
55 }
01 /**
02  *
03  * org.fneg.Messages.java
04  * Create at: 2012-6-4 下午4:51:20
05  * @author:feng
06  * Email:fengcunhan@gmail.com
07  *
08  */
09 public class Messages {
10    public static final int MSG_HELLO=0X1;
11 }

Android 主线程和线程之间相互发送消息的更多相关文章

  1. Handler主线程子线程之间的互相通信

    Handler主线程子线程之间的互相通信 package com.wyl.dansnote; import android.app.Activity; import android.os.Bundle ...

  2. Android消息机制之实现两个不同线程之间相互传递数据相互调用

    目的:实现两个不同线程之间相互传递数据相互调用方法. 线程一中定义mainHandler 并定义一个方法mainDecode 线程二中定义twoHandler 并定义一个方法twoEncode 实现当 ...

  3. Android主线程的消息系统(Handler\Looper)

    前言: 之前的文章写的都是关于Bitmap和内存的优化技术,这一篇文章给大家谈谈Handler. Handler是Android系统中比较重要的一个知识,在Android多线程面试经常会被问到,在实际 ...

  4. android 主线程和子线程之间的消息传递

    从主线程发送消息到子线程(准确地说应该是非UI线程)  package com.zhuozhuo; import android.app.Activity; import android.os.Bun ...

  5. Handler详解系列(四)——利用Handler在主线程与子线程之间互发消息,handler详解

    MainActivity如下: package cc.c; import android.app.Activity; import android.os.Bundle; import android. ...

  6. Handler具体解释系列(四)——利用Handler在主线程与子线程之间互发消息

    MainActivity例如以下: package cc.c; import android.app.Activity; import android.os.Bundle; import androi ...

  7. Android 主线程和子线程通信问题

        Android 如今不支持View在子线程中创建及调用其方法.假设要实现子线程内容更新之后.将结果及时反馈到主线程中,该怎样出来呢?     能够在主线程中创建Handler来实现. 这样子线 ...

  8. Android ThreadUtil 线程公共类,判断是否在主线程/ 子线程执行 相关操作

    前言:通常,我们写的公共的模块给别人用,但是这个模块又必须在特定的线程中执行. 比如,一个加载网络图片的的方法,需要在子线程中执行. /** * 加载网络图片 */ private void load ...

  9. RxJava开发精要7 – Schedulers-解决Android主线程问题

    原文出自<RxJava Essentials> 原文作者 : Ivan Morgillo 译文出自 : 开发技术前线 www.devtf.cn 转载声明: 本译文已授权开发者头条享有独家转 ...

随机推荐

  1. 【POJ 3669 Meteor Shower】简单BFS

    流星雨撞击地球(平面直角坐标第一象限),问到达安全地带的最少时间. 对于每颗流星雨i,在ti时刻撞击(xi,yi)点,同时导致(xi,yi)和上下左右相邻的点在ti以后的时刻(包括t)不能再经过(被封 ...

  2. UML_静态图

    类图        类图是描述类,接口,协作以及它们之间关系的图,用来显示系统中各个类的静态结构.类图是定义其他图的基础,在类图的基础上,可以使用状态图,协作图,组件图和配置图等进一步描述系统其他方面 ...

  3. 关于VMware导入Linux VM找不到网卡的问题

    今天遇到一个问题:由于虚拟机升级,导致以前的Linux VM(CentoS 6.7)在新的VMware里面打开,系统提示找不到网卡的问题,在网上找了好多解决办法,基本上都是一样的答案. 与网卡有关的几 ...

  4. Hibernate缓存、组件、继承映射

    Hibernate缓存.组件.继承映射 三种状态: 临时状态:不受session管理,没有提交到数据库:没有执行sql之前,new对象的时候: 持久化状态:受session管理,提交到数据库:正在执行 ...

  5. STM32F407VG (三)ADC

    12位ADC是一种逐次逼近型模拟数字转换器. 它有多达19个通道,可測量16个外部和2个内部信号源和VBAT通道.各通道的A/D转换能够单次.连续.扫描或间断模式运行. ADC的结果能够左对齐或右对齐 ...

  6. Android的Bitmap和BitmapDrawable类解析-android学习之旅(六十)

    使用简单图片 使用Drawable对象 bitmap和BitmapDrawable对象 package peng.liu.test; import android.app.Activity; impo ...

  7. ecside使用笔记(1)

    1. 部分属性描写叙述: 属性: tableId 描写叙述:  设置列表的唯一标识,默觉得"ec",当一个页面内有多个ECSIDE列表时,必须为每一个列表指定不同的 tableId ...

  8. 用户名_密码获取Access_Token

    http://www.ivanjevremovic.in.rs/live/domination/red/index-async-slider.html http://designova.net/rev ...

  9. Flash Recovery Area

    1. 设置闪回恢复区 闪回恢复区主要通过3个初始化参数来设置和管理 db_recovery_file_dest:指定闪回恢复区的位置db_recovery_file_dest_size:指定闪回恢复区 ...

  10. golang高级部分

    一.golang之OOP(orient object programming) 在函数声明时, 在其名字之前放上一个变量, 即是一个方法. 这个附加的参数会将该函数附加到这种类型上, 即相当于为这种类 ...