Как остановить таймер после определенного количества раз
Попытка использовать Timer
для выполнения этого 4 раза с интервалом в 10 секунд каждый.
Я пытался остановить его с помощью петли, но он продолжает разбиваться. Я пробовал использовать schedule()
с тремя параметрами, но я не знал, где реализовать переменную счетчика. Есть идеи?
final Handler handler = new Handler();
Timer timer2 = new Timer();
TimerTask testing = new TimerTask() {
public void run() {
handler.post(new Runnable() {
public void run() {
Toast.makeText(MainActivity.this, "test",
Toast.LENGTH_SHORT).show();
}
});
}
};
int DELAY = 10000;
for (int i = 0; i != 2 ;i++) {
timer2.schedule(testing, DELAY);
timer2.cancel();
timer2.purge();
}
3 ответа:
private final static int DELAY = 10000; private final Handler handler = new Handler(); private final Timer timer = new Timer(); private final TimerTask task = new TimerTask() { private int counter = 0; public void run() { handler.post(new Runnable() { public void run() { Toast.makeText(MainActivity.this, "test", Toast.LENGTH_SHORT).show(); } }); if(++counter == 4) { timer.cancel(); } } }; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); timer.schedule(task, DELAY, DELAY); }
Почему бы не использовать
AsyncTask
и просто иметь его поток.sleep (10000) иpublishProgress
в цикле while? Вот как это будет выглядеть:new AsyncTask<Void, Void, Void>() { @Override protected Void doInBackground(Void... params) { int i = 0; while(i < 4) { Thread.sleep(10000); //Publish because onProgressUpdate runs on the UIThread publishProgress(); i++; } // TODO Auto-generated method stub return null; } @Override protected void onProgressUpdate(Void... values) { super.onProgressUpdate(values); //This is run on the UIThread and will actually Toast... Or update a View if you need it to! Toast.makeText(MainActivity.this, "test", Toast.LENGTH_SHORT).show(); } }.execute();
Также в качестве дополнительной заметки, для более длительных повторяющихся задач, рассмотрите использование
AlarmManager
...