jobFinisced的空对象引用

时间:2018-05-15 09:05:22

标签: android jobservice

我正在使用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

1 个答案:

答案 0 :(得分:1)

this.params = params(除非params来自其他地方)是自我分配。

鉴于它最初未实例化,因此引用仍为null,因此NPE

你可能意味着

this.params = jobParameters;