进程保活

1,除了微信这样的白名单大佬,没有app可以青春永驻
2,保活只能是使用一些歪门邪道来延长进程的持续时间
3,如果在原生的安卓系统去做,可能会好很多,但介于国内环境,只能尽力而为,有些机型可谓圣斗士一样
4,网上保活方案众多,不可能全部用上,分析使用
5,所谓保活是延长我们核心进程的寿命,比如推送,或者IM,推送其实各厂家做了很多的保活机制,多数为共享长链接,小米这种系统级别的不说,IM也一样,但我们其实也可以在他们的基础上想办法再做一层保活,像个推需要自己集成实现一个service.

研究一下市面上常见的保活方法

1.经典的一像素保活,据说QQ是这门干的(据说),很流氓,很有效,就是在锁屏和解锁的时候创建一个一个像素的Activity,这样做的目的是提升进程的优先级,不过有部分手机好像把解锁屏幕的广播给拿掉了
2.双进程守护,开俩个进程相互唤起,因为系统的进程回收机制是一个个回收的,利用这个时间差来相互唤起,当一个进程被磨灭掉,另一个马上重启,缺点是现在大部分机型只要一键清理就玩完了,不过也没有更好的办法,而且8.0之后对这个做了限制,想要在一个后再服务中启动另一个服务会报错,可以用startForegroundService方法,但是会有一个通知在通知栏,这就有点不太友好了,不过介于8.0以下手机还有很多,可以考虑
3.native进程(已报废)
4.JobIntentService,这个好多人不知道,其实就是之前JobService,利用系统的调度去开启一个服务,不过这个很简单,比JobService的使用简单多了,这个东西会在解锁屏幕,充电啊这一些动作的时候去重启执行里面的job,甚至手机重启,所以用它来总一些事情再核实不过了,不过它也是会被杀死的.
5.利用账号同步机制拉活,不过貌似被改了,失效了
6.在后台播放一个无声的音频,看起来很不错,不过总感觉该方案有点....
7.将service设置为前台进程,通2方法一样,会强制有个通知,可以考虑用innerService发送俩个id一样的通知,然后结束掉一个(8.0以后需要处理),该方法很好

下面介绍最后一种方法:

public class PushService extends Service {

    private int type = 0;
    private Object pushGetData = null;
    private static final int SERVICE_ID=1;
    
    private void keepLive(){
        if (Build.VERSION.SDK_INT<18){ //4.3版本
            startForeground(SERVICE_ID,new Notification());
        }else if (Build.VERSION.SDK_INT<26){
            startForeground(SERVICE_ID,new Notification());
            startService(new Intent(this,InnerService.class));
        }else {
            NotificationManager notificationManager= (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
            NotificationChannel notificationChannel=new NotificationChannel("channel","push",NotificationManager.IMPORTANCE_MIN);
            if (notificationManager!=null){
                notificationManager.createNotificationChannel(notificationChannel);
                Notification notification=new NotificationCompat.Builder(this,"channel").build();
                startForeground(SERVICE_ID,notification);
            }
        }
    }

上面介绍了各个版本的适配方式
-- 1:在4.3版本以下直接设置通知栏就行
--2:7.0版本会上面方法会弹出通知栏。因此需要给出如下方案。

innerService发送俩个id一样的通知,然后结束掉一个
 public static class InnerService extends Service{
        @Nullable
        @Override
        public IBinder onBind(Intent intent) {
            return null;
        }
        @Override
        public int onStartCommand(Intent intent, int flags, int startId) {
            startForeground(SERVICE_ID,new Notification());
            stopForeground(true);
            stopSelf();
            return super.onStartCommand(intent, flags, startId);
        }
    }

--3:在8.0开始弹框需要加渠道ID:

 NotificationManager notificationManager= (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
            NotificationChannel notificationChannel=new NotificationChannel("channel","push",NotificationManager.IMPORTANCE_MIN);
            if (notificationManager!=null){
                notificationManager.createNotificationChannel(notificationChannel);
                Notification notification=new NotificationCompat.Builder(this,"channel").build();
                startForeground(SERVICE_ID,notification);
            }
上面的做法虽然能做到进程保活,但是也还会存在进程被销毁,因为只是“保”,所以需要采用主动的方式:

主要的思路是:采用进程守护的方式,创建守护进程,在保护的进程销毁时通过aidl双进程拉活.


image.png

通过binderService 两个service创建链接相互守护。保护进程中service思路一样。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 如何进行进程保活,首先我们应该先分析一下进程被杀死的原因开始 Android进程被杀死的场景分析: 从 Andro...
    编程小猪阅读 8,977评论 1 14
  • 如何进行进程保活,首先我们应该先分析一下进程被杀死的原因开始 Android进程被杀死的场景分析: 从 Andro...
    如颖随行日记阅读 10,363评论 2 4
  • Android中的进程保活应该分为两个方面: 提高进程的优先级,减少被系统杀死的可能性 在进程已经被杀死的情况下,...
    sososeen09阅读 8,820评论 5 42
  • 公司产品最近提出恶劣的需求,让我们的app像微信一样永远不被杀掉,随时给用户最友好的体验,当时我想到的是根据手机壳...
    勤能不能补拙阅读 35,974评论 23 59
  • 柔花弱草爱悲秋, 秋意从来不必愁。 愁雨愁风愁叶落, 落看明月挂枝头。
    花屋主人萧寒阅读 3,047评论 0 3