如何讓service不被殺死
1.在service中重寫下麵的方法,這個方法有三個返回值, START_STICKY是service被kill掉後自動重寫創建@Override
public int onStartCommand(Intent intent, int flags, int startId) {
return START_STICKY;
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
flags = START_STICKY;
return super.onStartCommand(intent, flags, startId);
// return START_REDELIVER_INTENT;
}
2.在Service的onDestroy()中重啟Service.
public void onDestroy() {
Intent localIntent = new Intent();
localIntent.setClass(this, MyService.class); //銷毀時重新啟動Service
this.startService(localIntent);
}
用360殺掉進程的時候,調用的是係統自帶的強製kill功能(即settings裏的),在kill時,會將應用的整個進程停掉,當然包括service在內,如果在running裏將service強製kill掉,顯示進程還在。不管是kill整個進程還是隻kill掉進應用的 service,都不會重新啟動service。不知道你是怎麼怎麼實現重啟的,實在是不解
ps:在eclipse中,用stop按鈕kill掉進程的時候,倒是會重啟service
KILL問題:
1. settings 中stop service
onDestroy方法中,調用startService進行Service的重啟。
2.settings中force stop 應用
捕捉係統進行廣播(action為android.intent.action.PACKAGE_RESTARTED)
3. 借助第三方應用kill掉running task
提升service的優先級
-------------------------------->>
service開機啟動
今天我們主要來探討android怎麼讓一個service開機自動啟動功能的實現。Android手機在啟動的過程中會觸發一個Standard Broadcast Action,名字叫android.intent.action.BOOT_COMPLETED(記得隻會觸發一次呀),在這裏我們可以通過構建一個廣播接收者來接收這個這個action.下麵我就來簡單寫以下實現的步驟:
第一步:首先創建一個廣播接收者,重構其抽象方法 onReceive(Context context, Intent intent),在其中啟動你想要啟動的Service或app。
public class BootBroadcastReceiver extends BroadcastReceiver {
//重寫onReceive方法
@Override
public void onReceive(Context context, Intent intent) {
//後邊的XXX.class就是要啟動的服務
Intent service = new Intent(context,XXXclass);
context.startService(service);
Log.v("TAG", "開機自動服務自動啟動.....");
//啟動應用,參數為需要自動啟動的應用的包名
Intent intent = getPackageManager().getLaunchIntentForPackage(packageName);
context.startActivity(intent );
}
}
第二步:配置xml文件,在receiver接收這種添加intent-filter配置
<receiver android:name="BootBroadcastReceiver">
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED"></action>
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</receiver>
第三步:添加權限 <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
---------------------------------------------------
如何實現一個不會被殺死的進程
看Android的文檔知道,當進程長期不活動,或係統需要資源時,會自動清理門戶,殺死一些Service,和不可見的Activity等所在的進程。
但是如果某個進程不想被殺死(如數據緩存進程,或狀態監控進程,或遠程服務進程),應該怎麼做,才能使進程不被殺死。
add android:persistent="true" into the <application> section in your AndroidManifest.xml
切記,這個不可濫用,係統中用這個的service,app一多,整個係統就完蛋了。
------------------------------------------------
提升service優先級的方法
Android 係統對於內存管理有自己的一套方法,為了保障係統有序穩定的運信,係統內部會自動分配,控製程序的內存使用。當係統覺得當前的資源非常有限的時候,為了保 證一些優先級高的程序能運行,就會殺掉一些他認為不重要的程序或者服務來釋放內存。這樣就能保證真正對用戶有用的程序仍然再運行。如果你的 Service 碰上了這種情況,多半會先被殺掉。但如果你增加 Service 的優先級就能讓他多留一會,我們可以用 setForeground(true) 來設置 Service 的優先級。
為什麼是 foreground ? 默認啟動的 Service 是被標記為 background,當前運行的 Activity 一般被標記為 foreground,也就是說你給 Service 設置了 foreground 那麼他就和正在運行的 Activity 類似優先級得到了一定的提高。當讓這並不能保證你得 Service 永遠不被殺掉,隻是提高了他的優先級。
從Android 1.5開始,一個已啟動的service可以調用startForeground(int, Notification)將service置為foreground狀態,調用stopForeground(boolean)將service置為 background狀態。
我們會在調用startForeground(int, Notification)傳入參數notification,它會在狀態欄裏顯示正在進行的foreground service。background service不會在狀態欄裏顯示。
在Android 1.0中,將一個service置為foreground狀態:
setForeground(true);
mNM.notify(id, notification);
將一個service置為background狀態:
mNM.cancel(id);
setForeground(false);
對比看出,在1.0 API中調用setForeground(boolean)隻是簡單的改變service的狀態,用戶不會有任何覺察。新API中強製將 notification和改變service狀態的動作綁定起來,foreground service會在狀態欄顯示,而background service不會。
Remote service controller & binding
跨進程調用Service。暫時不研究。
-------------------------------------------------------
如何防止Android應用中的Service被係統回收?
對於Service被係統回收,一般做法是通過提高優先級可以解決,在AndroidManifest.xml文件中對於intent-filter可以通過android:priority = "1000"這個屬性設置最高優先級,1000是最高值,如果數字越小則優先級越低,同時實用於廣播,推薦大家如果你的應用很重要,可以考慮通過係統常用intent action來觸發。(轉
最後更新:2017-04-03 12:55:06
上一篇:
SQL Server 2008 R2用戶'sa'登錄失敗(錯誤18456)
下一篇:
用戶 'sa' 登錄失敗。原因: 該帳戶被禁用。 (Microsoft SQL Server,錯誤: 18470)
8月18日雲棲精選夜讀:阿裏視頻雲最強轉碼技術揭秘:窄帶高清原理解析+用戶接入指南
OSS細粒度的權限控製
POJ-3262-Protecting the Flowers
像黑客一樣思考問題
iOS導航BarButtonItem文字或者圖片與屏幕邊界的間隔調整方法
Login控件:用戶登錄失敗的消息提示
跟蹤oracle中sql語句執行過程及相關知識拓展
java.lang.ClassCastException:org.apache.catalina.util.DefaultAnnotationProcessor cannot be cast to org.apache.AnnotationProcesso
cf 168 k-Multiple Free Set bin_search
麵對前端六年曆史代碼,如何接入並應用ES6解放開發效率