2012-12-13 7 views
2

내 음악 플레이어 응용 프로그램에 문제가있는 것 같습니다. 나가면 강제 종료 경고가 나타납니다. 이것은 내가 그것을 디버깅 후 문제의 원인 일 수 있습니다 생각하는 코드의 일부입니다응용 프로그램 종료시 Android 종료

private Runnable mUpdateTimeTask = new Runnable() { 
      public void run() { 
       long totalDuration = mp.getDuration(); 
       long currentDuration = mp.getCurrentPosition(); 

       // Displaying Total Duration time 
       songTotalDurationLabel.setText(""+utils.milliSecondsToTimer(totalDuration)); 
       // Displaying time completed playing 
       songCurrentDurationLabel.setText(""+utils.milliSecondsToTimer(currentDuration)); 

       // Updating progress bar 
       int progress = (int)(utils.getProgressPercentage(currentDuration, totalDuration)); 
       //Log.d("Progress", ""+progress); 
       songProgressBar.setProgress(progress); 

       // Running this thread after 100 milliseconds 
       mHandler.postDelayed(this, 100); 
      } 
     }; 

을 그리고 여기에 로그 캣입니다 : 내가 생각

12-13 13:26:01.700: E/AndroidRuntime(31838): FATAL EXCEPTION: main 
12-13 13:26:01.700: E/AndroidRuntime(31838): java.lang.IllegalStateException 
12-13 13:26:01.700: E/AndroidRuntime(31838): at android.media.MediaPlayer.getDuration(Native Method) 
12-13 13:26:01.700: E/AndroidRuntime(31838): at com.example.musicshare.AndroidBuildingMusicPlayerActivity$1.run(AndroidBuildingMusicPlayerActivity.java:341) 
12-13 13:26:01.700: E/AndroidRuntime(31838): at android.os.Handler.handleCallback(Handler.java:587) 
12-13 13:26:01.700: E/AndroidRuntime(31838): at android.os.Handler.dispatchMessage(Handler.java:92) 
12-13 13:26:01.700: E/AndroidRuntime(31838): at android.os.Looper.loop(Looper.java:123) 
12-13 13:26:01.700: E/AndroidRuntime(31838): at android.app.ActivityThread.main(ActivityThread.java:3691) 
12-13 13:26:01.700: E/AndroidRuntime(31838): at java.lang.reflect.Method.invokeNative(Native Method) 
12-13 13:26:01.700: E/AndroidRuntime(31838): at java.lang.reflect.Method.invoke(Method.java:507) 
12-13 13:26:01.700: E/AndroidRuntime(31838): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:847) 
12-13 13:26:01.700: E/AndroidRuntime(31838): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:605) 
12-13 13:26:01.700: E/AndroidRuntime(31838): at dalvik.system.NativeStart.main(Native Method) 

문제는 mp.getDuration 함께하지만, 나는 그것을 고치는 법을 모른다.

답변

5

실행 가능한 작업은 마치 후에도 실행되는 것처럼 보입니다. 제 의견은 당신이 removeCallbacks()에 전화하는 걸 잊을 수 있다는 것입니다.

나의 제안은 당신이 그것을 밖으로 당신의 코드를 사용할 수 있도록 전 세계적으로 당신의 Runnable mUpdateTimeTask를 선언합니다, 당신의 onBackPressed() 또는 앱을 종료 장소에

mHandler.removeCallbacks(mUpdateTimeTask); 

을 아래 라인을 추가하는 것입니다.

+0

덕분에 콜백을 제거해야 –

0

은 나를 위해 작동 postRunnable 전에

mHandler.removeCallbacks(mUpdateTimeTask); 
mHandler.post(...);