您的位置:首页 > 移动开发 > Android开发

JobService和JobScheduler机制在Android5.0以上保活

2017-04-05 16:17 288 查看
原文地址:http://blog.csdn.net/mynameishuangshuai/article/details/52770129

http://blog.csdn.net/qq_33689414/article/details/54668889

通常在5.0之前,我们可以使用广播或者闹钟等方式让我们的进程防杀自启,而5.0以后的Android系统,我们就可以使用JobService,JobService它是Android5.0以后新增的一个服务,我们先来看下官方的解释。



Google从Android SDK 21之后添加了JobScheduler来执行一些满足特定条件但不紧急的后台任务,我们可以利用JobScheduler来执行这些特殊的后台任务时来减少电量的消耗。JobService则是一个抽象类,其中包含两个抽象方法:
abstract boolean onStartJob(JobParameters params)
// 我们需要重写onStartJob方法在JobService被调度的时候
abstract boolean onStopJob(JobParameters params)
// 如果确定停止系统调度作业,即使调度作业可能被完成,将调用此方法
1
2
3
4


1
2
3
4

当我们有以下需求时,可以使用调度作业
APP有可以推迟的非面向用户的工作
APP有当插入设备时您希望优先执行的工作
APP有需要访问网络或 Wi-Fi 连接的任务
APP有希望作为一个批次定期运行的许多任务

接下来,我们使用JobService来实现APP进程防杀。 
1.首先声明权限
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>
1
1

2.自定义一个Service类,继承自JobService

@TargetApi(Build.VERSION_CODES.LOLLIPOP)
public class MyJobDaemonService extends JobService {
private int kJobId = 0;

@Override
public int onStartCommand(Intent intent, int flags, int startId) {
Log.i("MyJobDaemonService", "jobService启动");
scheduleJob(getJobInfo());
return START_NOT_STICKY;
}

@Override
public boolean onStartJob(JobParameters params) {
Log.i("MyJobDaemonService", "执行了onStartJob方法");
boolean isLocalServiceWork = isServiceWork(this, "com.marswin89.marsdaemon.demo.Service1");
boolean isRemoteServiceWork = isServiceWork(this, "com.marswin89.marsdaemon.demo.Service2");
if(!isLocalServiceWork||
!isRemoteServiceWork){
this.startService(new Intent(this,Service1.class));
// this.startService(new Intent(this,Service2.class));
// Toast.makeText(this, "进程启动", Toast.LENGTH_SHORT).show();
Log.i("onStartJob", "启动service1");
}
return true;
}

@Override
public boolean onStopJob(JobParameters params) {
Log.i("MyJobDaemonService", "执行了onStopJob方法");
scheduleJob(getJobInfo());
return true;
}

//将任务作业发送到作业调度中去
public void scheduleJob(JobInfo t) {
Log.i("MyJobDaemonService", "调度job");
JobScheduler tm =
(JobScheduler) getSystemService(Context.JOB_SCHEDULER_SERVICE);
tm.schedule(t);
}

public JobInfo getJobInfo(){
JobInfo.Builder builder = new JobInfo.Builder(kJobId++, new ComponentName(this, MyJobDaemonService.class));
builder.setRequiredNetworkType(JobInfo.NETWORK_TYPE_NONE);
builder.setPersisted(true);
builder.setRequiresCharging(false);
builder.setRequiresDeviceIdle(false);
//间隔1000毫秒
builder.setPeriodic(1000);
return builder.build();
}

// 判断服务是否正在运行
public boolean isServiceWork(Context mContext, String serviceName) {
boolean isWork = false;
ActivityManager myAM = (ActivityManager) mContext
.getSystemService(Context.ACTIVITY_SERVICE);
List<ActivityManager.RunningServiceInfo> myList = myAM.getRunningServices(100);
if (myList.size() <= 0) {
return false;
}
for (int i = 0; i < myList.size(); i++) {
String mName = myList.get(i).service.getClassName().toString();
if (mName.equals(serviceName)) {
isWork = true;
break;
}
}
return isWork;
}

}

Mainfiest.xml中注册MyJobDeamonServcie

<service
android:name=".MyJobDaemonService"
android:enabled="true"
android:exported="true"
android:permission="android.permission.BIND_JOB_SERVICE" />这一个配置非常重要,不然一直会报权限问题.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  JobService JobScheduler