在我们默认的利用post方法将线程添加到handler消息队列中时,其实此时并不是调用了线程的start方法,而是直接调用了线程的run方法,那么也就是说,他并没有在新线程中运行,为了证实这一结论,用一个简单的小程序来看一下:

package cn.android.handler;import android.app.Activity;import android.os.Bundle;import android.os.Handler;import android.util.Log;public class Handlertest extends Activity{private static final String SWORD="SWORD";private Handler handler = new Handler();public void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.main);//将线程r添加到handler的消息队列handler.post(r);//日志输出此线程的id与nameLog.i(SWORD,"activityId-->"+Thread.currentThread().getId());Log.i(SWORD,"activityName-->"+Thread.currentThread().getName());}Runnable r = new Runnable(){public void run(){//日志输出该线程的id和nameLog.i(SWORD,"handlerId-->"+Thread.currentThread().getId());Log.i(SWORD,"handlerName-->"+Thread.currentThread().getName());try {Thread.sleep(5000);} catch (InterruptedException e) {// TODO Auto-generated catch blocke.printStackTrace();}}};}
在虚拟机中运行,并查看日志输出的结果:

我们可以看到我们想要启动的线程其实和主线程是同一线程,那么,很多的时候我们需要在一个新的线程中进行这一操作,这就需要用到looper这个类了,下一篇博客介绍在新线程中处理消息的方法。

更多相关文章

  1. SpringBoot 2.0 中 HikariCP 数据库连接池原理解析
  2. 【Android(安卓)动画】帧动画、补间动画、属性动画
  3. 【攻克Android(安卓)(43)】WebView (网络视图)
  4. Android(安卓)4.4 Kitkat Phone工作流程浅析(四)__RILJ工作流程
  5. android 开机自启动的几种方法,监听不到RECEIVE_BOOT_COMPLETED的
  6. Fragment 与 ListView, BaseAdapter
  7. 【Android(安卓)Developers Training】 81. 解析XML数据
  8. android 编程小技巧(持续中)
  9. Android中获取TextView一行最多能显示几个字

随机推荐

  1. Android(安卓)NDK
  2. android的四种启动方式和各自特点
  3. Android(安卓)Studio 之一个项目的不同视
  4. android平台下基于OpenSL ES实现音频录制
  5. Android开发者官网:Android(安卓)4.4发布1
  6. 解决Only the original thread that crea
  7. Android移植到mini2440(进行中)
  8. Android之自制的分页表格控件
  9. Android打包成jar文件方法总结
  10. android的binder机制研究