Android之Handler在新线程中处理消息
fmms
13年前
在上一篇博客中介绍了利用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"); } } }运行并查看日志输出结果:
转自:http://blog.csdn.net/jjaze3344/article/details/7249524