具有 START_STICKY 的 Android 服务在终止应用程序时崩溃

标签 android android-service android-lifecycle

这是我的 Service 在从 Activity 中单击按钮时被调用。如果我在 Service 运行时向左滑动 Activity,它就会崩溃。我还尝试通过在 list 中放入 android:process=":remote" 在单独的进程中运行它,但它仍然是一样的。

@Override
public void onCreate(){
    super.onCreate();
    Log.d("Service", "Creating");
}

@Override
public IBinder onBind(Intent intent) {
    // TODO: Return the communication channel to the service.
    return null;
}

@Override
public int onStartCommand (Intent intent, int flags, int startId)
{
    super.onStartCommand(intent, flags, startId);

    Log.d("Started", "Service");

    type = intent.getIntExtra("Type",-1);
    mode = intent.getIntExtra("Mode",-1);
    rank = intent.getIntExtra("Rank", -1);
    latitude = intent.getDoubleExtra("Lat", -1.0);
    longitude = intent.getDoubleExtra("Long", -1.0);
    startTime = intent.getLongExtra("Start", 0);
    endTime = intent.getLongExtra("End", 0);

我得到的错误是:

  java.lang.RuntimeException: Unable to start service com.routofy.routofytest.MyLocationService@374afe93 with null: java.lang.NullPointerException: Attempt to invoke virtual method 'int android.content.Intent.getIntExtra(java.lang.String, int)' on a null object reference
        at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:2913)
        at android.app.ActivityThread.access$2100(ActivityThread.java:148)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1390)
        at android.os.Handler.dispatchMessage(Handler.java:102)
        at android.os.Looper.loop(Looper.java:135)
        at android.app.ActivityThread.main(ActivityThread.java:5312)
        at java.lang.reflect.Method.invoke(Native Method)
        at java.lang.reflect.Method.invoke(Method.java:372)
        at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:901)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:696)
 Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'int android.content.Intent.getIntExtra(java.lang.String, int)' on a null object reference
        at com.routofy.routofytest.MyLocationService.onStartCommand(MyLocationService.java:89)
        at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:2896)
at android.app.ActivityThread.access$2100(ActivityThread.java:148)
at    android.app.ActivityThread$H.handleMessage(ActivityThread.java:1390)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5312)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:901)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:696)

type = intent.getIntExtra("Type",-1); 上的 null 指针;

我知道终止应用程序就是终止进程,Intent 这个 Service 得到的结果是 null。但是如何处理这种情况,即使Activity被杀死,Intent也交给了Service? 我希望服务完全独立于 Activity。我也像这样运行它:

Intent pickIntent = new Intent(getApplicationContext(),MyLocationService.class);

最佳答案

I understand that killing the app is killing the process and intent this service is getting is coming out to be null.

由于您还没有发布 onStartCommand() 的返回值,我相信它是 START_STICKY,这意味着该服务由系统使用 null< 重新创建 Intent 传入。

But how to handle such cases that even if activity is killed intent is handed over to service.

只需返回START_REDELIVER_INTENT标志,这意味着:

“如果系统在 onStartCommand() 返回后终止服务,请重新创建服务并使用传递给服务。”

关于具有 START_STICKY 的 Android 服务在终止应用程序时崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32634566/

相关文章:

android - ViewPagerIndicator.CirclePageIndicator 在 OnSaveInstanceState 中崩溃

android - 从 android webkit 浏览器获取当前 Url

java - 无法使用 dagger2 android java 注入(inject) ViewModel

android - 我可以将 Intent Service 放入库项目中并在不同的应用程序中使用它吗?

java - 示例应用程序无法在虚拟设备上运行

android - handleLifecycleEvent 和 markState 之间有什么区别(来自 LifecycleRegistry 类)

Android本地服务注册

android - 修复 Android 屏幕底部的内容

Android在线程内创建处理程序到服务

android - 当我锁定屏幕时,Android 上的 OpenSL 音频停止 5.0.1 OK 6.0.1 Not OK