启动时IntentService崩溃

皮埃尔·查尔斯·曼金

我的服务有问题。事实是,当它分层运行时,它会使我的所有应用程序崩溃。调试应用程序告诉我,“ onCreate”方法结束后崩溃(请参见下面的代码)。似乎它甚至无法访问onHandedIntent,但不能确定这一点!我把我的代码和日志放在下面。我检查了清单,没问题。

谢谢大家的帮助

package com.example.pierr.puremusictest2;
import android.app.IntentService;
import android.content.Intent;
import android.media.AudioManager;
import android.media.MediaPlayer;
import android.util.Log;

import java.io.IOException;

public class MusicPlayerService extends IntentService{
static MediaPlayer mPlayer;
Intent gIntent;
String url = "http://lolilol.890m.com/Musique/CapitalKings/II/Capital_Kings_-_Satellites_Official_Audio_Video-r8.aac";

public MusicPlayerService() {
    super("mainThreadService");
    Log.i("blablabblablba","creation that's it2");
}

public void onCreate(){
    Log.i("blablabblablba","creation that's it2");
    mPlayer = new MediaPlayer();
    mPlayer.setAudioStreamType(AudioManager.STREAM_MUSIC);
    Log.i("blablabblablba","musicPlayer created");
}

@Override
protected void onHandleIntent(Intent argo0) {
play();
}


public void play(){
    try {
        Log.i("voila c'est cool","play");
        mPlayer.setDataSource(url);
    } catch (IOException e) {
        e.printStackTrace();

    Log.i("test","destroy");       }
    mPlayer.start();

}

}

启动我的服务的意图:

case R.id.play:
            Intent intent = new Intent(getActivity(), MusicPlayerService.class);
            getActivity().startService(intent);
            break;

最后是日志:

 java.lang.RuntimeException: Unable to start service com.example.pierr.puremusictest2.MusicPlayerService@419ed5d8 with Intent { cmp=com.example.pierr.puremusictest2/.MusicPlayerService }: java.lang.NullPointerException
                                                                                at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:2719)
                                                                                at android.app.ActivityThread.access$2100(ActivityThread.java:135)
                                                                                at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1293)
                                                                                at android.os.Handler.dispatchMessage(Handler.java:102)
                                                                                at android.os.Looper.loop(Looper.java:136)
                                                                                at android.app.ActivityThread.main(ActivityThread.java:5027)
                                                                                at java.lang.reflect.Method.invokeNative(Native Method)
                                                                                at java.lang.reflect.Method.invoke(Method.java:515)
                                                                                at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
                                                                                at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
                                                                                at dalvik.system.NativeStart.main(Native Method)
                                                                             Caused by: java.lang.NullPointerException
                                                                                at android.app.IntentService.onStart(IntentService.java:116)
                                                                                at android.app.IntentService.onStartCommand(IntentService.java:130)
                                                                                at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:2702)
                                                                                at android.app.ActivityThread.access$2100(ActivityThread.java:135) 
                                                                                at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1293) 
                                                                                at android.os.Handler.dispatchMessage(Handler.java:102) 
                                                                                at android.os.Looper.loop(Looper.java:136) 
                                                                                at android.app.ActivityThread.main(ActivityThread.java:5027) 
                                                                                at java.lang.reflect.Method.invokeNative(Native Method) 
                                                                                at java.lang.reflect.Method.invoke(Method.java:515) 
                                                                                at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779) 
                                                                                at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595) 
                                                                                at dalvik.system.NativeStart.main(Native Method) 
常用软件

使用服务的onCreate()方法,super.onCreate()请先调用,然后再执行其他操作。

请注意,使用aIntentService来播放音乐是一个很奇怪的选择:

  • 您的onHandleIntent()方法中没有看起来需要后台线程的内容。

  • IntentService一旦onHandleIntent()返回将销毁我忘记了这MediaPlayer是否将停止播放(一旦丢失的MediaPlayer对象被垃圾回收),或者您只是失去对播放的控制权。

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章