在Android的AlarmManager中,AlarmManager可以用來實(shí)現(xiàn)定時(shí)任務(wù),今天武林技術(shù)頻道小編在這里為大家?guī)鞟ndroid開發(fā)之AlarmManager的用法詳解,希望對你學(xué)習(xí)這方面知識(shí)有幫助。
一、概述:
該類提供一種訪問系統(tǒng)鬧鐘服務(wù)的方式,允許你去設(shè)置在將來的某個(gè)時(shí)間點(diǎn)去執(zhí)行你的應(yīng)用程序。當(dāng)你的鬧鐘響起(時(shí)間到)時(shí),在它上面注冊的一個(gè)意圖(Intent)將會(huì)被系統(tǒng)以廣播發(fā)出,然后自動(dòng)啟動(dòng)目標(biāo)程序,如果它沒有正在運(yùn)行。注冊的鬧鐘會(huì)被保留即使設(shè)備處于休眠中(如果鬧鐘在給定時(shí)間響起可以選擇是否喚醒設(shè)備)。如果鬧鐘關(guān)閉或者重啟,鬧鐘將被清除。
只要廣播的onReceive()方法正在執(zhí)行,這鬧鐘管理者(AlarmManager)會(huì)持有一個(gè)CPU喚醒鎖,這是為了保證手機(jī)不會(huì)休眠直到處理完該廣播,一旦onReceive()返回,那么鬧鐘管理者將會(huì)釋放喚醒鎖。這意味著只要OnReceive()方法完成,你的手機(jī)可能在某些情況下進(jìn)入休眠,如果你的鬧鐘廣播接收者調(diào)用的是Context.startService(),那么手機(jī)有可能在被請求的服務(wù)執(zhí)行之前進(jìn)入休眠,為了防止這種情況,你的BroadcastReceiver和服務(wù)需要實(shí)現(xiàn)一個(gè)單獨(dú)的喚醒鎖策略以確保手機(jī)繼續(xù)運(yùn)行,直到服務(wù)可用。
此處注意:該類適用于你想讓應(yīng)用程序在將來某個(gè)指定時(shí)間點(diǎn)執(zhí)行的情況,即使你的應(yīng)用程序現(xiàn)在沒有運(yùn)行。對一般的時(shí)間操作,使用Handler是更容易和更有效率的。
二、公有方法(Public Methods):
void cancel(PendingIntent operation)
取消AlarmManager的定時(shí)服務(wù)。
void set(int type, long triggerAtTime, PendingIntent operation)
設(shè)置在triggerAtTime時(shí)間啟動(dòng)由operation參數(shù)指定的組件。(該方法用于設(shè)置一次性鬧鐘)
void setInexactRepeating(int type, long triggerAtTime, long interval, PendingIntent operation)
設(shè)置一個(gè)非精確的周期性任務(wù)。
void setRepeating(int type, long triggerAtTime, long interval, PendingIntent operation)
設(shè)置一個(gè)周期性執(zhí)行的定時(shí)服務(wù)。
void setTime(long millis)
設(shè)置系統(tǒng)“墻”時(shí)鐘。需要android.permission.SET_TIME.權(quán)限。
void setTimeZone(String timeZone)
設(shè)置系統(tǒng)的默認(rèn)時(shí)區(qū)。需要android.permission.SET_TIME_ZONE.權(quán)限。
三、常用方法說明:
AlarmManager的常用方法有三個(gè):
(1)
set(int type,long startTime,PendingIntent pi)
該方法用于設(shè)置一次性鬧鐘。
第一個(gè)參數(shù)int type指定定時(shí)服務(wù)的類型,該參數(shù)接受如下值:
ELAPSED_REALTIME: 在指定的延時(shí)過后,發(fā)送廣播,但不喚醒設(shè)備(鬧鐘在睡眠狀態(tài)下不可用)。如果在系統(tǒng)休眠時(shí)鬧鐘觸發(fā),它將不會(huì)被傳遞,直到下一次設(shè)備喚醒。
ELAPSED_REALTIME_WAKEUP: 在指定的延時(shí)過后,發(fā)送廣播,并喚醒設(shè)備(即使關(guān)機(jī)也會(huì)執(zhí)行operation所對應(yīng)的組件) 。
延時(shí)是要把系統(tǒng)啟動(dòng)的時(shí)間SystemClock.elapsedRealtime()算進(jìn)去的,具體用法看代碼。
RTC: 指定當(dāng)系統(tǒng)調(diào)用System.currentTimeMillis()方法返回的值與triggerAtTime相等時(shí)啟動(dòng)operation所對應(yīng)的設(shè)備(在指定的時(shí)刻,發(fā)送廣播,但不喚醒設(shè)備)。如果在系統(tǒng)休眠時(shí)鬧鐘觸發(fā),它將不會(huì)被傳遞,直到下一次設(shè)備喚醒(鬧鐘在睡眠狀態(tài)下不可用)。
RTC_WAKEUP: 指定當(dāng)系統(tǒng)調(diào)用System.currentTimeMillis()方法返回的值與triggerAtTime相等時(shí)啟動(dòng)operation所對應(yīng)的設(shè)備(在指定的時(shí)刻,發(fā)送廣播,并喚醒設(shè)備)。即使系統(tǒng)關(guān)機(jī)也會(huì)執(zhí)行 operation所對應(yīng)的組件。
第二個(gè)參數(shù)表示鬧鐘執(zhí)行時(shí)間。
第三個(gè)參數(shù)PendingIntent pi表示鬧鐘響應(yīng)動(dòng)作:
PendingIntent pi:是鬧鐘的執(zhí)行動(dòng)作,比如發(fā)送一個(gè)廣播、給出提示等等。PendingIntent是Intent的封裝類。需要注意的是,如果是通過啟動(dòng)服務(wù)來實(shí)現(xiàn)鬧鐘提示的話,PendingIntent對象的獲取就應(yīng)該采用Pending.getService(Context c,int i,Intentintent,int j)方法;如果是通過廣播來實(shí)現(xiàn)鬧鐘提示的話,PendingIntent對象的獲取就應(yīng)該采用PendingIntent.getBroadcast(Context c,inti,Intent intent,int j)方法;如果是采用Activity的方式來實(shí)現(xiàn)鬧鐘提示的話,PendingIntent對象的獲取就應(yīng)該采用PendingIntent.getActivity(Context c,inti,Intent intent,int j)方法。如果這三種方法錯(cuò)用了的話,雖然不會(huì)報(bào)錯(cuò),但是看不到鬧鐘提示效果。
(2)
setRepeating(int type,long startTime,long intervalTime,PendingIntent pi)
設(shè)置一個(gè)周期性執(zhí)行的定時(shí)服務(wù)。第一個(gè)參數(shù)表示鬧鐘類型,第二個(gè)參數(shù)表示鬧鐘首次執(zhí)行時(shí)間,第三個(gè)參數(shù)表示鬧鐘兩次執(zhí)行的間隔時(shí)間,第三個(gè)參數(shù)表示鬧鐘響應(yīng)動(dòng)作。
(3)
setInexactRepeating(int type,long startTime,long intervalTime,PendingIntent pi)
該方法也用于設(shè)置重復(fù)鬧鐘,與第二個(gè)方法相似,不過其兩個(gè)鬧鐘執(zhí)行的間隔時(shí)間不是固定的而已。它相對而言更省電(power-efficient)一些,因?yàn)橄到y(tǒng)可能會(huì)將幾個(gè)差不多的鬧鐘合并為一個(gè)來執(zhí)行,減少設(shè)備的喚醒次數(shù)。第三個(gè)參數(shù)intervalTime為鬧鐘間隔,內(nèi)置的幾個(gè)變量如下:
INTERVAL_DAY:????? 設(shè)置鬧鐘,間隔一天
INTERVAL_HALF_DAY:? 設(shè)置鬧鐘,間隔半天
INTERVAL_FIFTEEN_MINUTES:設(shè)置鬧鐘,間隔15分鐘
INTERVAL_HALF_HOUR:???? 設(shè)置鬧鐘,間隔半個(gè)小時(shí)
INTERVAL_HOUR:? 設(shè)置鬧鐘,間隔一個(gè)小時(shí)
本文是武林技術(shù)頻道給大家?guī)淼腁ndroid開發(fā)之AlarmManager的用法詳解,希望對你學(xué)習(xí)這方面知識(shí)有幫助,也請大家繼續(xù)支持武林技術(shù)頻道!
新聞熱點(diǎn)
疑難解答
圖片精選