JobService和JobScheduler应用

JobScheduler scheduler = (JobScheduler) getSystemService(Context.JOB_SCHEDULER_SERVICE);
        ComponentName componentName = new ComponentName(MainActivity.this, MyJobServer.class);
        JobInfo.Builder builder = new JobInfo.Builder(++jobId, componentName);
            //设置JobService执行的最小延时时间
        builder.setMinimumLatency(5 * 1000);
            //设置JobService执行的最晚时间
        builder.setOverrideDeadline(20 * 1000);
		builder.setPeriodic(PERIOD);//设置下一次执行的时间间隔>= 15mins
        builder.setPersisted(true);

        //设置执行的网络条件
           builder.setRequiredNetworkType(JobInfo.NETWORK_TYPE_ANY);
		//**JobInfo.NETWORK_TYPE_UNMETERED 非移动网络**
        builder.setRequiresDeviceIdle(false);//是否要求设备为idle状态
        builder.setRequiresCharging(true);//是否要设备为充电状态

        scheduler.schedule(builder.build());
  • 同个jobid重复提交只会执行一次

JobSever

 <service android:name=".MyJobServer"
          android:permission="android.permission.BIND_JOB_SERVICE"/>
          
            
@RequiresApi(api = Build.VERSION_CODES.LOLLIPOP)
public class MyJobServer extends JobService {
    @Override
    public boolean onStartJob(JobParameters params) {
        Log.v("MyJobServer", "onStartJob" + params.getJobId());
        jobFinished(params, false);//如果参数传true,系统会在某个时间段重新执行该job
        return false;//return true 会直到调用了jobFinished()后才会释放系统资源
    }

    @Override
    public boolean onStopJob(JobParameters params) {
        Log.v("MyJobServer", "onStopJob" + params.getJobId());
        return false;
    }
}

最后,总结一下JobService的使用:

  1. 先继承JobService,并重写startJob和stopJob

  2. 在manifest.xml中声明JobService的时候,记得一定要加上

  3. android:permission=”android.permission.BIND_JOB_SERVICE”

  4. 后台任务不能执行耗时任务,如果一定要这么做,一定要再起一个线程去做,使用 thread/handler/AsyncTask都可以。

  5. JobService一定要设置至少一个执行条件,如有网络连接、充电中、系统空闲…

  6. 任务执行完后记得调用jobFinished()通知系统释放相关资源

  7. 如果我们的后台任务满足JobService的一个或多个约束条件,就可以考虑是不是应该用JobService来执行

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Foreground Service + JobScheduler 的方式可以通过同时利用前台服务和 JobScheduler 来实现应用保活,可以在系统资源充足的情况下执行任务,同时不会在通知栏显示持续的通知。下面是一个简单的实现方式: 1. 创建一个前台服务,将应用置于前台状态,并在 onStartCommand() 方法中返回 START_STICKY,表示服务被杀掉后会被系统重启。 ``` public class ForegroundService extends Service { ... @Override public int onStartCommand(Intent intent, int flags, int startId) { startForeground(NOTIFICATION_ID, new Notification()); return START_STICKY; } ... } ``` 2. 在 onCreate() 方法中创建一个 JobScheduler,定时执行任务。 ``` public class ForegroundService extends Service { ... private JobScheduler mJobScheduler; ... @Override public void onCreate() { super.onCreate(); mJobScheduler = (JobScheduler) getSystemService(Context.JOB_SCHEDULER_SERVICE); JobInfo jobInfo = new JobInfo.Builder(JOB_ID, new ComponentName(this, JobSchedulerService.class)) .setPeriodic(15 * 60 * 1000) // 每 15 分钟执行一次任务 .setRequiredNetworkType(JobInfo.NETWORK_TYPE_ANY) .build(); mJobScheduler.schedule(jobInfo); } ... } ``` 3. 创建一个 JobService,在 onStartJob() 方法中执行需要保持应用活跃的操作。 ``` public class JobSchedulerService extends JobService { ... @Override public boolean onStartJob(JobParameters params) { // 执行需要保持应用活跃的操作 return true; } ... } ``` 需要注意的是,为了避免被系统误识别为滥用权限,任务的执行间隔不宜过于频繁,同时需要适当调整任务的优先级和网络条件等参数,以确保任务可以在系统资源充足的情况下执行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值