简体   繁体   English

如果我使用服务android,为什么我的应用程序关闭?

[英]Why does my app shut down if i use service android?

I'm trying to make a simple audio player. 我正在尝试制作一个简单的音频播放器。 When I create it in the main activity without service, it works correctly, music is playing (it works if I press power button to turn off the screen) and this is still working correctly after turn on the screen. 当我在没有服务的主活动中创建它时,它正常工作,音乐正在播放(如果我按下电源按钮关闭屏幕就可以工作)并且在打开屏幕后仍然可以正常工作。 But if I use service for playing music in the background, my app shuts down when I press power button for turn on the screen. 但是,如果我使用服务在后台播放音乐,当我按下电源按钮打开屏幕时,我的应用程序会关闭。

public class MainActivity extends AppCompatActivity {

    static ArrayList<HashMap<String, Object>> listSongs = new ArrayList<>();
    Intent intent;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        listSongs = getAllMusicInfo();
        intent = new Intent(this, BackgroundPlayer.class);

        Button buttonStart = (Button) findViewById(R.id.startService);
        buttonStart.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                startService(intent);
                Toast.makeText(MainActivity.this, "It's started", Toast.LENGTH_SHORT).show();
            }
        });

        Button buttonStop = (Button) findViewById(R.id.StopService);
        buttonStop.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                stopService(intent);
                Toast.makeText(MainActivity.this, "It's stopped", Toast.LENGTH_SHORT).show();
            }
        });
    }

    public class BackgroundPlayer extends Service implements MediaPlayer.OnCompletionListener {
    MediaPlayer player;

    @Override
    public void onCreate() {
        super.onCreate();

        player = new MediaPlayer();

        try {
            player.setDataSource((String) MainActivity.listSongs.get(0).get("path"));
            player.prepare();
        } catch (IOException e) {
            e.printStackTrace();
        }
    }

    @Nullable
    @Override
    public IBinder onBind(Intent intent) {
        return null;
    }

    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {
        player.start();
        return START_STICKY;
    }

    @Override
    public void onCompletion(MediaPlayer mp) {}
}

06-05 09:58:54.206 31873-31873/com.vitaliylevashov.serviceplayer V/MediaPlayer: start

06-05 09:58:54.206 31873-31885/com.vitaliylevashov.serviceplayer V/MediaPlayer: message received msg=6, ext1=0, ext2=0 06-05 09:58:54.206 31873-31885/com.vitaliylevashov.serviceplayer V/MediaPlayer: Received MEDIA_STARTED 06-05 09:58:54.206 31873-31885/com.vitaliylevashov.serviceplayer V/MediaPlayer: callback application 06-05 09:58:54.206 31873-31885/com.vitaliylevashov.serviceplayer V/MediaPlayer: back from callback 06-05 09:58:54.236 31873-31873/com.vitaliylevashov.serviceplayer I/MediaPlayer: Don't send intent. 06-05 09:58:54.206 31873-31885 / com.vitaliylevashov.serviceplayer V / MediaPlayer:收到的消息msg = 6,ext1 = 0,ext2 = 0 06-05 09:58:54.206 31873-31885 / com.vitaliylevashov。 serviceplayer V / MediaPlayer:已收到MEDIA_STARTED 06-05 09:58:54.206 31873-31885 / com.vitaliylevashov.serviceplayer V / MediaPlayer:回调申请06-05 09:58:54.206 31873-31885 / com.vitaliylevashov.serviceplayer V / MediaPlayer :回调06-05 09:58:54.236 31873-31873 / com.vitaliylevashov.serviceplayer I / MediaPlayer:不发送意图。 msg.arg1 = 0, msg.arg2 = 0 06-05 09:58:54.236 31873-31873/com.vitaliylevashov.serviceplayer E/MediaPlayer: Should have subtitle controller already set 06-05 09:58:54.256 31873-31873/com.vitaliylevashov.serviceplayer V/MediaPlayer-JNI: getCurrentPosition: 192 (msec) 06-05 09:58:54.256 31873-31873/com.vitaliylevashov.serviceplayer V/MediaPlayer-JNI: isPlaying: 1 << 06-05 09:59:25.526 31873-31873/com.vitaliylevashov.serviceplayer D/AndroidRuntime: Shutting down VM 06-05 09:59:25.526 31873-31873/com.vitaliylevashov.serviceplayer W/dalvikvm: threadid=1: thread exiting with uncaught exception (group=0x41660bc0) 06-05 09:59:25.526 31873-31873/com.vitaliylevashov.serviceplayer E/AndroidRuntime: FATAL EXCEPTION: main Process: com.vitaliylevashov.serviceplayer, PID: 31873 android.database.StaleDataException: Attempted to access a cursor after it has been closed. msg.arg1 = 0,msg.arg2 = 0 06-05 09:58:54.236 31873-31873 / com.vitaliylevashov.serviceplayer E / MediaPlayer:应该已经设置了字幕控制器06-05 09:58:54.256 31873-31873 / com.vitaliylevashov.serviceplayer V / MediaPlayer-JNI:getCurrentPosition:192(msec)06-05 09:58:54.256 31873-31873 / com.vitaliylevashov.serviceplayer V / MediaPlayer-JNI:isPlaying:1 << 06-05 09: 59:25.526 31873-31873 / com.vitaliylevashov.serviceplayer D / AndroidRuntime:关闭VM 06-05 09:59:25.526 31873-31873 / com.vitaliylevashov.serviceplayer W / dalvikvm:threadid = 1:线程退出未捕获的异常( group = 0x41660bc0)06-05 09:59:25.526 31873-31873 / com.vitaliylevashov.serviceplayer E / AndroidRuntime:FATAL EXCEPTION:main进程:com.vitaliylevashov.serviceplayer,PID:31873 android.database.StaleDataException:试图访问a光标关闭后。 at android.database.BulkCursorToCursorAdaptor.throwIfCursorIsClosed(BulkCursorToCursorAdaptor.java:64) at android.database.BulkCursorToCursorAdaptor.requery(BulkCursorToCursorAdaptor.java:133) at android.database.CursorWrapper.requery(CursorWrapper.java:186) at android.app.Activity.performRestart(Activity.java:5346) at android.app.ActivityThread.handleSleeping(ActivityThread.java:3487) at android.app.ActivityThread.access$3000(ActivityThread.java:155) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1428) at android.os.Handler.dispatchMessage(Handler.java:102) at android.os.Looper.loop(Looper.java:136) at android.app.ActivityThread.main(ActivityThread.java:5433) 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:1268) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1084) at dalvik.system.NativeStart.main(Native Method) 在android.database.BulkCursorToCursorAdaptor.throwIfCursorIsClosed(BulkCursorToCursorAdaptor.java:64)在android.database.BulkCursorToCursorAdaptor.requery(BulkCursorToCursorAdaptor.java:133)在android.database.CursorWrapper.requery(CursorWrapper.java:186)在android.app。 Activity.performRestart(Activity.java:5346)位于android.app.ActivityThread.acle上的android.app.ActivityThread.handleSleeping(ActivityThread.java:3487)(ActivityThread.java:155)$。 handleMessage(ActivityThread.java:1428)位于android.app.AtoT.Thread.main上的android.os.Handler.dispatchMessage(Handler.java:102)android.os.Looper.loop(Looper.java:136)处于ActivityThread.java :5433)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:1268)在dalvik.system.NativeStart.main(本地方法)的com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1084)

add a service tag in Manifest ,may be you havent added that in manifest 在Manifest中添加服务标签,可能你没有在清单中添加它

<service android:name=".MyService" />

request to post error log/logcat 请求发布错误日志/ logcat

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM