Android SERVICE后台服务进程的自启动和保持
来源:互联网 发布:郑州java培训班 编辑:程序博客网 时间:2024/06/06 04:58
Service组件在android开发中经常遇到,其经常作为后台服务,需要始终保持运行,负责处理一些必要(见不得人)的任务。而一些安全软件,如360等,会有结束进程的功能,如果不做Service的保持,就会被其杀掉。
1. service中重写onStartCommand方法,这个方法有三个返回值, START_STICKY是service被kill掉后自动
3.setForeground(true);
4. android:process=”com.xxx.xxxservice”配置到单独的进程中
如何保持Service的运行状态是现在要说明的,核心就是利用ANDROID的系统广播,触发自己的程序检查Service的运行状态,如果被杀掉,就再起来。
常用的有开机广播,解锁屏幕的广播,电量变化等等, 其中解屏的广播算比较频繁的了,但是也并不能保证一定的频率,尤其是在特定的时间里(比如用户睡觉的时候,用户并不进行解锁操作).而我们仍要做一些操作的时候,就没有办法了.
我利用的系统广播是
Intent.ACTION_TIME_TICK,这个广播每分钟发送一次,我们可以每分钟检查一次Service的运行状态,如果已经被结束了,就重新启动Service。
它的优点就是间隔时间短而且非常稳定, 而其他的广播并不能保证这一点,当然,在具体的应用中还是要根据需求使用, 结合其他广播来保证自己的service一定会被重启.
1、 Intent.ACTION_TIME_TICK的使用
我们知道广播的注册有静态注册和动态注册,但此系统广播只能通过动态注册的方式使用。即你不能通过在manifest.xml里注册的方式接收到这个广播,只能在代码里通过
registerReceiver()方法注册。
在ThisApp extends Application 或者在service里注册广播:
在广播接收器MyBroadcastReceiver extends BroadcastReceiver的onReceive里
点击进入: 品牌服饰鞋包9.9元特价包邮抢购:http://shop109590806.taobao.com/
1. service中重写onStartCommand方法,这个方法有三个返回值, START_STICKY是service被kill掉后自动
public int onStartCommand(Intent intent, int flags, int
return START_STICKY;
}
2. 配置android:persistent="true"3.
4. android:process=”com.xxx.xxxservice”配置到单独的进程中
以上的方法要么只是提升service优先级或者存活率, 并不能解决被安全软件强行杀死的问题.
要么像第四种单独的进程运行service在360老的版本是可以的,但是在360的比较新的版本中仍然会被杀死.
如何保持Service的运行状态是现在要说明的,核心就是利用ANDROID的系统广播,触发自己的程序检查Service的运行状态,如果被杀掉,就再起来。
常用的有开机广播,解锁屏幕的广播,电量变化等等, 其中解屏的广播算比较频繁的了,但是也并不能保证一定的频率,尤其是在特定的时间里(比如用户睡觉的时候,用户并不进行解锁操作).而我们仍要做一些操作的时候,就没有办法了.
因此,我采用了一种别的方案. 另外再加上两个类似一守护进程的Service, 分别检查Service的运行状态,注册响应的广播,对其进行守护,一旦发现没有运行就将其启动.
我利用的系统广播是
Intent.ACTION_TIME_TICK,这个广播每分钟发送一次,我们可以每分钟检查一次Service的运行状态,如果已经被结束了,就重新启动Service。
它的优点就是间隔时间短而且非常稳定, 而其他的广播并不能保证这一点,当然,在具体的应用中还是要根据需求使用, 结合其他广播来保证自己的service一定会被重启.
毕竟现在安全软件是越来越厉害了,更新得也是非常频繁. 有时间还是要看下还有没有其他的方法,综合几种来使用.
1、 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, class);xxxService. -
context.startService(i); -
} -
-
- }
0 0
- Android SERVICE后台服务进程的自启动和保持
- Android SERVICE后台服务进程的自启动和保持
- Android SERVICE后台服务进程的自启动和保持
- android service后台服务进程的自启动和保持
- Android SERVICE后台服务进程的自启动和保持
- Android SERVICE后台服务进程的自启动和保持
- Android SERVICE后台服务进程的自启动和保持
- -------------------Android SERVICE后台服务进程的自启动和保持
- Android SERVICE后台服务进程的自启动和保持
- Android SERVICE后台服务进程的自启动和保持
- Android SERVICE后台服务进程的自启动和保持
- Android SERVICE后台服务进程的自启动和保持
- Android Service后台服务进程的自启动和保持
- Android SERVICE后台服务进程的自启动和保持
- Android SERVICE后台服务进程的自启动和保持
- Android SERVICE后台服务进程的自启动和保持
- SERVICE后台服务进程的自启动和保持
- SERVICE后台服务进程的自启动和保持
- php事务处理.php
- Debug模式下链接release下的lib文件
- p1774机器翻译
- 第20条:类层次优于标签类
- oracle 解除表锁定
- Android SERVICE后台服务进程的自启动和保持
- gedit 报警告
- panel组件href方式脚本的执行顺序
- iOS调试技巧---查看View的层次结构 [view recursiveDescription]
- websphere下面报webapp.WebApp logError SRVE0293E 错误
- 海康威视2014校园宣讲招聘c/c++笔试题(浙工大)
- 《TCP/IP详解卷1:协议》--特殊情况的IP地址
- 函数指针变量与指针型函数区别
- 第三方网站响应时间和浏览器兼容性测试