具有 START_STICKY 的 Android 服务在杀死应用程序时崩溃

问题描述 投票:0回答:1

这是我的

Service
Activity
上单击按钮时被呼叫。如果我在
Activity
运行时向左滑动
Service
,它就会崩溃。我还尝试通过在清单中放入
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)

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

我知道杀死应用程序就是杀死进程,并且

Intent
这个
Service
正在变得
null
。但即使
Activity
被杀,
Intent
也交给了
Service
,该怎么处理呢? 我希望服务完全独立于
Activity
。我也像这样运行它:

Intent pickIntent = new Intent(getApplicationContext(),MyLocationService.class);
java android android-service android-lifecycle
1个回答
5
投票

我知道杀死应用程序就是杀死进程,并且该服务所获得的意图将是空的。

既然你还没有发布

onStartCommand()
的返回值,我相信它是
START_STICKY
,意味着该服务是由系统重新创建的,并传入了
null
Intent

但是如何处理这种情况,即使活动被终止,意图也会移交给服务。

只需返回

START_REDELIVER_INTENT
标志,这意味着:

“如果系统在

onStartCommand()
返回后终止服务,请重新创建服务并使用传递给服务的最后一个意图调用
onStartCommand()
。”

© www.soinside.com 2019 - 2024. All rights reserved.