TimerTask не выполняется? - PullRequest
       4

TimerTask не выполняется?

1 голос
/ 19 июля 2011

Вот мой класс таймера. Этот класс предназначен для постоянного обновления таймера в представлении.Тем не менее, когда я запускаю приложение, на экране отображается первое сообщение с тостами, а второе никогда не появляется (метод «выполнения» timerTask никогда не выполняется).Я знаю, что это, вероятно, что-то простое, что я делаю неправильно.Если бы кто-нибудь мог направить меня в правильном направлении, это было бы здорово.

public class MyTimer  { 

static Timer _timerTask = new Timer();
static int totalSeconds = 1, hour = 0, min = 0, sec = 0;
static String mTimeFormat = "%02d:%02d:%02d";
static String timeTakenString;



public static void start (){
    Toast.makeText(GPSMain.context, "Message one", Toast.LENGTH_LONG).show();

    TimerTask timer = new TimerTask() {
        @Override
        public void run() {
            Toast.makeText(GPSMain.context, "Message two", Toast.LENGTH_LONG).show();
            totalSeconds += 1;
            sec += 1;
            if(sec >= 60) {
                sec = 0;
                min += 1;
                if (min >= 60) {
                    min = 0;
                    hour += 1;
                }
            }
            timeTakenString = String.format(mTimeFormat, hour, min, sec);
            postExecute.sendEmptyMessage(0); //update UI
        }
        private Handler postExecute = new Handler(){
            public void dispatchMessage(Message msg) {
                super.dispatchMessage(msg);
                GPSMain.timer.setText("Time Taken: "+timeTakenString);
            }
        };
    };
_timerTask.scheduleAtFixedRate(timer,1000,1000);
}
}

код в другом файле, вызывающем этот класс:

MyTimer myTimer = new MyTimer();
....
myTimer.start();

ИЗМЕНЕНИЕ ПРОЕКТА ИЗМЕНЕНО!Мой руководитель проекта изменил спецификацию проекта, так что ему больше не нужно обновлять таймер для пользовательского интерфейса, а отображать его как конечный результат.В любом случае, принять первый ответ, поскольку он решает исходную проблему.Выложу новый код ниже.

Новый код вызывает:

 System.currentTimeMillis();

в начале и в конце цикла выполнения, который возвращает long.Затем первое значение вычитается из второго значения, чтобы вычислить время, затраченное на выполнение цикла выполнения.Затем этим значением манипулируют и помещают в формат таймера, который отображается в конце в виде строки.

public static String getTimeTaken(long end, long start){
    @SuppressWarnings("unused")
    String formattedTime = "", hourHour = "", hourMin = ":", minSec = ":";
    long timeTaken = (end-start)/1000, hour = 0, min = 0, sec = 0;
    if (timeTaken>9 ){
        hourHour = "0";
        hourMin = ":0";
        if (timeTaken>=60){
            if (timeTaken>= 3200){
                hour = timeTaken/3200;
                timeTaken = timeTaken%3200;
                if (hour>9){
                    hourHour = "";
                }
            }
            min = timeTaken/60;
            timeTaken = timeTaken%60;
            if (min >9){
                hourMin = ":";
            }
        }
        sec = timeTaken;
        if(sec%60<10){
            minSec = ":0";
        }
        return formattedTime = (hourHour+hour+hourMin+min+minSec+sec);
    }
    sec = timeTaken;
    minSec = ":0";
    hourMin = ":0";
    hourHour = "0";
    return formattedTime = (hourHour+hour+hourMin+min+minSec+sec);
}

Ответы [ 2 ]

2 голосов
/ 19 июля 2011

Используя поток, вы не можете обновить свой интерфейс для того, чтобы использовать runOnUiThread

youractivity.this.runOnUiThread(new Runnable(){public void run(){Toast.makeText(mContext, "Message", Toast.LENGTH_LONG).show();}});
0 голосов
/ 12 июля 2012

(Очень поздно ... просто отвечать на вопрос, если кто-то дойдет до этого вопроса ... планирование задачи не гарантирует, что она будет выполнена в нужное время ... это может занять больше времени, иногда намного дольше ...)1001 *

...