Я продолжаю получать исключение нулевого указателя при вызове метода ниже внутри метода запуска.
protected void swTimerDisplay()
{
String display;
long now;
long diff;
long secs;
long mins;
long hours;
if(timerIsRunning)
{
now = System.currentTimeMillis();
}else{
now = endTime;
}
diff = now - startTime;
if(diff < 0)
{
diff = 0;
}
/**
* Calculate the
* secs,mins and hours
*/
secs = diff / 1000;
mins = secs / 60;
hours = mins / 60;
secs = secs % 60;
mins = mins % 60;
display = String.format("%d", hours) + ":" +
String.format("%02d", mins) + ":" +
String.format("%02d", secs);
swCounter.setText(display);
}
вот вывод журнала cat
02-18 19:47:27.143: E/AndroidRuntime(1695): FATAL EXCEPTION: main
02-18 19:47:27.143: E/AndroidRuntime(1695): Process: com.webdeveloper93.profitnessstopwatch, PID: 1695
02-18 19:47:27.143: E/AndroidRuntime(1695): java.lang.NullPointerException
02-18 19:47:27.143: E/AndroidRuntime(1695): at com.webdeveloper93.profitnessstopwatch.StopwatchTimer.swTimerDisplay(StopwatchTimer.java:57)
02-18 19:47:27.143: E/AndroidRuntime(1695): at com.webdeveloper93.profitnessstopwatch.timerUpdate.run(timerUpdate.java:22)
02-18 19:47:27.143: E/AndroidRuntime(1695): at android.os.Handler.handleCallback(Handler.java:733)
02-18 19:47:27.143: E/AndroidRuntime(1695): at android.os.Handler.dispatchMessage(Handler.java:95)
02-18 19:47:27.143: E/AndroidRuntime(1695): at android.os.Looper.loop(Looper.java:137)
02-18 19:47:27.143: E/AndroidRuntime(1695): at android.app.ActivityThread.main(ActivityThread.java:4998)
02-18 19:47:27.143: E/AndroidRuntime(1695): at java.lang.reflect.Method.invokeNative(Native Method)
02-18 19:47:27.143: E/AndroidRuntime(1695): at java.lang.reflect.Method.invoke(Method.java:515)
02-18 19:47:27.143: E/AndroidRuntime(1695): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:777)
Спасибо за любую помощь, которую вы можете предоставить.
ИЗМЕНИТЬ:
Строка 57: swCounter.setText(display);
ниже показано, где swTimerDisplay(); называется
public class timerUpdate extends StopwatchTimer implements Runnable {
@Override
public void run() {
swTimerDisplay();
if(handle != null)
{
handle.postDelayed(this, UPDATE);
}
}
}
надеюсь, кто-то может помочь мне понять это, потому что это сводит меня с ума :) еще раз спасибо
EDIT: Вот дополнительный код по запросу
public class Stopwatch extends Activity implements OnClickListener {
private StopwatchTimer timer;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.stopwatch);
//Create new instance of StopwatchTimer
timer = new StopwatchTimer();
timer.swCounter = (TextView) findViewById(R.id.swcounter);
timer.start = (Button) findViewById(R.id.start);
timer.stop = (Button) findViewById(R.id.stop);
timer.start.setOnClickListener(this);
timer.stop.setOnClickListener(this);
}
@Override
public void onClick(View v) {
if(v==timer.start)
{
timer.timerStart();
}else if(v==timer.stop)
{
timer.timerStop();
}
}
public final Runnable timerUpdate = new Runnable(){
public void run(){
try {
timer.swTimerDisplay();
if(timer.handle != null)
{
timer.handle.postDelayed(this, StopwatchTimer.UPDATE);
}
}
catch (Exception e) {
e.printStackTrace();
}
}
};
}
выше мой код, и swTimerDisplay вызывается в методе запуска
swCounter
бытьnull
? Какая строкаStopwatchTimer.java:57
вообще? - person MadProgrammer   schedule 19.02.2014endTime
? - person Kevin Bowersox   schedule 19.02.2014endTime
может быть только примитивным (скорее всего, длинным). @DigCamara Плохо просто догадываться, вы можете сделать вывод из кода OP, чтоstartTime
является примитивом (вероятно, длинным). - person SK9   schedule 19.02.2014