點擊進入: 品牌服飾鞋包9.9元特價包郵搶購:http://shop109590806.taobao.com/
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)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);
- }
- }