Android SERVICE长驻内存的免杀处理
来源:互联网 发布:淘宝怎么去除同款 编辑:程序博客网 时间:2024/06/06 01:58
Service组件常用在网络,音乐播放等需要后台操作的程序中,在activity退出后,在后台,始终保持运行,负责完成播放歌曲,网络下载等操作。而当系统内存紧张时,anroid会关闭后台优先级低的进程,或者一些能清理内存的软件360,手机卫士等,也会结束优先级低的进程。如果不做Service的保持,就会被其杀掉。
在早些时候,我们可以通过在
1. service中重写onStartCommand方法,这个方法有三个返回值, START_STICKY是service被kill掉后自动
public int onStartCommand(Intent intent, int flags, int startId) {
return START_STICKY;
}
2. 配置android:persistent="true"
3. setForeground(true);
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里注册广播:
- IntentFilter filter = newIntentFilter(Intent.ACTION_TIME_TICK);
- MyBroadcastReceiver receiver = new MyBroadcastReceiver();
- registerReceiver(receiver, filter);
在广播接收器MyBroadcastReceiver extends BroadcastReceiver的onReceive里
- boolean isServiceRunning = false;
- if (intent.getAction().equals(Intent.ACTION_TIME_TICK)) {
- //检查Service状态
- ActivityManager manager = (ActivityManager)AppApplication.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);
- }
- }
注:
这个监听和重启在新版本中不起作用,一般情况下,我们应该监听来自系统的经常操作的广播来启动服务,比如wifi强度,信号强度广播,触屏事件等来启动服务,被杀后重启的代码可以放入下面中
@Override
public void onStart(Intent intent, int startId) {
// TODO Auto-generated method stub
startIntent = intent;
}
@Override
public void onDestroy() {
// TODO Auto-generated method stub
Log.i("jia, #####:", "AlarmServer, onDestroy");
if (startIntent != null) {
startService(startIntent);
}
}
- Android SERVICE长驻内存的免杀处理
- Android 处理ListView的长按时间
- <Android>长按事件的连续处理
- android service常驻内存的一点思考
- android service常驻内存的一点思考
- Android中Service的优先级的处理
- android 内存溢出的处理
- Android service 常驻内存
- Android Home 长按键处理
- 用android处理ListView的条目长按事件
- 【Android】Handler使用入门 处理耗时较长的程序
- 处理固定宽度下的长字符串绘制(Android)
- [Android]长按电源键(Power Key)的处理
- 处理固定宽度下的长字符串绘制(Android)
- 木马源代码免杀处理
- android-长按Home键,删除历史记录时,service的生命周期
- 浅谈Android内存泄漏&&实现杀不死的无界面后台Service
- 如何处理java相关网络协议占内存的问题啊?为何时间越长,内存占用越大?
- 文本编辑器的查询功能
- mysql字符串相加函数concat()
- Textview 里面文字加单词分隔符
- Binary Tree Zigzag Level Order Traversal
- 显著性论文学习阶段总结(一)
- Android SERVICE长驻内存的免杀处理
- Black Box+POJ+treap树模板
- 线性滤波之平滑滤波
- robotium测试工具使用之——输出log日志
- 显著性论文学习阶段总结(二)
- sizeof和strlen 比较经典
- Vision引擎中导入和导出高度图
- QQ通讯原理浅析
- Comparable与Comparator