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的线程队列。
- Android笔记之handler
- Android之Handler笔记
- android学习笔记之Handler
- Android学习笔记之Handler
- Android学习笔记之Handler(一)
- Android入门笔记之Service和Handler
- android学习笔记之handler(1)
- android学习笔记之handler(2)
- android学习笔记之handler初接触!
- Android 学习笔记 二十二 之Handler
- Android笔记---多线程之handler(旧)
- Android学习笔记之Handler内存泄露
- Android初学笔记之<Handler理解>
- android学习笔记之handler简单实用
- Android之Handler的用法(笔记)
- Android之Handler的用法(笔记)
- Android学习笔记040之Handler
- 强强笔记之android Handler 简解
- 谷歌增加新的搜索外观弹出视窗功能
- 《税务登记管理办法》
- C++ 虚函数表解析(转载)
- D85029048435
- js中的eval详解
- Android之Handler笔记
- vs2008每次 F5 build都会重新编译链接 特别浪费时间
- 8篇MongoDB教程快速学会入门 第3篇 细说高级操作
- BASE64Decoder小解
- MySQL MyISAM/InnoDB高并发优化经验
- Access 导出各种格式文件
- #if, #elif, #else, #endif 使用
- 浅谈HTTP中Get与Post的区别
- ios获取内存信息