进程保活一直是广大APP开发者所希望的,因为进程活着我们就可以操作很多事情(推送,数据同步等等),但是google大大是不允许这样做的(优化),所以我们要另辟蹊径。

  1. 先来看看android中有几种进程吧。
    • 前台进程:Foreground process

      • 用户正在交互的Activity(onResume())
      • 当某个Service绑定正在交互的Activity。
      • 被主动调用为前台Service(startForeground())
      • 组件正在执行生命周期的回调(onCreate()/onStart()/onDestroy())
      • BroadcastReceiver 正在执行onReceive();

    • 可见进程:Visible process
      • 我们的Activity处在onPause()(没有进入onStop())
      • 绑定到前台Activity的Service。
    • 服务进程:Service process
      • 简单的startService()启动。
    • 后台进程:Background process
      • 对用户没有直接影响的进程----Activity出于onStop()的时候。
        android:process=":xxx"

    • 空进程:Empty process
      • 不含有任何的活动的组件。(android设计的,为了第二次启动更快,采取的一个权衡)

  2、通常我们启动的都是一个服务进程,要么直接 startService() 要么 bindService(),我们可能需要在这些服务进程里面做一些事情,但这些事情并不是说我们现在要做的,可能是将来要做的,或者是在某个时间条件下要做的,这时候我们就需要我们的service保持活动状态。

  3、JobService 可以算是一个 JobScheduler 的回调服务。JobScheduler是一个系统级的作业调度器,我们将某些任务扔给系统,当达到我们设定的条件以后,JobScheduler再吊起我们的JobService执行我们的业务逻辑。

  4、接下来看看我们如何实现。(我就直接上代码了)

    • @SuppressLint("NewApi")
      public class JobHandleService extends JobService {
      private int kJobId = 0; @Override
      public void onCreate() {
      super.onCreate();
      Log.i("INFO", "jobService create");
      } @Override
      public int onStartCommand(Intent intent, int flags, int startId) {
      Log.i("INFO", "jobService start");
      // 在服务启动时,直接将任务推到JobScheduler 的任务队列,然后在设定的时间条件到达时,便会直接吊起我们的服务,走onStartJob()方法
      scheduleJob(getJobInfo());
      return START_NOT_STICKY;
      } @Override
      public void onDestroy() {
      super.onDestroy();
      } @Override
      public boolean onStartJob(JobParameters params) {
      // params.getExtras()
      // scheduleJob(getJobInfo());
      boolean isLocalServiceWork = isServiceWork(this, "com.xxx.XxxService");
      boolean isRemoteServiceWork = isServiceWork(this, "com.xxx.XxxService"); if (!isLocalServiceWork || !isRemoteServiceWork) {
      this.startService(new Intent(this, LocalService.class));
      this.startService(new Intent(this, RemoteService.class));
      Toast.makeText(this, "process start", Toast.LENGTH_SHORT).show();
      }
      return true;
      } @Override
      public boolean onStopJob(JobParameters params) {
      Log.i("INFO", "job stop");
      // 当执行完毕时,我们再将任务加入到 JobScheduler 里面就可以了。
      scheduleJob(getJobInfo());
      return true;
      } /**
      * Send job to the JobScheduler.
      */
      public void scheduleJob(JobInfo t) {
      Log.i("INFO", "Scheduling job");
      JobScheduler tm = (JobScheduler) getSystemService(Context.JOB_SCHEDULER_SERVICE);
      if (tm != null) {
      tm.schedule(t);
      }
      } public JobInfo getJobInfo() {
      JobInfo.Builder builder = new JobInfo.Builder(kJobId++, new ComponentName(this, JobHandleService.class));
      builder.setRequiredNetworkType(JobInfo.NETWORK_TYPE_ANY);
      builder.setPersisted(true);
      builder.setRequiresCharging(false);
      builder.setRequiresDeviceIdle(false);
      builder.setPeriodic(10);//间隔时间--周期
      return builder.build();
      } /**
      * 判断某个服务是否正在运行的方法
      *
      * @param mContext
      * @param serviceName 是包名+服务的类名(例如:net.loonggg.testbackstage.TestService)
      * @return true代表正在运行,false代表服务没有正在运行
      */
      public boolean isServiceWork(Context mContext, String serviceName) {
      boolean isWork = false;
      ActivityManager myAM = (ActivityManager) mContext.getSystemService(Context.ACTIVITY_SERVICE);
      List<RunningServiceInfo> myList = null;
      if (myAM != null) {
      myList = myAM.getRunningServices(100);
      }
      if (myList != null && myList.size() <= 0) {
      return false;
      }
      if (myList != null) {
      for (int i = 0; i < myList.size(); i++) {
      String mName = myList.get(i).service.getClassName();
      if (mName.equals(serviceName)) {
      isWork = true;
      break;
      }
      }
      }
      return isWork;
      }
      }

我这里就是简单的示范一下,具体我们项目里面的实现并没有发到上面,各位可以自己琢磨。

