我正在使用JobService构建应用。此JobService应每1分钟启动一次服务。
这是我的JobService类:
public class BleJobService extends JobService {
JobParameters params;
DoItTask doIt;
@Override
public boolean onStartJob(JobParameters jobParameters) {
this.params = params;
Log.d("TestService", "Work to be called from here");
startService(new Intent(this, BlePowerService_JobScheduler.class));
/*doIt = new DoItTask();
doIt.execute();*/
jobFinished(params, false);
return true;
}
@Override
public boolean onStopJob(JobParameters jobParameters) {
Log.d("TestService", "System calling to stop the job here");
if (doIt != null)
doIt.cancel(true);
return false;
}
private class DoItTask extends AsyncTask<Void, Void, Void> {
@Override
protected void onPostExecute(Void aVoid) {
Log.d("DoItTask", "Clean up the task here and call jobFinished...");
jobFinished(params, false);
super.onPostExecute(aVoid);
}
@Override
protected Void doInBackground(Void... params) {
Log.d("DoItTask", "Working here...");
return null;
}
}
}
但如果我尝试启动此JobService,则会出现此错误:
FATAL EXCEPTION: main
Process: com.eresult.diabesitycare.devicesensor, PID: 15938
java.lang.NullPointerException: Attempt to invoke virtual method 'android.app.job.IJobCallback android.app.job.JobParameters.getCallback()' on a null object reference
at android.app.job.JobService$JobHandler.handleMessage(JobService.java:161)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6776)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1496)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1386)
问题在于此行代码:
jobFinished(params, false);
params为null
答案 0 :(得分:1)
this.params = params
(除非params
来自其他地方)是自我分配。
鉴于它最初未实例化,因此引用仍为null
,因此NPE
。
你可能意味着
this.params = jobParameters;