解决这个问题对我来说有点困难,因为我是通过别人的安卓设备的崩溃报告得到的,我没有办法问他们问题,而且我从来没有在我自己的安卓设备上看到过这种情况。
崩溃报告说它是 Android 4.1.2,堆栈跟踪是:
java.lang.NullPointerException
at android.media.MediaPlayer$EventHandler.handleMessage(MediaPlayer.java:2102)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:5021)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:556)
at dalvik.system.NativeStart.main(Native Method)
不幸的是,grepcode.com 上的 android 源代码似乎与这些行号不匹配,所以我不确定哪个是空的。
我不知道发生这种情况时用户在做什么,所以我不知道这是在播放音乐或音效时发生的,还是在销毁时发生的。我有点怀疑它可能在销毁期间发生。我在活动的 onDestroy 方法中有以下代码:
public void onDestroy() {
synchronized(curPlayers) {
for(List<MediaP> ms : curPlayers.values()) {
synchronized(ms) {
for(MediaP m : ms) {
synchronized(m) {
m.m.stop();
m.m.release();
}
}
}
}
curPlayers.clear();
}
}
private static class MediaP {
private MediaP(MediaPlayer m) {
this.m = m;
}
private MediaPlayer m;
private boolean wasPlaying = false;
}
里面有什么我应该做的吗?