android延時執行的幾種方式
阿新 • • 發佈:2019-01-06
在專案中有很多的方法可能我們不需要立即執行,那麼就需要延時。
首先第一種就是執行緒: 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
}
while(i<13) {
hanlder.postDelayed(runnable, delayMillis*i); i++;
/*此處postDelay不會阻塞執行緒,這裡的意思是等待delayMillis*i毫秒以後再將執行緒加入佇列,但是程式後面程式碼依然會立即繼續執行,而不是等待delayMillis*i毫秒後再執行。*//*剛開始我的理解是程式會在postDelayed處暫停等待 delayMillis*i毫秒後再執行後面的i++,但是經過測試,發現這是錯誤的。實際情況是程式會立即執行i++;所以這裡的執行情況應為:程式連續執行12次postDelayed,只是會在delayMills*i 毫秒後才依次加入佇列中。*/
第四種是 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) {
hanlder.postDelayed(runnable, delayMillis*i); i++;
/*此處postDelay不會阻塞執行緒,這裡的意思是等待delayMillis*i毫秒以後再將執行緒加入佇列,但是程式後面程式碼依然會立即繼續執行,而不是等待delayMillis*i毫秒後再執行。*//*剛開始我的理解是程式會在postDelayed處暫停等待 delayMillis*i毫秒後再執行後面的i++,但是經過測試,發現這是錯誤的。實際情況是程式會立即執行i++;所以這裡的執行情況應為:程式連續執行12次postDelayed,只是會在delayMills*i 毫秒後才依次加入佇列中。*/
第四種是 AlarmManager 一般的簡單任務不這麼做。