Android開發(fā)中實(shí)現(xiàn)定時器功能的方法有哪些?針對這個問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項(xiàng)目有:域名與空間、網(wǎng)頁空間、營銷軟件、網(wǎng)站建設(shè)、溧陽網(wǎng)站維護(hù)、網(wǎng)站推廣。
一、Timer
Timer是Android直接啟動定時器的類,TimerTask是一個子線程,方便處理一些比較復(fù)雜耗時的功能邏輯,經(jīng)常與handler結(jié)合使用。
跟handler自身實(shí)現(xiàn)的定時器相比,Timer可以做一些復(fù)雜的處理,例如,需要對有大量對象的list進(jìn)行排序,在TimerTask中執(zhí)行不會阻塞子線程,常常與handler結(jié)合使用,在處理完復(fù)雜耗時的操作后,通過handler來更新UI界面。
timer.schedule(task, delay,period);
task: TimerTask類型的對象,實(shí)現(xiàn)TimerTask的run()方法就是要周期執(zhí)行的一個任務(wù);
delay : 從定時器初始化成功 開始啟動 的延遲時間。
period:定時器的間隔時間。
第三個參數(shù)就是執(zhí)行的周期,為long類型。
TimerTask task= new TimerTask() { @Override public void run() { count++; Log.i("MainActivity",count + ""); } }; new Timer().shedule(task,0,1000);//
以下是幾種調(diào)度task的方法:
//time為Date類型:在指定時間執(zhí)行
timer.schedule(task, time);
//firstTime為Date類型,period為long,表示從firstTime時刻開始,每隔period毫秒執(zhí)行一次。
timer.schedule(task, firstTime,period);
//delay 為long類型:從現(xiàn)在起過delay毫秒執(zhí)行一次。
timer.schedule(task, delay);
//delay為long,period為long:從現(xiàn)在起過delay毫秒以后,每隔period毫秒執(zhí)行一次。
timer.schedule(task, delay,period);
//time為Date類型:在指定時間執(zhí)行一次。
timer.schedule(task, time);
//firstTime為Date類型,period為long,表示從firstTime時刻開始,每隔period毫秒執(zhí)行一次。
timer.schedule(task, firstTime,period);
//delay 為long類型:從現(xiàn)在起過delay毫秒執(zhí)行一次。
timer.schedule(task, delay);
//delay為long,period為long:從現(xiàn)在起過delay毫秒以后,每隔period毫秒執(zhí)行一次。
timer.schedule(task, delay,period);
注意: 1.taskonDestory()中取消掉,否則可能發(fā)生崩潰
2.用TimerTask定時進(jìn)行某些操作的APP,即使退出了,TimerTask中依然會運(yùn)行一會,但是不能長時間運(yùn)行
3.對于部分手機(jī),如果你在TimerTask直接更新了UI線程是不會報(bào)錯的,而且運(yùn)行正常,但是一定注意,更新UI一定要在主線程中執(zhí)行,否則排查錯誤的時候你懂得。而且這個東西特別耗電,特別耗電,特別耗電,重要的事情說三遍,一定在不使用的時候關(guān)閉
二 、CountDownTimer
CountDownTimer cdt = new CountDownTimer(10000, 100) { @Override public void onTick(long millisUntilFinished) { tv_hello.setText(millisUntilFinished + ""); } @Override public void onFinish() { } }; cdt.start();
onTick中的方法一次
直到執(zhí)行完10000/100次為止,最后會執(zhí)行onFinish()
三、 AlarmManager
Intent intent2 = newIntent(ReadLogService.this,TestBroadcast.class); PendingIntent pd=PendingIntent.getBroadcast(getApplicationContext(),0,intent2,PendingIntent.FLAG_ONE_SHOT); AlarmManager am = (AlarmManager)getSystemService(ALARM_SERVICE); long triggerTime =SystemClock.elapsedRealtime() + 5*1000; am.set(AlarmManager.ELAPSED_REALTIME,triggerTime, pd);
上面就是定時器的基本用法,先獲取manager,然后定義鬧鐘的flag,循環(huán)時間,到指定時間發(fā)出的pendingIntent。
一般都發(fā)出的pendingIntent都是廣播,我們自定義一個廣播接收器,就可以通過接收這個廣播,來處理自己的功能邏輯了。
這里需要注意在獨(dú)立進(jìn)程中配置,這是android所定義的
1,Alarm定時不需要程序自身去維護(hù),而又系統(tǒng)來維護(hù),使得程序更好避免了容易出錯問題,更是占用系統(tǒng)資源,cpu占有率。
2,即使程序退出后,程序自身不會有任何煩惱的問題,系統(tǒng)到時間自動調(diào)用對應(yīng)組件執(zhí)行定義好的邏輯
3,定時的多樣性,包括一次定時,循環(huán)定時(在xx年x月x日執(zhí)行,周一至周五執(zhí)行,每天幾點(diǎn)幾分執(zhí)行。。。)
四、 handler
Handler可以幫助我們在子線程中操作UI線程,例如子線程解析數(shù)據(jù),解析結(jié)束后通知UI刷新界面。他本身也可以實(shí)現(xiàn)定時器。
private Handler handler = Handler() { public handleMessage(android.os.Message msg) { switch (msg.what) { : // 移除所有的msg.what為0等消息,保證只有一個循環(huán)消息隊(duì)列再跑 handler.removeMessages(); // app的功能邏輯處理 ... // 再次發(fā)出msg,循環(huán)更新 handler.sendEmptyMessageDelayed(, ); break; : // 直接移除,定時器停止 handler.removeMessages(); break; default: break; } }; };
只要在啟動定時器的時候,Handler.sendEmptyMessage(0),定時器就啟動了。繼續(xù)循環(huán)和停止的方法,注釋上已經(jīng)寫了。
每次循環(huán)都是在主線程中操作,避免了子線程和主線程之間的穿插交互,個人覺得比timer好控制,功能實(shí)現(xiàn)也很簡單。
個人覺得比較適用連續(xù)更新UI,不做復(fù)雜耗時的處理的情況,例如在播放器中,我們需要更新當(dāng)前播放進(jìn)度的時間的顯示,僅僅是更新了文字顯示,用handler就是個不錯的選擇。
五、Thread
Thread實(shí)現(xiàn)定時器是創(chuàng)建一個子線程,在里面while循環(huán),可以通過handler來更新UI。個人覺得Thread和Timer沒區(qū)別,只是長得不一樣。
private MyThread thread; private class MyThread extends Thread { public boolean stop; public () { while (!stop) { // 處理功能 // 通過睡眠線程來設(shè)置定時時間 { Thread.sleep(); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } }; }; /** * 啟動線程 * */ private start() { (thread == ) { thread = MyThread(); thread.start(); } } /** * 停止線程 * */ private () { (thread != ) { thread.stop = ; thread = ; } }
覺得跟Timer差不多,沒什么特殊優(yōu)點(diǎn)
跟Timer差不多,多線程如果考慮不周經(jīng)常會出問題,經(jīng)常會出現(xiàn)多個相同功能的線程同時存在,android本身對于子線程的使用使用數(shù)量是有限制的,而且一個app同時跑多個線程是一個很可怕的事情,所以和Timer一樣,使用的時候一定要謹(jǐn)慎考慮。
關(guān)于Android開發(fā)中實(shí)現(xiàn)定時器功能的方法有哪些問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識。