当前位置: 移动技术网 > IT编程>移动开发>Android > Android 如何保证service在后台不被kill

Android 如何保证service在后台不被kill

2019年07月24日  | 移动技术网IT编程  | 我要评论

整风肃纪心得体会,工作鉴定,超能力恶作剧

android 其实无法做多绝对的不被后台kill掉,我们只能尽量使用一些操作提升不被kill的机会。

一、onstartcommand方法,返回start_sticky

  start_sticky 在运行onstartcommand后service进程被kill后,那将保留在开始状态,但是不保留那些传入的intent。不久后service就会再次尝试重新创建,因为保留在开始状态,在创建     service后将保证调用onstartcommand。如果没有传递任何开始命令给service,那将获取到null的intent。

  start_not_sticky 在运行onstartcommand后service进程被kill后,并且没有新的intent传递给它。service将移出开始状态,并且直到新的明显的方法(startservice)调用才重新创建。因为如果没有传递任何未决定的intent那么service是不会启动,也就是期间onstartcommand不会接收到任何null的intent。

  start_redeliver_intent 在运行onstartcommand后service进程被kill后,系统将会再次启动service,并传入最后一个intent给onstartcommand。直到调用stopself(int)才停止传递intent。如果在被kill后还有未处理好的intent,那被kill后服务还是会自动启动。因此onstartcommand不会接收到任何null的intent。 

二、提升service优先级      

  在androidmanifest.xml文件中对于intent-filter可以通过android:priority = "1000"这个属性设置最高优先级,1000是最高值,如果数字越小则优先级越低,同时适用于广播。

三、提升service进程优先级

  android中的进程是托管的,当系统进程空间紧张的时候,会依照优先级自动进行进程的回收。android将进程分为6个等级,它们按优先级顺序由高到低依次是:

   1.前台进程( foreground_app)

   2.可视进程(visible_app )

   3.次要服务进程(secondary_server )  

   4.后台进程 (hidden_app)

   5.内容供应节点(content_provider)

   6.空进程(empty_app)

当service运行在低内存的环境时,将会kill掉一些存在的进程。因此进程的优先级将会很重要,可以使用startforeground 将service放到前台状态。这样在低内存时被kill的几率会低一些。

四、ondestory里面发送广播重启service

service +broadcast  方式,就是当service走ondestory的时候,发送一个自定义的广播,当收到广播的时候,重新启动service;

五、application加上persistent属性

六、监听系统广播判断service状态

通过系统的一些广播,比如:手机重启、界面唤醒、应用状态改变等等监听并捕获到,然后判断我们的service是否还存活,别忘记加权限啊。

七、双进程service

让2个进程互相保护,其中一个service被清理后,另外没被清理的进程可以立即重启进程

八、联系厂商,加入白名单

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持移动技术网!

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网