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以后新增的一个服务,我们先来看下官方的解释。
![](https://oscdn.geek-share.com/Uploads/Images/Content/202009/03/b74dfd83751b09b2b6266e8adb398813)
Google从Android SDK 21之后添加了JobScheduler来执行一些满足特定条件但不紧急的后台任务,我们可以利用JobScheduler来执行这些特殊的后台任务时来减少电量的消耗。JobService则是一个抽象类,其中包含两个抽象方法:
2
3
4
![](https://oscdn.geek-share.com/Uploads/Images/Content/201701/9cc493f1e15b23d0f4eaea0d0f8b35d0.png)
1
2
3
4
当我们有以下需求时,可以使用调度作业
APP有可以推迟的非面向用户的工作
APP有当插入设备时您希望优先执行的工作
APP有需要访问网络或 Wi-Fi 连接的任务
APP有希望作为一个批次定期运行的许多任务
接下来,我们使用JobService来实现APP进程防杀。
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" />这一个配置非常重要,不然一直会报权限问题.
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
![](https://oscdn.geek-share.com/Uploads/Images/Content/201701/9cc493f1e15b23d0f4eaea0d0f8b35d0.png)
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机制在Android5.0以上保活
- JobService和JobScheduler机制在Android5.0以上保活
- JobService和JobScheduler机制在Android5.0以上保活
- JobService 和 JobScheduler Android5.0以上的进程保活
- (4.6.17.6)进程保活(Android的5.0分界线):Android5.0以上版本的force close到底发生了什么改变?
- Android5.0中Binder机制相关的native层的Parcel分析
- Android异常-android5.0以上网络请求失败-retry error, curr request is null
- Android5.0以上实现对手机屏幕录制并将视频实时保存到本地(亦可实时传输)
- 32位ubuntu物理地址扩展(PAE)分页机制及如何开启PAE支持4G以上内存(有时grub里面会让你选择)
- JobScheduler和JobService机制保活进程
- Android5.0以上Button去除阴影
- android5.0以上手机host修改教程
- Android5.0以上版本对比
- android之Jobscheduler运行机制详解
- ViewPager禁止滑动(兼容Android5.0以上)
- Android5.0以上版本ActiveAndroid报ClassNotFoundException错误
- Android5.0以上的状态栏透明和沉浸式模式兼容底部导航栏与界面重复
- Android5.0以上蓝牙能够加载数据 5.0以下加载不了数据
- 绕过android 5.0以上的pie机制