1. Timer 用法
- new Timer().schedule(new TimerTask(){
- @Override
- public void run() {
- // TODO Auto-generated method stub
- // do some your own process when the timeout come up
- }, delay, period);
Timer作用:延时或循环执行。
使用带period参数的schedule方法该timer以period为周期,循环执行run方法。--------循环执行。
使用不带period参数的schedule方法则该timer只在delay时间到来时执行一次。--------单次执行。
2. 注意
TimerTask运行在一个单独的线程里,而不是UI线程。所以使用Android timer时,注意android的单线程原则,确保线程安全。不要在TimerTask的run方法中做UI相关的操作,如:TextView.setText()等,这样可能会导致UI线程阻塞。如果需要可以使用handler向UI线程发消息,具体处理由UI线程自己完成。在使用完Timer之后,要使用Timer的cancel方法取消Timer,否则Timer一直在运行。
下面为实例演示:
1.Timer +TimerTask
Timer timer = new Timer( );
TimerTask task = new TimerTask( ) {
public void run ( ) {
Message message = new Message( );
message.what = 1;
handler.sendMessage(message);
}
};
final Handler handler = new Handler( ) {
public void handleMessage(Message msg) {
switch (msg.what) {
case 1:
log.e("Timer","Timer");
break;
}
super.handleMessage(msg);
}
};
protected void onDestroy ( ) {
if (timer != null) {
timer.cancel( );
timer = null;
}
super.onDestroy( );
}
protected void onCreate (Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
this.setContentView(R.layout.main);
timer.schedule(task,1000,5000);
}
需要注意的是 timer.schedule(task,1000,5000),如果设置为 timer.schedule(task,5000)是不会工作的。
------------------------------------------------------------------------------------------------------------------------------------------------------------------------
2.Handler+Runnable
final Handler handler = new Handler( ) {
public void handleMessage(Message msg) {
switch (msg.what) {
case 1:
log.e("Timer","Timer");
break;
}
super.handleMessage(msg);
}
};
private Runnable runnable = new Runnable( ) {
public void run ( ) {
Message message = handler .obtainMessage( );
message.what = 1;
handler.sendMessage(message);
}
};
handler.postDelayed(runnable,1000); // 开始Timer
handler.removeCallbacks(runnable); //停止Timer