Android--使用JobService实现进程保活的更多相关文章

  1. JobScheduler布置后台任务以及实现进程保活?

    1.简介 在Android 5.0 提供了一套新的 JobScheduler API,它允许您定义要在以后的某个时间或在指定的条件下(例如,当设备在充电时)异步运行的作业来优化电池寿命. https: ...

  2. Android进程保活

    Android进程回收机制 Low Memory Killer原理 微信团队原创分享:Android版微信后台保活实战分享(网络保活篇) 微信团队原创分享:Android版微信后台保活实战分享(进程保 ...

  3. 转: android app进程保活的文章列表

    1. Android 后台任务型App多进程架构演化 http://www.jianshu.com/p/4ac1f373e8cd 2. 关于 Android 进程保活,你所需要知道的一切 http:/ ...

  4. 关于 Android 进程保活,你所需要知道的一切

    早前,我在知乎上回答了这样一个问题:怎么让 Android 程序一直后台运行,像 QQ 一样不被杀死?.关于 Android 平台的进程保活这一块,想必是所有 Android 开发者瞩目的内容之一.你 ...

  5. Android记一次后台保活设计心得2018

    首先我并不推荐也不喜欢手机应用通过各种手段后台保活,但是当产品经理确定一定以及肯定地提出了这个需求,活着应用有着必须常驻后台的理由,也就只有硬着头皮去与各个手机的后台管理机制做斗争了. 背景:因为开发 ...

  6. Android中的跨进程调用技术AIDL

    什么是AIDL Android系统中的进程之间不能共享内存,因此,需要提供一些机制在不同进程之间进行数据通信. 为了使其他的应用程序也可以访问本应用程序提供的服务,Android系统采用了远程过程调用 ...

  7. Android系统在新进程中启动自定义服务过程(startService)的原理分析

    在编写Android应用程序时,我们一般将一些计算型的逻辑放在一个独立的进程来处理,这样主进程仍然可以流畅地响应界面事件,提高用户体验.Android系统为我们提供了一个Service类,我们可以实现 ...

  8. Google Android官方文档进程与线程(Processes and Threads)翻译

    android的多线程在开发中已经有使用过了,想再系统地学习一下,找到了android的官方文档,介绍进程与线程的介绍,试着翻译一下. 原文地址:http://developer.android.co ...

  9. 内存不足时Android 系统如何Kill进程

    [转]内存不足时Android 系统如何Kill进程 大家其实都或多或少知道,Android系统有自已的任务管理器,当系统内存不足时,系统需要KILL一些进程(应用),以回收一部分资源,来保证系统仍可 ...

随机推荐

  1. 阿里云申请ssl证书

    申请证书(本文以阿里云服务器为背景,申请证书也以阿里云域名申请证书来作为实例) (1)登陆阿里云服务器,初次配置的用户,不建议直接搜索‘ssl证书’进行购买,因为这样购买后证书与域名对应的引导性并不强 ...

  2. c# 导入导出excel方法封装

    在很多项目中,都会使用到文件的上传下载等,为了方便,封装了一个帮助类,每次直接拿过来使用就可以了,下面是封装的类和使用方法. using Common.AttributeHelper; using N ...

  3. Lombok的@Data、@Setter、@Getter注解没反应问题解决

    在用@Data注解时,没有生成setter/getter方法.百度了一堆都没解决方法,后来用Google查了一下解决了~~~ 使用IDEA需要安装Lombok插件,我这里已经下载好,如果没下载安装点击 ...

  4. 面试题:两种方法计算n!

    直接上代码package com.face.test; public class Test { /** * 面试题:递归方法计算n! */ @org.junit.Test public void di ...

  5. 使用EF+ASP.NET MVC+Bootstrap开发一个功能强大的问卷调查系统

    功能简介 支持七大题型 下拉选择题.单选题.多选题.填空题.数字题.问答题.组合/矩阵题(单选组合.多选组合.填空组合.数字组合) 题库支持 每个问卷都要设置姓名.年龄.性别.学历,怎么办?题库帮您轻 ...

  6. 课程回顾-Neural Network & Deep Learning

    为什么深度学习发展了数据计算算法发展Logistics RegressionNumpyreshape的计算代价很小,所以你不确定数据维度的时候都可以放上一些解决潜在bug的trick做了归一化之后梯度 ...

  7. sql server 锁与事务拨云见日(下)

    在锁与事务系列里已经写完了上篇中篇,这次写完下篇.这个系列俺自认为是有条不紊的进行,但感觉锁与事务还是有多很细节没有讲到,温故而知新可以为师矣,也算是一次自我提高总结吧,也谢谢大伙的支持.在上一篇的末 ...

  8. 微信小程序注册60s倒计时功能 使用JS实现注册60s倒计时功能

    微信小程序+WEB使用JS实现注册[60s]倒计时功能开发步骤: 1.wxml页面代码: <text>绑定手机</text> <form bindsubmit=" ...

  9. shell 脚本实现文件对称加密

    前言 之前手机里管理密码的脚本,都是直接编写进纯文本然后进行多次归档及压缩来实现不明文存储,一直觉得不太安全,于是昨天晚上编写脚本实现了简单的文件对称加密. 网上文章都利用 openssl 来进行文件 ...

  10. python 闯关之路四(下)(并发编程与数据库编程)

    并发编程重点: 并发编程:线程.进程.队列.IO多路模型 操作系统工作原理介绍.线程.进程演化史.特点.区别.互斥锁.信号. 事件.join.GIL.进程间通信.管道.队列. 生产者消息者模型.异步模 ...