在项目中有很多的方法可能我们不需要立即执行,那么就需要延时。
首先第一种就是线程: sleep会阻塞线程
new Thread (new Runnable(){
public void run(){
Thread.sleep(time);
method(); //执行的方法
}
})
第二种就是 定时器:
TimerTask task = new TimerTask(){
public void run(){
//method
}
}
Timer timer = new Timer();
timer.schedule(task,delay);
第三种就是: postDelayed不会阻塞线程
new Handler().postDelayed(new Runnable(){
public void run(){
//execute the task
}
第四种是 AlarmManager 一般的简单任务不这么做。
首先第一种就是线程: sleep会阻塞线程
new Thread (new Runnable(){
public void run(){
Thread.sleep(time);
method(); //执行的方法
}
})
第二种就是 定时器:
TimerTask task = new TimerTask(){
public void run(){
//method
}
}
Timer timer = new Timer();
timer.schedule(task,delay);
第三种就是: postDelayed不会阻塞线程
new Handler().postDelayed(new Runnable(){
public void run(){
//execute the task
}
},delay);
例如如下代码:
int i = 0;
long delayMillis = 900000;
while(i<13)
while(i<13)
{
hanlder.postDelayed(runnable, delayMillis*i);
hanlder.postDelayed(runnable, delayMillis*i);
i++;
/*
此处postDelay不会阻塞线程,这里的意思是等待delayMillis*i毫秒以后再将线程加入队列,但是程序后面代码依然会立即继续执行,而不是等待delayMillis*i毫秒后再执行。*/
/*刚开始我的理解是程序会在postDelayed处暂停等待 delayMillis*i毫秒后再执行后面的i++,但是经过测试,发现这是错误的。实际情况是程序会立即执行i++;所以这里的执行情况应为:程序连续执行12次postDelayed,只是会在delayMills*i 毫秒后才依次加入队列中。*/
第四种是 AlarmManager 一般的简单任务不这么做。