在上一篇博客中介绍了利用post方法将线程添加到handler消息队列其实是和主线程在同一线程中运行的,如果这一线程是一个耗时操作的话主线程会等这个线程的run方法运行之后才会继续进行下面的操作,而此时主线程可以理解为处于假死状态,用户可能会理解为挂掉了,这样的情况肯定是万万不能出现的,那么怎么解决这一问题呢。
第一种方法就是不调用handler的post方法,而是像我们原来在java中实现多线程方法一样,创建一个Thread,然后调用start方法。
第二种方法就是利用android开发框架中的looper类来实现:
首先创建一个HandlerThread新线程并调用start方法:
HandlerThread handlerThread = new HandlerThread("handler_thread");
handlerThread.start();
将handlerThread的looper作为参数绑定到一个继承handler的子类线程中:
MyHandler myHandler = new MyHandler(handlerThread.getLooper());
class MyHandler extends Handler{
public MyHandler(){
}
public MyHandler(Looper looper){
super(looper);
}
public void handleMessage(Message msg){
}
}
在handlerMessage方法中处理消息。
在实例中:
package cn.android.handler;
import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.HandlerThread;
import android.os.Looper;
import android.os.Message;
import android.util.Log;
public class HandlerTestActivity extends Activity {
/** Called when the activity is first created. */
private static final String SWORD="SWORD";
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
//打印当前线程ID
Log.i(SWORD,"Activity--->"+Thread.currentThread().getId());
//生成一个HandlerThread对象,实现了使用Looper来处理消息队列
HandlerThread handlerThread = new HandlerThread("handler_thread");
//在使用HandlerThread的getLooper()方法之前,必须先调用该类的start()方法启动线程
handlerThread.start();
MyHandler myHandler = new MyHandler(handlerThread.getLooper());
Message msg = myHandler.obtainMessage();
//将msg发送到目标对象,所谓的目标对象,就是生成该msg对象的handler对象
Bundle b = new Bundle();
b.putInt("age", 20);
b.putString("name", "Jhon");
msg.setData(b);
//发送消息对象
msg.sendToTarget();
}
class MyHandler extends Handler{
public MyHandler(){
}
public MyHandler(Looper looper){
super(looper);
}
public void handleMessage(Message msg){
Bundle b = msg.getData();
int age = b.getInt("age");
String name = b.getString("name");
Log.i(SWORD,"age--"+age+" name---"+name);
Log.i(SWORD,"handlerId"+Thread.currentThread().getId());
Log.i(SWORD,"handlerMessage");
}
}
}
运行并查看日志输出结果: