Service组件在android开发中常常遇到,其常常做为后台服务,须要始终保持运行,负责处理一些必要(见不得人)的任务。而一些安全软件,如360等,会有结束进程的功能,若是不作Service的保持,就会被其杀掉。
在早些时候,咱们能够经过在
1. service中重写onStartCommand方法,这个方法有三个返回值, START_STICKY是service被kill掉后自动
java
public int onStartCommand(Intent intent, int flags, int startId) {
android
return START_STICKY;
安全
}spa
2. 配置android:persistent="true"
3. setForeground(true);
4. android:process=”com.xxx.xxxservice”配置到单独的进程中
.net
以上的方法要么只是提高service优先级或者存活率, 并不能解决被安全软件强行杀死的问题.
orm
要么像第四种单独的进程运行service在360老的版本是能够的,可是在360的比较新的版本中仍然会被杀死.xml
如何保持Service的运行状态是如今要说明的,核心就是利用ANDROID的系统广播,触发本身的程序检查Service的运行状态,若是被杀掉,就再起来。
经常使用的有开机广播,解锁屏幕的广播,电量变化等等, 其中解屏的广播算比较频繁的了,可是也并不能保证必定的频率,尤为是在特定的时间里(好比用户睡觉的时候,用户并不进行解锁操做).而咱们仍要作一些操做的时候,就没有办法了.
blog
所以,我采用了一种别的方案. 另外再加上两个相似一守护进程的Service, 分别检查Service的运行状态,注册响应的广播,对其进行守护,一旦发现没有运行就将其启动.进程
我利用的系统广播是
Intent.ACTION_TIME_TICK,这个广播每分钟发送一次,咱们能够每分钟检查一次Service的运行状态,若是已经被结束了,就从新启动Service。
它的优势就是间隔时间短并且很是稳定, 而其余的广播并不能保证这一点,固然,在具体的应用中仍是要根据需求使用, 结合其余广播来保证本身的service必定会被重启.
开发
毕竟如今安全软件是愈来愈厉害了,更新得也是很是频繁. 有时间仍是要看下还有没有其余的方法,综合几种来使用.
下边就是具体的代码和注意事项了:
一、 Intent.ACTION_TIME_TICK的使用
咱们知道广播的注册有静态注册和动态注册,但此系统广播只能经过动态注册的方式使用。即你不能经过在manifest.xml里注册的方式接收到这个广播,只能在代码里经过
registerReceiver()方法注册。
在ThisApp extends Application 或者在service里注册广播:
[java] view plaincopy
IntentFilter filter = newIntentFilter(Intent.ACTION_TIME_TICK);
MyBroadcastReceiver receiver = new MyBroadcastReceiver();
registerReceiver(receiver, filter);
在广播接收器MyBroadcastReceiver extends BroadcastReceiver的onReceive里
[java] view plaincopy
boolean isServiceRunning = false;
if (intent.getAction().equals(Intent.ACTION_TIME_TICK)) {
//检查Service状态
ActivityManager manager = (ActivityManager)ThisApp.getContext().getSystemService(Context.ACTIVITY_SERVICE);
for (RunningServiceInfo service :manager.getRunningServices(Integer.MAX_VALUE)) {
if("so.xxxx.xxxxService".equals(service.service.getClassName()))
{
isServiceRunning = true;
}
}
if (!isServiceRunning) {
Intent i = new Intent(context, xxxService.class);
context.startService(i);
}
}