对于保活目前的需求:
对于很多场景用户都需要应用在后台长时间的运行,但是Android系统会存在杀后台进程的情况,并且随着系统版本的更新,杀进程的力度还有越来越大的趋势,系统这种做法本身出发点是好的,因为可以节省内存,降低功耗,也避免了一些流氓行为。当遇到需要在后台运行的场景,用户也是愿意让它在后台运行的,比如跑步类应用,硬件长连类应用等。一方面流氓软件用各种流氓手段进行保活,另一方面系统加大杀后台的力度,导致我们一些真正需要在后台运行的应用被误杀,苦不堪言。
如何做到优雅保活呢?
为了做到保活,出现了不少的【黑科技】,比如一个像素的Activity,播放无声音频,双进程互相守护等,这些做法可以说是很流氓了,甚至破坏了Android的生态,好在随着Android系统版本的更新,这些非常规的保活手段很多都已失效了。
对于那些确实需要在后台运行的应用,我们如何去做呢?
后台运行白名单
从Android 6.0开始,系统为了省电增加了休眠模式,系统待机一段时间后,会杀死后台正在运行的进程,但系统会有一个后台运行白名单,白名单里的应用将不会受到影响,在原声系统下,通过【设置】->【电池】->【电池优化】->【未优化应用】,可以看到这个白名单,通常会看到下面这两位:

当被别人问起别的产品都能保活,为什么我们的不行的时候,你就知道怎么怼回去了,大厂通过和手机厂商的合作,将自己的应用默认加入到白名单中,如果你在一个能谈成这种合作的大厂,也就不用做什么处理了。但对于一般的小公司怎么处理呢?
好在系统还没有抛弃我们,允许我们申请把应用加入白名单。那么怎么操作呢?
1.首先,在AndroidManifest.xml 文件中配置一下权限:

2.可以通过以下方法判断应用是否在白名单中

如果不在白名单中,可以通过一下代码申请加入白名单:

申请时会出现下面的弹窗:

可以看到,这个系统弹窗会有影响电池的续航提醒,所以如果想让用户点允许,必须进行相关的说明,如果要判断用户是否点击了允许,可以在申请的时候调用startActivityForResult , 在onActivityResult 里再判断一次是否在白名单中。
厂商后台管理
Android开发的一个难点在于,各个手机厂商对原生系统进行了不同的定制,导致我们需要进行不同的适配,后台管理就是一个很好的体现,几乎各个厂都有自己的后台管理,就算加入了后台运行白名单,仍然可能会被厂商自己的后台管理干掉。
如果能把应用加入厂商的后台管理白名单,可以进一步降低进程被杀的概率,不同的厂商在不同的地方进行设置,一般是在各自的【手机管家】,但更难的是,就算同一个厂商的系统,不同的版本也可能是在不同的地方设置。
最理想的做法是,我们根据不同的手机,甚至不同的系统版本,给用户呈现一个图文操作步骤,并且提供一个按钮,直接跳转到指定的页面进行设置,但需要对每个厂商每个版本进行适配,工作量较大,下面我已小米4C为例子进行描述,其它厂商参考相关专业文档。

运行结果如下图:

一般当你选择无限制,手机出现熄屏后就不会出现后台杀进程现象,亲测有效。具体可参考GitHub - liuxinggithub/baohuo: 优雅保活
其它厂商的处理可参考https://www.cnblogs.com/Android-Alvin/p/12465949.html 仅作为个人学习总结之用,有借鉴网络文章,若有版权问题请联系删除。
网友评论