Как остановить Handler Runnable?
Я использую обработчик в следующей программе, и я хочу остановить его, когда я =5, но обработчик не останавливается и работает непрерывно.
b1.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
handler = new Handler();
runnable = new Runnable() {
public void run() {
try {
Toast.makeText(getApplicationContext(), "Handler is working", Toast.LENGTH_LONG).show();
System.out.print("Handler is working");
if(i==5){
//Thread.currentThread().interrupt();
handler.removeCallbacks(runnable);
System.out.print("ok");
Toast.makeText(getApplicationContext(), "ok", Toast.LENGTH_LONG).show();
}
i++;
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
handler.postDelayed(this, 5000);
}
};
handler.postDelayed(runnable, 5000);
//return;
}
});
4 ответа
Потому что вы звоните postDelayed()
снова после удаления перезвонов. Пожалуйста, используйте этот код:
final Handler handler = new Handler();
final Runnable runnable = new Runnable() {
public void run() {
Log.d("Runnable","Handler is working");
if(i == 5){ // just remove call backs
handler.removeCallbacks(this);
Log.d("Runnable","ok");
} else { // post again
i++;
handler.postDelayed(this, 5000);
}
}
};
//now somewhere in a method
b1.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
handler.removeCallbacks(runnable);
handler.postDelayed(runnable, 5000);
}
});
protected void onStop() {
super.onStop();
handler.removeCallbacks(runnable);
}
Вы можете остановить это так
Просто видел этот вопрос. Я бы использовал CountDownTimer() вместо этого. Запустите его всего за 5 секунд и каждую секунду:
new CountDownTimer(5000, 1000) {
public void onTick(long milsecRemain) {
// Code to run every second
Log.i("Seconds left", String.valueOf(milsecRemain/1000));
}
public void onFinish() {
// 10 seconds have passed
}
}.start();
Вы не показываете, где "я" инициализируется. Может быть, это никогда не < 5.
Я нашел решение, которое работает для меня. Это пример кода, где я ожидаю остановки по таймеру, но я видел, что он был жив, даже если я не работал:
boolean bFlagForceExit = false;
Handler timerHandler = new Handler();
private Runnable timerRunnable = new Runnable() {
@Override
public void run() {
if (bFlagForceExit )
MyProcessForExit();
if (bSomeflagForRunAction)
RunProcess();
timerHandler.postDelayed(this, MILISEGUNDOS_ESPERA); }
};
private void MyProcessForExit()
{
timerHandler.removeCallbacks(timerRunnable);
// close activity or whatever
finish();
}
private void RunProcess()
{
// action that i do when tick
// time to leave or stop
bFlagForceExit = true;
}
Тогда я обнаружил, что это работает, если removeCallbacks(timerRunnable)
был вызван для других тем, поэтому я решил проблему следующим образом.
boolean bFlagForceExit = false;
Handler timerHandler = new Handler();
private Runnable timerRunnable = new Runnable() {
@Override
public void run() {
if (bFlagForceExit )
{
// add a thred for run your stop handler
new Thread(new Runnable() {
public void run() {
SalirDeProceso();
}
}).start();
}
if (bSomeflagForRunAction)
RUnProcess();
timerHandler.postDelayed(this, MILISEGUNDOS_ESPERA); }
};