Не удалось запустить службу [имя службы] с нулевым значением
Недавно я закодировал Android-виджет и протестировал его на эмуляторе, а также в своем Galaxy S, он отлично работал на обоих, после того как я опубликовал то же самое на рынке Android, теперь я получаю некоторые отчеты об ошибках.
Я указываю службу в onUpdate класса Widget следующим образом:
if (appWidgetIds != null) {
final int N = appWidgetIds.length;
// Perform this loop procedure for each App Widget that belongs to
// this
// provider
for (int i = 0; i < N; i++) {
// Start Service for each instance
int appWidgetId = appWidgetIds[i];
Intent active = new Intent(context, DialerService.class);
active.setAction("Start");
active.putExtra(AppWidgetManager.EXTRA_APPWIDGET_ID,
appWidgetId);
context.startService(active);
}
}
ошибка, которую некоторые люди получают:
java.lang.RuntimeException: Unable to start service [email protected] with null: java.lang.NullPointerException
at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:3282)
at android.app.ActivityThread.access$3600(ActivityThread.java:135)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2211)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:144)
at android.app.ActivityThread.main(ActivityThread.java:4937)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:521)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.NullPointerException
**at dialer.impact.DialerService.onStart(DialerService.java:18)**
at android.app.Service.onStartCommand(Service.java:420)
at android.app.ActivityThread.handleServiceArgs(ActivityThread.java:3267)
... 10 more
ошибка содержит a NullPointerException
в строке 18 ServiceClass
, которая такова:
@Override
public void onStart(Intent intent, int startId) {
//Line 18th
String command = intent.getAction();
int appWidgetId = intent.getExtras().getInt(
AppWidgetManager.EXTRA_APPWIDGET_ID);
RemoteViews remoteView = new RemoteViews(getApplicationContext()
.getPackageName(), R.layout.main);
AppWidgetManager appWidgetManager = AppWidgetManager
.getInstance(getApplicationContext());
}
Строка 18 - это String command = intent.getAction();
что может быть причиной намерения быть нулевым
пожалуйста, помогите
Ответы
Ответ 1
В соответствии с документацией для onStart()
(фактически onStartCommand()
, но параметры одинаковы):
Задание Предназначен для запуска службы (намерения), как указано. Это может быть null, если служба перезапущен после его завершения и он ранее вернулся ничего, кроме START_STICKY_COMPATIBILITY.
Ответ 2
Привет, просто добавьте к этому, поэтому обходным путем является просто добавить if (intent!= null) до getAction()? Если я это сделаю, будет ли сервис запущен должным образом позже? Это означает, что ОС фактически помогает мне правильно запустить службу в случае нулевого намерения. Я боюсь оказаться в ситуации, когда служба вообще не запускается.