Android handler详解
2016-07-12 11:35
429 查看
在网上看到很多人写了关于Android的Handler机制,这个很重要,可能对于初学者可能有一些难理解,对于其回调,还有一系列发送,处理消息的机制感到有些迷惑,首先要明白Handler到底有什么用,在什么情况下使用,为什么针对不同的情况要有一系列的操作。
通常我们所说的主线程就是UI线程,也可以理解为Application中的主代码,没有创建新的线程,我是这样理解的,如果把主线程比作树的主干,那么其他创建的新线程比作树的分支,为了安全考虑,一般只有主线程才能更新UI,但是由于一些耗时的操作要放在新创建的线程中,,当任务结束以后,可能要更新UI,这时候怎么处理呢?
Android就提供了一个媒介,连接主线程和新线程的消息通信,那就是Handler类。
每个Handler实例,都会绑定到创建他的线程中(一般是位于主线程)
Handler中分发消息的一些方法
post(Runnable)
postAtTime(Runnable,long)
postDelayed(Runnable long)
sendEmptyMessage(int)
sendMessage(Message)
sendMessageAtTime(Message,long)
sendMessageDelayed(Message,long)
以上post类方法允许你排列一个Runnable对象到主线程队列中,
sendMessage类方法, 允许你安排一个带数据的Message对象到队列中,等待更新。
以下为一个实例,它实现的功能为:通过线程修改界面Button的内容
通常我们所说的主线程就是UI线程,也可以理解为Application中的主代码,没有创建新的线程,我是这样理解的,如果把主线程比作树的主干,那么其他创建的新线程比作树的分支,为了安全考虑,一般只有主线程才能更新UI,但是由于一些耗时的操作要放在新创建的线程中,,当任务结束以后,可能要更新UI,这时候怎么处理呢?
Android就提供了一个媒介,连接主线程和新线程的消息通信,那就是Handler类。
Handler的一些特点:
主要接受子线程发送的数据, 并用此数据配合主线程更新UI,handler可以分发Message对象和Runnable对象到主线程中。每个Handler实例,都会绑定到创建他的线程中(一般是位于主线程)
Handler中分发消息的一些方法
post(Runnable)
postAtTime(Runnable,long)
postDelayed(Runnable long)
sendEmptyMessage(int)
sendMessage(Message)
sendMessageAtTime(Message,long)
sendMessageDelayed(Message,long)
以上post类方法允许你排列一个Runnable对象到主线程队列中,
sendMessage类方法, 允许你安排一个带数据的Message对象到队列中,等待更新。
Handler实例
子类需要继承Hendler类,并重写handleMessage(Message msg) 方法, 用于接受线程数据。以下为一个实例,它实现的功能为:通过线程修改界面Button的内容
public class MyHandlerActivity extends Activity { Button button; MyHandler myHandler; protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.handlertest); button = (Button)findViewById(R.id.button); myHandler = new MyHandler(); // 当创建一个新的Handler实例时,它会绑定到当前线程和消息的队列中,开始分发数据 // Handler有两个作用 //(1): 定时执行Message和Runnalbe 对象 // (2): 让一个动作在不同的线程中执行。 // 它安排消息,用以下方法 // post(Runnable) // postAtTime(Runnable,long) // postDelayed(Runnable,long) // sendEmptyMessage(int) // sendMessage(Message); // sendMessageAtTime(Message,long) // sendMessageDelayed(Message,long) // 以上方法以 post开头的允许你处理Runnable对象 //sendMessage()允许你处理Message对象(Message里可以包含数据,) MyThread m = new MyThread(); new Thread(m).start(); } class MyHandler extends Handler { public MyHandler() { } public MyHandler(Looper L) { super(L); } // 子类必须重写此方法,接受数据 @Override public void handleMessage(Message msg) { // TODO Auto-generated method stub 8fef Log.d("MyHandler", "handleMessage"); super.handleMessage(msg); // 此处可以更新UI Bundle b = msg.getData(); String color = b.getString("color"); MyHandlerActivity.this.button.append(color); } } class MyThread implements Runnable { public void run() { try { Thread。sleep(10000); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } Message msg = new Message(); Bundle b = new Bundle();// 存放数据 b.putString("color", "我的"); msg.setData(b); MyHandlerActivity.this.myHandler.sendMessage(msg); // 向Handler发送消息,更新UI } } }
相关文章推荐
- Android属性动画实现布局的下拉展开效果
- 关于overridePendingTransition 无效
- Android设置系统开机自动永不休眠
- Android Broadcast
- Android自定义控件:动画类---插值器Interpolator
- Android 开发要加油
- NullPointerException: Attempt to invoke virtual method 'void android.widget.TextView.setText(java.la
- Android Studio 出现Don't see your Device 解决办法
- Android Proguard 详解
- AndroidStudio MacOsFM自定义快捷键
- android emulator创建avd命令
- Android SDK目录结构及作用
- Android_聊天软件_添加好友_与服务器交互
- Android layout属性大全
- Android快速批量多渠道包的“蛋生”
- android笔记之SQLite 数据库操作
- Android性能优化总结
- Android属性 android:focusableInTouchMode
- Android 提示超出64K的解决办法
- android 设置 永不休眠