OverView:
Handler是一个能够发送和处理与线程的消息队列相关的Message和实现了Runnable的objects的java类。每一个Handler的实例都与一个线程和该线程的消息队列相关,当创建一个Handler的实例时,系统会自动将它绑定到线程或者线程的消息队列(绑定的线程为创建该Handler对象的线程)中,并会发送Message和Runnable的实例到消息队列中,当消息出队的时候处理他们。
由上可以知道,Handler对象处理Message或者是Runnable的实例时,分成了三个阶段:
1)create handler
2)send messages/runnables
3)process
Handler的两个主要用途:
- schedule messages和runnables在未来的某一个时间点执行
- 将一个将要在其他线程内执行的action入队
其中,scheduling messages and runnables主要是通过各种各样的postXXX和sendXXX函数去完成的,post式主要是针对于runnables,而send式主要是针对于Messages。注意:sendMessage的函数,可以使发送的Message包含一个bundle的数据,并且会在Handler的handleMessage方法中被处理。
在上述的方法中,你可以指定一个延迟时间段让系统处理这个handler,但此时要求你实现timeouts、ticks或者其他的time_based行为。
当你的application被创建时,它的主线程主要是管理一个消息队列,而这个消息队列主要涉及应用的顶层组件(如Activity、Service,etc)以及它所创建的window。因此,如果你想处理一些UI改变或者只能主线程才有权限处理的任务,你可以创建你自己的线程,并让他们通过handler与主线程通信。而这个通过handler通信的过程就是主要运用了post、send型函数,并且这些messages、runnables会被安排到消息队列中,在恰当的时候会被调用处理。
代码:
package com.zhouyou.robocademoproj;
import android.os.Handler;
import android.os.Message;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity {
private Handler mHandler;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mHandler = new Handler(){
@Override
public void handleMessage(Message msg) {
if(msg.what == 0x111) {
super.handleMessage(msg);
System.out.println("handleMessage is called");
Bundle bundle = msg.getData();
Toast.makeText(MainActivity.this, "姓名:" + bundle.getString("name") + ",年龄:" + bundle.get("age"), Toast.LENGTH_SHORT).show();
}
}
};
}
public void onClickButton(View v){
Message msg = new Message();
msg.what = 0x111;
Bundle bundle = new Bundle();
bundle.putString("name","李明");
bundle.putInt("age", 19);
msg.setData(bundle);
mHandler.sendMessage(msg);
}
}
布局文件:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.zhouyou.robocademoproj.MainActivity">
<Button
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="请点击我"
android:onClick="onClickButton"/>
</RelativeLayout>