【发布时间】:2018-01-31 01:27:30
【问题描述】:
为什么我的异步任务返回 null?它以前工作得很好。我做错了什么?
我是一名新开发人员,我不太了解如何解决此问题。
这是我的代码。
private class PlayAudioFileBg extends AsyncTask<String, Object, MediaPlayer> {
@Override
protected MediaPlayer doInBackground(String... params) {
try {
mMediaPlayer = new MediaPlayer();
mMediaPlayer.setAudioStreamType(AudioManager.STREAM_MUSIC);
mMediaPlayer.setDataSource(params[0]);
mMediaPlayer.prepare();
return mMediaPlayer;
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
return null;
}
@Override
protected void onPostExecute(final MediaPlayer mediaPlayer) {
super.onPostExecute(mediaPlayer);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
mSeekBar.setProgress(0, true);
}else{
mSeekBar.setProgress(0);
}
mediaPlayer.start();
mSeekBar.setEnabled(true);
mediaPlayer.setOnCompletionListener(new MediaPlayer.OnCompletionListener() {
@Override
public void onCompletion(MediaPlayer mp) {
if(repeatTimes != 0){
mediaPlayer.start();
}else{
releaseMediaPlayer();
}
}
});
原木猫 08-22 09:51:04.279 11359-11359/com.example.android.top10music E/AndroidRuntime: 致命异常: main 进程:com.example.android.top10music,PID:11359 java.lang.NullPointerException:尝试调用虚拟方法'void android.media.MediaPlayer.start()' 在空对象引用上 在 com.example.android.top10music.NarutoActivity$PlayAudioFileBg.onPostExecute(NarutoActivity.java:404) 在 com.example.android.top10music.NarutoActivity$PlayAudioFileBg.onPostExecute(NarutoActivity.java:375) 在 android.os.AsyncTask.finish(AsyncTask.java:632) 在 android.os.AsyncTask.access$600(AsyncTask.java:177) 在 android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:645) 在 android.os.Handler.dispatchMessage(Handler.java:102) 在 android.os.Looper.loop(Looper.java:135) 在 android.app.ActivityThread.main(ActivityThread.java:5753) 在 java.lang.reflect.Method.invoke(本机方法) 在 java.lang.reflect.Method.invoke(Method.java:372) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1405) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1200)
【问题讨论】:
-
请详细解释“我的异步任务返回 null”是什么意思。
AsyncTask不会“返回”任何东西。如果您的意思是doInBackground()正在返回null,请检查 LogCat,因为您正在捕获异常并在那里记录堆栈跟踪。 -
查看 logcat 内部,您应该会发现异常。或者在 catch 块中放置断点并打印 e.getMessage()
-
张贴你的日志猫
-
是的,doInBackground 方法返回 null 我的日志猫正在打印 NullPointerException
-
mediaPlayer 在哪里定义为变量?
标签: android