热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

实例讲解Android多线程应用开发中Handler的使用

这篇文章主要介绍了Android多线程应用开发中Handler的使用,Handle主要被用来更新UI和处理消息,需要的朋友可以参考下

其实可以理解Handler为主线程和另外的线程之间进行数据更新的东东,并且Handler在主线程中,并在Handler直接调用线程的run方法

package com.Handler02; 
 
import android.app.Activity; 
import android.os.Bundle; 
import android.os.Handler; 
 
public class Handler02Activity extends Activity { 
  /** Called when the activity is first created. */ 
  private Handler handler=new Handler(); 
  @Override 
  public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    handler.post(thread1); 
    setContentView(R.layout.main); 
    
    System.out.println("================Main==============="+Thread.currentThread().getId()); 
    System.out.println("============Main========="+Thread.currentThread().getName()); 
  } 
  Runnable thread1=new Runnable() { 
     
    @Override 
    public void run() { 
      System.out.println("======thread1==============="+Thread.currentThread().getId()); 
      System.out.println("========thread1============"+Thread.currentThread().getName()); 
      try { 
        Thread.sleep(10000); 
      } catch (Exception e) { 
        // TODO: handle exception 
      } 
       
    } 
  }; 
} 

结果是主线程等待10s后才显示出来,并且线程ID

package com.Handler4; 
 
import android.app.Activity; 
import android.os.Bundle; 
import android.os.Handler; 
import android.os.Message; 
import android.view.View; 
import android.widget.TextView; 
 
public class Handler4Activity extends Activity { 
  /** Called when the activity is first created. */ 
  private TextView textView; 
  private MyHandler myHandler=new MyHandler(); 
  @Override 
  public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.main); 
    textView=(TextView)this.findViewById(R.id.textView1); 
  } 
  class MyHandler extends Handler{ 
    //从消息队列中取出并handleMessage处理消息 
    @Override 
    public void handleMessage(Message msg) { 
      textView.setText((String)msg.obj); 
    } 
  } 
  public void download(View view){ 
    Thread thread=new Thread(new Runnable() { 
       
      @Override 
      public void run() { 
        try { 
          String s="zhangzhao"; 
          Thread.sleep(5000); 
          //数据发送出来 
          //textView.setText(s); 
          Message message=Message.obtain();//最好不要new,这个obtain会节省资源 
          message.obj=s; 
          myHandler.sendMessage(message);//没有指定looper那么就会发送给主线程中的looper 
           
        } catch (InterruptedException e) { 
          // TODO Auto-generated catch block 
          e.printStackTrace(); 
        } 
         
      } 
       
    }); 
    thread.start();//会出错原因是在非UI线程里面直接操作UI 
    //主线程维护了一个消息对列,当其他的线程有数据需要传递给主线程的时候,你就把数据封装成一个Message对象,然后放在主线程的 
    //消息队列中去,对应消息的处理由Looper,子线程通过Handler把下载完的数据封装到Message里面,然后把消息取出来交给Handler进行处理 
    //通过Handle和Message实现两个线程之间达到共享数据 
  } 
} 

package com.Handler5; 
 
import android.app.Activity; 
import android.os.Bundle; 
import android.os.Handler; 
import android.os.Message; 
import android.view.View; 
import android.widget.Button; 
import android.widget.ProgressBar; 
import android.widget.TextView; 
 
public class Handler5Activity extends Activity { 
  /** Called when the activity is first created. */ 
  private ProgressBar progressBar; 
  private Button button; 
  private TextView textView; 
  private MyHandler myHandler=new MyHandler(); 
  int i=0; 
  @Override 
  public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
   
    setContentView(R.layout.main); 
    progressBar = (ProgressBar)this.findViewById(R.id.progressBar1); 
    textView=(TextView)this.findViewById(R.id.textView1); 
  } 
  class MyHandler extends Handler{ 
    @Override 
    public void handleMessage(Message msg) { 
      int pos =(Integer)msg.obj; 
      progressBar.setProgress(pos); 
      textView.setText(pos+"%"); 
       
    } 
  } 
  public void downLoad(View view){ 
      
    new Thread(new Runnable() { 
       
      @Override 
      public void run() { 
        while(i<=100){ 
          try { 
            Thread.sleep(300); 
            i+=10; 
            Message message=Message.obtain(); 
            message.obj=i; 
            myHandler.sendMessage(message); 
          } catch (InterruptedException e) { 
            // TODO Auto-generated catch block 
            e.printStackTrace(); 
          } 
         
        } 
         
      } 
    }).start(); 
  } 
} 

效果:

2016131175347004.jpg (283×189)


推荐阅读
  • FinOps 与 Serverless 的结合:破解云成本难题
    本文探讨了如何通过 FinOps 实践优化 Serverless 应用的成本管理,提出了首个 Serverless 函数总成本估计模型,并分享了多种有效的成本优化策略。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • MQTT技术周报:硬件连接与协议解析
    本周开发笔记重点介绍了在新项目中使用MQTT协议进行硬件连接的技术细节,涵盖其特性、原理及实现步骤。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • Linux设备驱动程序:异步时间操作与调度机制
    本文介绍了Linux内核中的几种异步延迟操作方法,包括内核定时器、tasklet机制和工作队列。这些机制允许在未来的某个时间点执行任务,而无需阻塞当前线程,从而提高系统的响应性和效率。 ... [详细]
  • 本文提供了使用Java实现Bellman-Ford算法解决POJ 3259问题的代码示例,详细解释了如何通过该算法检测负权环来判断时间旅行的可能性。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • 深入探讨CPU虚拟化与KVM内存管理
    本文详细介绍了现代服务器架构中的CPU虚拟化技术,包括SMP、NUMA和MPP三种多处理器结构,并深入探讨了KVM的内存虚拟化机制。通过对比不同架构的特点和应用场景,帮助读者理解如何选择最适合的架构以优化性能。 ... [详细]
  • 本文探讨了 Spring Boot 应用程序在不同配置下支持的最大并发连接数,重点分析了内置服务器(如 Tomcat、Jetty 和 Undertow)的默认设置及其对性能的影响。 ... [详细]
  • 微软Exchange服务器遭遇2022年版“千年虫”漏洞
    微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • 作者:守望者1028链接:https:www.nowcoder.comdiscuss55353来源:牛客网面试高频题:校招过程中参考过牛客诸位大佬的面经,但是具体哪一块是参考谁的我 ... [详细]
  • 深入解析TCP/IP五层协议
    本文详细介绍了TCP/IP五层协议模型,包括物理层、数据链路层、网络层、传输层和应用层。每层的功能及其相互关系将被逐一解释,帮助读者理解互联网通信的原理。此外,还特别讨论了UDP和TCP协议的特点以及三次握手、四次挥手的过程。 ... [详细]
  • 本文详细探讨了HTML表单中GET和POST请求的区别,包括它们的工作原理、数据传输方式、安全性及适用场景。同时,通过实例展示了如何在Servlet中处理这两种请求。 ... [详细]
  • 深入解析Redis内存对象模型
    本文详细介绍了Redis内存对象模型的关键知识点,包括内存统计、内存分配、数据存储细节及优化策略。通过实际案例和专业分析,帮助读者全面理解Redis内存管理机制。 ... [详细]
author-avatar
亲眼耳闻目睹42
这个家伙很懒,什么也没留下!
RankList | 热门文章
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有