筆者上篇做了一個定時提醒的小應用,但是最后遺留了一個問題,那就是如果設置提醒的間隔時間過長,那么計時的service便會被android系統kill掉。(主要是由于android自帶內存清理)
在進行了大量的查閱和測試后,筆者終于解決了該問題:
當然,在此也要稍微提一下,筆者只測試了,在以一小時為左右的時間內可以不被殺死,還沒有測試2個小時以上的情況,更沒有測試以天為單位的時間,具體測試如下:(item右下角是程序執行的時間)

??
好了,進入正題,如何解決service會被kill的情況呢?
那就是設置**前臺服務**,那什么是前臺服務呢?
如果你希望服務可以一直保持運行狀態,而不會由于系統內存不足的原因導致被回收,就可以考慮使用前臺服務。前臺服務和普通服務最大的區別就在于,它會一直有一個正在運行的圖標在系統的狀態欄顯示,下拉狀態欄后可以看到更加詳細的信息,非常類似于通知的效果。
接下來就以墨跡天氣為例,如下圖:

大家有沒有想過,墨跡天氣是如何能夠在后臺不斷更新通知欄的中天氣,并且不被kill掉的呢?
沒錯,就是用到了**前臺服務**。好了,接下來就講一下具體怎么使用。
首先看一下整個Service的代碼:
~~~
public class LongRunningService extends Service {
@Override
public IBinder onBind(Intent intent) {
return null;
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
//啟用前臺服務,主要是startForeground()
Notification notification = new Notification(R.drawable.queen2, "用電腦時間過長了!白癡!"
, System.currentTimeMillis());
notification.setLatestEventInfo(this, "快去休息!!!",
"一定保護眼睛,不然遺傳給孩子,老婆跟別人跑啊。", null);
//設置通知默認效果
notification.flags = Notification.FLAG_SHOW_LIGHTS;
startForeground(1, notification);
AlarmManager manager = (AlarmManager) getSystemService(ALARM_SERVICE);
//讀者可以修改此處的Minutes從而改變提醒間隔時間
//此處是設置每隔55分鐘啟動一次
//這是55分鐘的毫秒數
int Minutes = 55 * 60 * 1000;
//SystemClock.elapsedRealtime()表示1970年1月1日0點至今所經歷的時間
long triggerAtTime = SystemClock.elapsedRealtime() + Minutes;
//此處設置開啟AlarmReceiver這個Service
Intent i = new Intent(this, AlarmReceiver.class);
PendingIntent pi = PendingIntent.getBroadcast(this, 0, i, 0);
//ELAPSED_REALTIME_WAKEUP表示讓定時任務的出發時間從系統開機算起,并且會喚醒CPU。
manager.set(AlarmManager.ELAPSED_REALTIME_WAKEUP, triggerAtTime, pi);
return super.onStartCommand(intent, flags, startId);
}
@Override
public void onDestroy() {
super.onDestroy();
//在Service結束后關閉AlarmManager
AlarmManager manager = (AlarmManager) getSystemService(ALARM_SERVICE);
Intent i = new Intent(this, AlarmReceiver.class);
PendingIntent pi = PendingIntent.getBroadcast(this, 0, i, 0);
manager.cancel(pi);
}
}
~~~
在筆者的代碼中,最核心的部分如下:
~~~
//啟用前臺服務,主要是startForeground()
Notification notification = new Notification(R.drawable.queen2, "用電腦時間過長了!白癡!"
, System.currentTimeMillis());
notification.setLatestEventInfo(this, "快去休息!!!",
"一定保護眼睛,不然遺傳給孩子,老婆跟別人跑啊。", null);
//設置通知默認效果
notification.flags = Notification.FLAG_SHOW_LIGHTS;
startForeground(1, notification);
~~~
此處和通知的使用特別像,但是并沒有使用NotificationManager來講通知顯示出來,而是調用了startForeground()方法。調用startForeground()方法后就會讓這個Service(在筆者的代碼中是LongRunningService)變成一個前臺服務了,并且會在系統狀態欄顯示出來。
可能有部分讀者還是不太明白,那么便由筆者再仔細說一下。
在筆者的代碼中,除了筆者所說的核心部分外,筆者主要實現了后臺計時的功能。倘若筆者不使用前臺服務,那么后臺計時的服務很可能在運行了幾十分鐘甚至幾分鐘的時候就被android系統給回收了。
在設置前臺服務后,LongRunningService這個服務成為了前臺服務,那么其中實現的功能也是會被系統當做了前臺任務運行,并且不會回收,于是便能一直運行了。
當然此方法也是需要慎用,倘若使用了,便會存在android系統不會去自動殺死的一個服務,如果該服務在一直執行,那么手機內存占用和手機耗電量都會自然增加,說不定也會降低用戶體驗哦。
- 前言
- android SharedPreference的簡單使用(登陸界面記住密碼)
- android 通知Notification的使用小實例(振動,燈光,聲音)
- android調用攝像頭拍照,從相冊中選擇照片并裁剪
- android從相冊中獲取圖片出錯,圖片無法裁剪的問題
- android 后臺定時提醒(Service,AlarmManager的使用)
- android如何讓后臺服務service不被殺死(設置前臺服務)
- android修改控件外觀(使用drawable資源)
- android 自定義view的使用(最佳demo——返回標題欄)
- android viewpager+fragment做主界面(超容易理解的demo!)
- Fragment生命周期
- Android DrawerLayout 高仿QQ5.2雙向側滑菜單
- Android DrawerLayout側滑菜單+nineoldandroids動畫
- Android 通知欄Notification的整合 全面學習 (一個DEMO讓你完全了解它)
- Android應用開發-護眼提醒-總結篇