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双进程拉活.
通过binderService 两个service创建链接相互守护。保护进程中service思路一样。