android 让service不被杀死-------------提高程序优先级

1.在service中重寫下面的方法,這個方法有三個返回值, START_STICKY是service被kill掉後自動重寫建立 
[代碼]java代碼: 
@Override 
public int onStartCommand(Intent intent, int flags, int startId) { 
return START_STICKY; 
}---------------- 
@Override 
public int onStartCommand(Intent intent, int flags, int startId) { 
// TODO Auto-generated method stub 
Log.v("TrafficService","startCommand"); 




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); 





用qq管家殺掉程序的時候,調用的是系統自帶的強制kill功能(即settings裡的),在kill時,會將應用的整個程序停掉,當然包括service在內,如果在running裡將service強制kill掉,顯示程序還在。不管是kill整個程序還是只kill掉進應用的 service,都不會重新啟動service。不知道你是怎麼實現重啟的,實在是不解。 在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。 
[代碼]java代碼: 
import android.content.BroadcastReceiver;  
import android.content.Context;  
import android.content.Intent;  
import android.util.Log;  




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檔案,在re 
ceiver接收這種新增intent-filter配置  
[代碼]java代碼: 
<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一多,整個系統就完蛋了。 
目前系統中有phone等非常有限的,必須一直活著的應用在試用。 
提升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被系統回收? 很多朋友都在問,如何防止Android應用中的Service被系統回收?下面簡單解答一下。 
對於Service被系統回收,一般做法是通過提高優先級可以解決,在AndroidManifest.xml檔案中對於intent-filter可以通過 android:priority = "1000"這個屬性設定最高優先級,1000是最高值,如果數字越小則優先級越低,同時實用於廣播,推薦大家如果你的應用很重要,可以考慮通過系統常用intent action來觸發。




下面這是從另外的網頁上看到的,一併轉過來了


為了提高 我們的Activity中的線程的
線程優先級(Thread-Priority),我們需要在AndroidManifest.xml 中使用 'uses-permission' 這樣做:
XML: 
          <uses-permission id="android.permission.RAISED_THREAD_PRIORITY"/>


  現在你可以在你的Activity中使用以下代碼改變或提高任何線程的優先級:
Java: 
          import android.os.Process;
// ...


// -----------------------------------
// Set the priority of the calling thread, based on Linux priorities:
// -----------------------------------


// Changes the Priority of the calling Thread!
Process.setThreadPriority(12);
// Changes the Priority of passed Thread (first param)
Process.setThreadPriority(Process.myTid(), 12);


  這裡 range 的範圍是 -20 (高) 到 +19 (低). 不要選得 太高  


  最好使用預先定義在 android.os.Process 的constants :
Java: 
          // Lower is 'more impotant'
Process.THREAD_PRIORITY_LOWEST = 19
Process.THREAD_PRIORITY_BACKGROUND = 5
Process.THREAD_PRIORITY_DEFAULT = 0
Process.THREAD_PRIORITY_FOREGROUND = -5
Process.THREAD_PRIORITY_DISPLAY = -10
Process.THREAD_PRIORITY_URGENT_DISPLAY = -15
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值