Android之Handler在新线程中处理消息
2013-07-18 16:22
411 查看
在上一篇博客中介绍了利用post方法将线程添加到handler消息队列其实是和主线程在同一线程中运行的,如果这一线程是一个耗时操作的话主线程会等这个线程的run方法运行之后才会继续进行下面的操作,而此时主线程可以理解为处于假死状态,用户可能会理解为挂掉了,这样的情况肯定是万万不能出现的,那么怎么解决这一问题呢。
第一种方法就是不调用handler的post方法,而是像我们原来在java中实现多线程方法一样,创建一个Thread,然后调用start方法。
第二种方法就是利用android开发框架中的looper类来实现:
首先创建一个HandlerThread新线程并调用start方法:
[html]
view plaincopy
HandlerThread handlerThread = new HandlerThread("handler_thread");
handlerThread.start();
将handlerThread的looper作为参数绑定到一个继承handler的子类线程中:
[html]
view plaincopy
MyHandler myHandler = new MyHandler(handlerThread.getLooper());
class MyHandler extends Handler{
public MyHandler(){
}
public MyHandler(Looper looper){
super(looper);
}
public void handleMessage(Message msg){
}
}
在handlerMessage方法中处理消息。
在实例中:
[html]
view plaincopy
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://hi.csdn.net/attachment/201202/10/0_1328871093tqqz.gif)
分享到:
第一种方法就是不调用handler的post方法,而是像我们原来在java中实现多线程方法一样,创建一个Thread,然后调用start方法。
第二种方法就是利用android开发框架中的looper类来实现:
首先创建一个HandlerThread新线程并调用start方法:
[html]
view plaincopy
HandlerThread handlerThread = new HandlerThread("handler_thread");
handlerThread.start();
将handlerThread的looper作为参数绑定到一个继承handler的子类线程中:
[html]
view plaincopy
MyHandler myHandler = new MyHandler(handlerThread.getLooper());
class MyHandler extends Handler{
public MyHandler(){
}
public MyHandler(Looper looper){
super(looper);
}
public void handleMessage(Message msg){
}
}
在handlerMessage方法中处理消息。
在实例中:
[html]
view plaincopy
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://hi.csdn.net/attachment/201202/10/0_1328871093tqqz.gif)
分享到:
相关文章推荐
- Android Handler在新线程中处理消息
- Android之Handler在新线程中处理消息
- Android:在子线程中更新UI,解析异步消息处理机制(Handler)
- #Android笔记#线程与消息处理之Handler
- 【Android开发】线程与消息处理-Handler消息传递机制之Looper
- Android异步消息处理线程之----Looper+MessageQueue+Handler
- Android学习—— Handler 的消息发送,在新的线程处理消息
- 关于android Handler进行线程处理消息队列与线程队列线程无法停止的问题
- Android之Handler在新线程中处理消息
- Android线程之异步消息处理机制(二)——Message、Handler、MessageQueue和Looper
- java.lang.RuntimeException: 将消息发送到死的线程上处理程序的处理程序 (android.os.Handler)
- 解析Android消息处理机制:Handler/Thread/Looper & MessageQueue
- Android消息处理机制、Hanlder机制(Handler、Looper、MessageQueue和Message)
- Android应用程序消息处理机制(Looper、Handler)分析
- Android异步消息处理机制Handler
- Android 异步消息处理机制 让你深入理解 Looper、Handler、Message三者关系
- Android 异步消息处理机制 让你深入理解 Looper、Handler、Message三者关系
- Android消息处理机制(Handler、Looper、MessageQueue与Message)
- Android消息处理机制(Handler、Looper、MessageQueue与Message)
- android的消息处理机制——Looper,Handler,Message