android handler 线程机制的研究

先来看一段代码:

package com.my; import android.app.Activity; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.util.Log; public class DemoActivity extends Activity { private final static int MESSAGE=1; Handler handler=new Handler() { @Override public void handleMessage(Message msg) { // TODO Auto-generated method stub super.handleMessage(msg); switch(msg.what) { case MESSAGE: Log.e("222", Thread.currentThread().getId()+"--->"+Thread.currentThread().getName()); } } }; @Override protected void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub super.onCreate(savedInstanceState); setContentView(R.layout.main); Log.e("111", Thread.currentThread().getId()+"--->"+Thread.currentThread().getName()); Message msg=new Message(); msg.what=MESSAGE; handler.sendMessage(msg); } }

在这段代码中打印出如下log:

2

可以看出,handler和主程序都运行在主线程里面,如果要想让handler运行在不同的线程里面,就需要重新启动一个线程,代码如下:

package com.my; import android.app.Activity; import android.os.Bundle; import android.os.Handler; import android.os.Message; import android.util.Log; public class DemoActivity extends Activity { private final static int MESSAGE = 1; Handler handler = new Handler() { @Override public void handleMessage(Message msg) { // TODO Auto-generated method stub super.handleMessage(msg); switch (msg.what) { case MESSAGE: Thread thread = new Thread(new Runnable() { @Override public void run() { // TODO Auto-generated method stub Log.e("333", Thread.currentThread().getId() + "--->" + Thread.currentThread().getName()); } }); thread.start(); Log.e("222", Thread.currentThread().getId() + "--->" + Thread.currentThread().getName()); } } }; @Override protected void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub super.onCreate(savedInstanceState); setContentView(R.layout.main); Log.e("111", Thread.currentThread().getId() + "--->" + Thread.currentThread().getName()); Message msg = new Message(); msg.what = MESSAGE; handler.sendMessage(msg); } }

运行后的log如下:

3

从上面的demo可以很明显地看出handler是和主线程在同一个线程中运行的,要想让handler里面处理的内容在不同的线程中运行,那么只有重新启动一个线程,才可以做到。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值