我的TimerTask没有运行

时间:2016-04-12 13:50:31

标签: android timertask

由于某种原因我的计时器只运行一次:

代码:

int i = 0;
private void startTimer() {


    final Timer timer = new Timer();
    final TimerTask task = new TimerTask() {
        @Override
        public void run() {

            Log.d("DTAG","K1");

            if(preferences.getBoolean(IS_RUNNING_KEY, false))
            {
                Log.d("DTAG","K2");
                final int k = i++;
                runOnUiThread(new Runnable() {
                    @Override
                    public void run() {
                        timeCounter.setText(""+k);
                        Log.d("DTAG","K: "+k);
                    }
                });
            } else {

                Log.d("DTAG","K3");
                timer.cancel();
                timer.purge();

            }
        }
    };

    timer.schedule(task, 1000);

}

日志:

04-12 16:47:32.333 3079-3684/com.michlind.nanytime D/DTAG: K1
04-12 16:47:32.334 3079-3684/com.michlind.nanytime D/DTAG: K2
04-12 16:47:32.338 3079-3079/com.michlind.nanytime D/DTAG: K: 0

3 个答案:

答案 0 :(得分:4)

这是schedule(TimerTask, long)的预期行为。从文档

  

在指定的延迟后安排单个执行任务。

请尝试使用scheduleAtFixedRate

timer.scheduleAtFixedRate(task, 0, 1000);

您可以阅读更多here

答案 1 :(得分:1)

您需要使用两个参数调用 schedule 方法。首先是它必须等待多少才能开始,第二个是执行之间的间隔:

 // schedule the timer, after the first 1000ms the TimerTask will run every 1s
 timer.schedule(timerTask, 1000, 1000); //

答案 2 :(得分:1)

可以尝试阅读文档以更好地理解Timer

您正在使用的功能

 Timer.schedule(TimerTask, long)

在指定的延迟后安排单个执行任务。

使用

Timer.scheduleAtFixedRate (TimerTask task, long delay, long period)

用于在特定延迟通过后调度任务以重复固定速率执行,即在您的情况下

timer.schedule(task, 0, 1000);