Nougat / Oreo的JobScheduler

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

我在android中跟踪了一些关于jobscheduling的在线教程,我尝试了这样做,发现下面的代码编译没有错误。但问题是没有来自onPostExecute/doInBackground返回消息的祝酒词。有什么可能需要吗?就像我只是运行代码并放置一些吐司并注意到myScheduler.schedule(myjobInfo);工作,后台任务正在执行。

我的gradle文件根本没有被触及

compileSdkVersion 26
 defaultConfig {
    applicationId "com.example.umarmalik.myapplication"
    minSdkVersion 21
    targetSdkVersion 26
    versionCode 1
    versionName "1.0"
    testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
}

这是我的JobScheduler课程

  public class MJobScheduler extends JobService {

private MJobExecutor executor;


@Override
public boolean onStartJob(final JobParameters params) {

executor = new MJobExecutor(){
    @Override
    protected void onPostExecute(String s) {
        Toast.makeText(getApplicationContext(),s,Toast.LENGTH_LONG).show();
       jobFinished(params,true);
    }
};
    executor.execute();
    return true;
}

@Override
public boolean onStopJob(JobParameters params) {
    executor.cancel(true);
    return false;
}
}

这是我的JobExecutor

public class MJobExecutor extends AsyncTask<Void,Void,String> {

@Override
protected String doInBackground(Void... voids) {
    return "Background task running";
}
}

我的主要活动类如下:

public class MainActivity extends AppCompatActivity {


private static final int JOBID = 110;
private JobScheduler myScheduler;
private JobInfo myjobInfo;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    ComponentName myComp = new ComponentName(this,MJobScheduler.class);
    JobInfo.Builder myBuilder = new JobInfo.Builder(JOBID,myComp);

    myBuilder.setPeriodic(6000);
    myBuilder.setRequiredNetworkType(JobInfo.NETWORK_TYPE_ANY);
    myBuilder.setPersisted(true);


    myScheduler = (JobScheduler) getSystemService(JOB_SCHEDULER_SERVICE);
    myjobInfo = myBuilder.build();


    myScheduler.schedule(myjobInfo);
}
}

我的清单

<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

<application
    android:allowBackup="true"
    android:icon="@mipmap/ic_launcher"
    android:label="@string/app_name"
    android:roundIcon="@mipmap/ic_launcher_round"
    android:supportsRtl="true"
    android:theme="@style/AppTheme">
    <activity android:name=".MainActivity">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>

    <service
        android:name=".MJobScheduler"
        android:permission="android.permission.BIND_JOB_SERVICE"
        android:exported="true" />

</application>
android api android-studio android-jobscheduler jobservice
1个回答
3
投票

根据这个答案,定期工作的最短时间是15分钟,这就是为什么它不适合你。 https://stackoverflow.com/a/48337856/5604896

完成作业后更新活动的更好方法是使用广播接收器。如果活动正在运行,将会通知。

public class MJobScheduler extends JobService {

    private MJobExecutor executor;


    @Override
    public boolean onStartJob(final JobParameters params) {

        executor = new MJobExecutor(this, params);
        executor.execute();
        return true;
    }

    @Override
    public boolean onStopJob(JobParameters params) {
        executor.cancel(true);
        return false;
    }

    private static class MJobExecutor extends AsyncTask<Void, Void, String> {
        private WeakReference<JobService> jobServiceReference;
        private JobParameters params;

        MJobExecutor(JobService jobService, JobParameters params) {
            jobServiceReference = new WeakReference<>(jobService);
            this.params = params;
        }

        @Override
        protected String doInBackground(Void... voids) {
            return "Background task running";
        }

        @Override
        protected void onPostExecute(String s) {
            super.onPostExecute(s);
            JobService jobService = jobServiceReference.get();
            if (jobService != null) {
                Intent intent = new Intent("JOB_FINISHED");
                intent.putExtra("result", s);
                LocalBroadcastManager.getInstance(jobService).sendBroadcast(intent);
                jobService.jobFinished(params, true);
            }
        }
    }
}

而你的活动:

public class MainActivity extends AppCompatActivity {


    private static final int JOBID = 110;
    private JobScheduler myScheduler;
    private JobInfo myjobInfo;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        ComponentName myComp = new ComponentName(this, MJobScheduler.class);
        JobInfo.Builder myBuilder = new JobInfo.Builder(JOBID, myComp);
        myBuilder.setPeriodic(15 * 60 * 1000);

        myBuilder.setRequiredNetworkType(JobInfo.NETWORK_TYPE_ANY);
        myBuilder.setPersisted(true);

        myScheduler = (JobScheduler) getSystemService(JOB_SCHEDULER_SERVICE);
        myjobInfo = myBuilder.build();


        myScheduler.schedule(myjobInfo);

        LocalBroadcastManager.getInstance(this).registerReceiver(broadcastReceiver, new IntentFilter("JOB_FINISHED"));
    }

    private BroadcastReceiver broadcastReceiver = new BroadcastReceiver() {
        @Override
        public void onReceive(Context context, Intent intent) {
            Toast.makeText(context, intent.getStringExtra("result"), Toast.LENGTH_LONG).show();
        }
    };

    @Override
    protected void onDestroy() {
        super.onDestroy();
        LocalBroadcastManager.getInstance(this).unregisterReceiver(broadcastReceiver);
    }
}
最新问题
© www.soinside.com 2019 - 2024. All rights reserved.