真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Android開發(fā)中實(shí)現(xiàn)定時器功能的方法有哪些

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)知識。


分享標(biāo)題:Android開發(fā)中實(shí)現(xiàn)定時器功能的方法有哪些
網(wǎng)站鏈接:http://weahome.cn/article/pjschs.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部