Android之Handler笔记

来源:互联网 发布:tensorflow的tpuapi 编辑:程序博客网 时间:2024/05/01 11:13

Android之Handler笔记

Handler包含两个队列:一个消息队列,一个线程队列。通过这两个队列可以实现线程之间的异步消息通信。

1.Handler与线程

A)

package mars.handler;

import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;

public class HandlerActivity extends Activity {
    /** Called when the activity is first created. */
//声明两个按钮控件
private Button startButton = null;
private Button endButton = null;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        //根据控件的ID得到代表控件的对象,并未这两个按钮设置相应的监听器
        startButton = (Button)findViewById(R.id.startButton);
        startButton.setOnClickListener(new StartButtonListener());
        endButton = (Button)findViewById(R.id.endButton);
        endButton.setOnClickListener(new EndButtonListener());
        
    }
    class StartButtonListener implements OnClickListener{


@Override
public void onClick(View v) {
//调用Handler的post方法,将要执行的线程对象添加到队列当中
handler.post(updateThread);
}
   
    }
    
    class EndButtonListener implements OnClickListener{


@Override
public void onClick(View v) {
handler.removeCallbacks(updateThread);
}
   
    }
    //创建一个Handler对象
    Handler handler  = new Handler();
    //将要执行的操作写在线程对象的run方法当中
    Runnable updateThread =  new Runnable(){


@Override
public void run() {
System.out.println("UpdateThread");
//在run方法内部,执行postDelayed或者是post方法
handler.postDelayed(updateThread, 3000);
}
   
    };
}

上述程序的写这种将Runnable写成匿名内部类的方式,通过handler.post()方法是直接调用了TupdateThread线程的run()方法,而不是将updateThread线程从start()方法开始运行。因此这种方式是运行在同一个线程中的,而不是两个线程。

B)

import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.SystemClock;


public class HandlerTest extends Activity {
private Handler handler = new Handler();
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// sendMessage();
//handler.post(r);
setContentView(R.layout.main);
Thread t = new Thread(r);
t.start();
System.out.println("activity--->" + Thread.currentThread().getId());
System.out.println("activityname--->" + Thread.currentThread().getName());
}

Runnable r = new Runnable(){


@Override
public void run() {
// TODO Auto-generated method stub
System.out.println("handler--->" + Thread.currentThread().getId());
System.out.println("handlername--->" + Thread.currentThread().getName());
try {
Thread.sleep(10000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

};
}

由于我们的线程对象t直接调用了start()方法,所以线程t的是从start()方法开始的,具有完整的线程生命周期。所以线程t的run()方法会运行在另一个线程中。

C)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;


public class HandlerTest2 extends Activity {


@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
//打印了当前线程的ID
System.out.println("Activity-->" + Thread.currentThread().getId());
//生成一个HandlerThread对象,实现了使用Looper来处理消息队列的功能,这个类由Android应用程序框架提供
HandlerThread handlerThread = new HandlerThread("handler_thread");
//在使用HandlerThread的getLooper()方法之前,必须先调用该类的start();
handlerThread.start();
MyHandler myHandler = new MyHandler(handlerThread.getLooper());
Message msg = myHandler.obtainMessage();

Bundle b = new Bundle();
b.putInt("age", 20);
b.putString("name", "Jhon");
msg.setData(b);
msg.sendToTarget();

                //将msg发送到目标对象,所谓的目标对象,就是生成该msg对象的handler对象
}

class MyHandler extends Handler{
public MyHandler(){

}
public MyHandler(Looper looper){
super(looper);
}
@Override

//当Handler接收到msg时,就会执行相应Handler的handleMessage()方法;
public void handleMessage(Message msg) {
Bundle b = msg.getData();
int age = b.getInt("age");
String name = b.getString("name");
System.out.println("age is " + age + ", name is" + name);
System.out.println("Handler--->" + Thread.currentThread().getId());
System.out.println("handlerMessage");
}
}
}

上述程序真正的实现了线程间的异步通信,主线程在运行的同时,HandlerThread线程通过Looper与的Handler进行绑定,以用来处理所绑定的Handler的线程队列。