如何保证Service不被第三方杀毒软件杀死

第一种方式

我们可以提升Service的优先级来防止被杀除,就是使用前台Service来实现(360就是这么做的)

第二种

我们可以通过监听广播的方式实现,就是我们定义一个广播接收器,在这个接收器里面监听一些系统广播(比如:Intent.ACTION_TIME_TICK,这个广播每分钟发送一次,),一旦收到这些广播之后,就去查看我们的服务Service有没有被启动,如果没有启动的话,则启动就可以了。

第三种

在Service的onDestroy方法中,调用startService进行Service的重启。

第四种

守护进程:守护进程一般在系统启动时开始运行,除非强行终止,否则直到系统关机都保持运行。

守护进程的三个特点:后台运行 独立于终端 完成一定任务

守护进程必须与运行前的环境隔离开来。环境包括以下几点:

1.在后台运行(这是为避免挂起控制终端将守护进程放入后台执行。方法是在进程中调用 fork() 使父进程终止, 让守护进行在子进程中后台执行。)

2.脱离控制终端、登录会话和进程组{进程属于一个进程组(进程组号和进程组长进程号)登录会话可以包含多个进程组。这些进程组共享一个控制终端。}

3. 改变当前工作目录(进程活动时,其工作目录所在的文件系统不能卸下。一般需要将工作目录改变到根目录。)

4.禁止进程重新打开控制终端(进程已经成为无终端的会话组长,重新申请打开一个控制终端。)

5.关闭打开的文件描述符 (进程从创建它的父进程那里继承了打开的文件描述符。)

守护进程实例包括两部分:主程序test.c和初始化程序init.c。主程序每隔一分钟向/tmp目录中的日志test.log报告运行状态。初始化程序中的init_daemon函数负责生成守护进程。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章