Android 的消息机制(4)

简介:

上面的文章我们演示了如何把一个Message由子线程发送给主线程,但是如何将一个Message从主线程发送给子线程呢?子线程在默认的情况下是没有Looper的,也就没有可能操作子线程的消息队列。我们通过查API文档可以看到:

Class used to run a message loop for a thread. Threads by default do not have a message loop associated with them; to create one, call prepare() in the thread that is to run the loop, and then loop() to have it process messages until the loop is stopped.

Most interaction with a message loop is through the Handler class.

大概意思是,线程在默认情况下是没有Looper的,但是可以通过调用Prepare()方法来运行一个loop,然后使用loop()方法来处理消息直到loop结束。通常的使用方式是:

 
 
  1. class LooperThread extends Thread {  
  2.     public Handler mHandler;  
  3.    
  4.     public void run() {  
  5.         Looper.prepare();  
  6.         mHandler = new Handler() {  
  7.             public void handleMessage(Message msg) { // process incoming  
  8.                                                         // messages here  
  9.             }  
  10.         };  
  11.         Looper.loop();  
  12.     }  
  13.    

例程如下,基本过程是这样的,启动主线程,然后启动子线程,子线程注册Looper,主线程发送一个Message给子线程,然后子线程的handler处理此消息,再把此消息发送给主线程的消息队列,主线程空间显示此消息~

 
 
  1. /**  
  2.  * MessageExample4.java  
  3.  * com.test.Message  
  4.  *  
  5.  * Function: TODO  
  6.  *  
  7.  *   ver     date           author  
  8.  * ──────────────────────────────────  
  9.  *           2011-3-23      Leon  
  10.  *  
  11.  * Copyright (c) 2011, TNT All Rights Reserved.  
  12.  */  
  13.    
  14. package com.test.Message;  
  15.    
  16. import android.app.Activity;  
  17. import android.graphics.Color;  
  18. import android.os.Bundle;  
  19. import android.os.Handler;  
  20. import android.os.Looper;  
  21. import android.os.Message;  
  22. import android.view.View;  
  23. import android.view.View.OnClickListener;  
  24. import android.widget.Button;  
  25. import android.widget.LinearLayout;  
  26. import android.widget.TextView;  
  27.    
  28. /**  
  29.  * ClassName:MessageExample4 主线程如何传递消息给子线程 Function: TODO ADD FUNCTION Reason:  
  30.  * TODO ADD REASON  
  31.  *  
  32.  * @author Leon  
  33.  * @version  
  34.  * @since Ver 1.1  
  35.  * @Date 2011-3-23  
  36.  */  
  37. public class MessageExample4 extends Activity implements OnClickListener {  
  38.    
  39.     private final int WC = LinearLayout.LayoutParams.WRAP_CONTENT;  
  40.     private final int FP = LinearLayout.LayoutParams.FILL_PARENT;  
  41.     public TextView tv;  
  42.     private Button btn, btn2;  
  43.     private Handler h;  
  44.    
  45.     public void onCreate(Bundle icicle) {  
  46.         super.onCreate(icicle);  
  47.         LinearLayout layout = new LinearLayout(this);  
  48.         layout.setOrientation(LinearLayout.VERTICAL);  
  49.    
  50.         btn = new Button(this);  
  51.         btn.setId(101);  
  52.    
  53.         btn.setText("test looper");  
  54.         btn.setOnClickListener(this);  
  55.         LinearLayout.LayoutParams param = new LinearLayout.LayoutParams(100, 50);  
  56.         param.topMargin = 10;  
  57.         layout.addView(btn, param);  
  58.    
  59.         btn2 = new Button(this);  
  60.         btn2.setId(102);  
  61.    
  62.         btn2.setText("exit");  
  63.         btn2.setOnClickListener(this);  
  64.         layout.addView(btn2, param);  
  65.    
  66.         tv = new TextView(this);  
  67.         tv.setTextColor(Color.WHITE);  
  68.         tv.setText("");  
  69.         LinearLayout.LayoutParams param2 = new LinearLayout.LayoutParams(FP, WC);  
  70.         param2.topMargin = 10;  
  71.         layout.addView(tv, param2);  
  72.    
  73.         setContentView(layout);  
  74.         // 启动子线程  
  75.         new myThread().start();  
  76.     }  
  77.    
  78.     public void onClick(View v) {  
  79.         switch (v.getId()) {  
  80.         case 101:  
  81.             String obj = "mainThread";  
  82.             Message m = h.obtainMessage(1, 1, 1, obj);  
  83.             h.sendMessage(m);  
  84.             break;  
  85.         case 102:  
  86.             finish();  
  87.             break;  
  88.         }  
  89.    
  90.     }  
  91.    
  92.     // ------------------------------------------------------  
  93.    
  94.     class EHandler extends Handler {  
  95.         public EHandler(Looper looper) {  
  96.             super(looper);  
  97.         }  
  98.    
  99.         @Override  
  100.         public void handleMessage(Message msg) {  
  101.             tv.setText((String) msg.obj);  
  102.         }  
  103.     }  
  104.    
  105.     // ------------------------------------------------------  
  106.     class myThread extends Thread {  
  107.         private EHandler mHandler;  
  108.    
  109.         public void run() {  
  110.             Looper.prepare();  
  111.             h = new Handler() {  
  112.                 public void handleMessage(Message msg) {  
  113.                     EHandler ha = new EHandler(Looper.getMainLooper());  
  114.                     String obj = (String) msg.obj + ", myThread";  
  115.                     Message m = ha.obtainMessage(1, 1, 1, obj);  
  116.                     ha.sendMessage(m);  
  117.                 }  
  118.             };  
  119.             Looper.loop();  
  120.    
  121.         }  
  122.     }  
  123.    

 


本文转自 最牛傻蛋 51CTO博客,原文链接:http://blog.51cto.com/zuiniuwang/718336,如需转载请自行联系原作者

相关文章
|
10月前
|
前端开发 编译器 Android开发
构建高效Android应用:探究Kotlin协程的异步处理机制
【4月更文挑战第2天】在现代移动应用开发中,提供流畅且响应迅速的用户体验是至关重要的。随着Android平台的发展,Kotlin语言凭借其简洁性和功能性编程的特点成为了主流选择之一。特别地,Kotlin协程作为一种新型的轻量级线程管理机制,为开发者提供了强大的异步处理能力,从而显著提升了应用程序的性能和响应速度。本文将深入探讨Kotlin协程在Android中的应用,分析其原理、实现以及如何通过协程优化应用性能。
|
10月前
|
存储 Java Android开发
Android系统升级的机制概要
Android系统升级的机制概要
203 0
|
4月前
|
存储 安全 Android开发
探索Android与iOS的隐私保护机制
在数字化时代,移动设备已成为我们生活的一部分,而隐私安全是用户最为关注的问题之一。本文将深入探讨Android和iOS两大主流操作系统在隐私保护方面的策略和实现方式,分析它们各自的优势和不足,以及如何更好地保护用户的隐私。
|
5月前
|
消息中间件 存储 Java
Android消息处理机制(Handler+Looper+Message+MessageQueue)
Android消息处理机制(Handler+Looper+Message+MessageQueue)
73 2
|
4月前
|
Linux Android开发 iOS开发
深入探索Android与iOS的多任务处理机制
在移动操作系统领域,Android和iOS各有千秋,尤其在多任务处理上展现出不同的设计理念和技术实现。本文将深入剖析两大平台在后台管理、资源分配及用户体验方面的策略差异,揭示它们如何平衡性能与电池寿命,为用户带来流畅而高效的操作体验。通过对比分析,我们不仅能够更好地理解各自系统的工作机制,还能为开发者优化应用提供参考。
|
4月前
|
算法 Linux 调度
深入探索安卓系统的多任务处理机制
【10月更文挑战第21天】 本文旨在为读者提供一个关于Android系统多任务处理机制的全面解析。我们将从Android操作系统的核心架构出发,探讨其如何管理多个应用程序的同时运行,包括进程调度、内存管理和电量优化等方面。通过深入分析,本文揭示了Android在处理多任务时所面临的挑战以及它如何通过创新的解决方案来提高用户体验和设备性能。
135 1
|
5月前
|
消息中间件 存储 Java
Android面试高频知识点(2) 详解Android消息处理机制(Handler)
Android面试高频知识点(2) 详解Android消息处理机制(Handler)
|
5月前
|
消息中间件 存储 Java
Android面试高频知识点(2) 详解Android消息处理机制(Handler)
Android面试高频知识点(2) 详解Android消息处理机制(Handler)
85 1
|
5月前
|
存储 安全 数据安全/隐私保护
探索安卓与iOS的隐私保护机制####
【10月更文挑战第15天】 本文深入剖析了安卓和iOS两大操作系统在隐私保护方面的策略与技术实现,旨在揭示两者如何通过不同的技术手段来保障用户数据的安全与隐私。文章将逐一探讨各自的隐私控制功能、加密措施以及用户权限管理,为读者提供一个全面而深入的理解。 ####
183 1
|
5月前
|
消息中间件 存储 Java
Android消息处理机制(Handler+Looper+Message+MessageQueue)
Android消息处理机制(Handler+Looper+Message+MessageQueue)
145 2

热门文章

最新文章