亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Android的線程使用來更新UI----Thread、Handler

系統 2118 0
方法一:(java習慣,在android不推薦使用)
剛剛開始接觸android線程編程的時候,習慣好像java一樣,試圖用下面的代碼解決問題
Java代碼 復制代碼 ? 收藏代碼
  1. new ?Thread(? new ?Runnable()?{????? ??
  2. ???? public ? void ?run()?{????? ??
  3. ?????????myView.invalidate();???? ??
  4. ?????}???????????? ??
  5. }).start();??
      new Thread( new Runnable() {     
    public void run() {     
         myView.invalidate();    
     }            
}).start();

    

可以實現功能,刷新UI界面。但是這樣是不行的,因為它違背了單線程模型:Android UI操作并不是線程安全的并且這些操作必須在UI線程中執行。
方法二:(Thread+Handler)
查閱了文檔和apidemo后,發覺常用的方法是利用Handler來實現UI線程的更新的。
Handler來根據接收的消息,處理UI更新。Thread線程發出Handler消息,通知更新UI。
Java代碼 復制代碼 ? 收藏代碼
  1. Handler?myHandler?=? new ?Handler()?{?? ??
  2. ?????????? public ? void ?handleMessage(Message?msg)?{??? ??
  3. ??????????????? switch ?(msg.what)?{??? ??
  4. ???????????????????? case ?TestHandler.GUIUPDATEIDENTIFIER:??? ??
  5. ?????????????????????????myBounceView.invalidate();?? ??
  6. ????????????????????????? break ;??? ??
  7. ???????????????}??? ??
  8. ??????????????? super .handleMessage(msg);??? ??
  9. ??????????}??? ??
  10. ?????};?? ??
  11. ? class ?myThread? implements ?Runnable?{??? ??
  12. ?????????? public ? void ?run()?{?? ??
  13. ??????????????? while ?(!Thread.currentThread().isInterrupted())?{???? ??
  14. ??????????????????????? ??
  15. ????????????????????Message?message?=? new ?Message();??? ??
  16. ????????????????????message.what?=?TestHandler.GUIUPDATEIDENTIFIER;??? ??
  17. ?????????????????????? ??
  18. ????????????????????TestHandler. this .myHandler.sendMessage(message);??? ??
  19. ???????????????????? try ?{??? ??
  20. ?????????????????????????Thread.sleep( 100 );???? ??
  21. ????????????????????}? catch ?(InterruptedException?e)?{??? ??
  22. ?????????????????????????Thread.currentThread().interrupt();??? ??
  23. ????????????????????}??? ??
  24. ???????????????}??? ??
  25. ??????????}??? ??
  26. ?????}?????
      Handler myHandler = new Handler() {  
          public void handleMessage(Message msg) {   
               switch (msg.what) {   
                    case TestHandler.GUIUPDATEIDENTIFIER:   
                         myBounceView.invalidate();  
                         break;   
               }   
               super.handleMessage(msg);   
          }   
     };  
 class myThread implements Runnable {   
          public void run() {  
               while (!Thread.currentThread().isInterrupted()) {    
                       
                    Message message = new Message();   
                    message.what = TestHandler.GUIUPDATEIDENTIFIER;   
                      
                    TestHandler.this.myHandler.sendMessage(message);   
                    try {   
                         Thread.sleep(100);    
                    } catch (InterruptedException e) {   
                         Thread.currentThread().interrupt();   
                    }   
               }   
          }   
     }   
    

以上方法demo看: http://rayleung.javaeye.com/blog/411860
方法三:(java習慣,不推薦)
在Android平臺中需要反復按周期執行方法可以使用Java上自帶的TimerTask類,TimerTask相對于Thread來說對于資源消耗的更低,除了使用Android自帶的AlarmManager使用Timer定時器是一種更好的解決方法。 我們需要引入import java.util.Timer; 和 import java.util.TimerTask;
Java代碼 復制代碼 ? 收藏代碼
  1. public ? class ?JavaTimer? extends ?Activity?{?? ??
  2. ?? ??
  3. ????Timer?timer?=? new ?Timer();?? ??
  4. ????TimerTask?task?=? new ?TimerTask(){??? ??
  5. ???????? public ? void ?run()?{?? ??
  6. ????????????setTitle( "hear?me?" );?? ??
  7. ????????}???????????? ??
  8. ????};?? ??
  9. ??
  10. ???? public ? void ?onCreate(Bundle?savedInstanceState)?{?? ??
  11. ???????? super .onCreate(savedInstanceState);?? ??
  12. ????????setContentView(R.layout.main);?? ??
  13. ??????? ??
  14. ?????????timer.schedule(task,? 10000 );?? ??
  15. ??
  16. ????}?? ??
  17. }????
      public class JavaTimer extends Activity {  
  
    Timer timer = new Timer();  
    TimerTask task = new TimerTask(){   
        public void run() {  
            setTitle("hear me?");  
        }            
    };  

    public void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.main);  
       
         timer.schedule(task, 10000);  

    }  
}  
    

方法四:(TimerTask + Handler)
實際上這樣做是不行的,這跟Android的線程安全有關!應該通過配合Handler來實現timer功能的!
Java代碼 復制代碼 ? 收藏代碼
  1. public ? class ?TestTimer? extends ?Activity?{?? ??
  2. ?? ??
  3. ????Timer?timer?=? new ?Timer();?? ??
  4. ????Handler?handler?=? new ?Handler(){??? ??
  5. ???????? public ? void ?handleMessage(Message?msg)?{?? ??
  6. ???????????? switch ?(msg.what)?{?????? ??
  7. ???????????? case ? 1 :?????? ??
  8. ????????????????setTitle( "hear?me?" );?? ??
  9. ???????????????? break ;?????? ??
  10. ????????????}?????? ??
  11. ???????????? super .handleMessage(msg);?? ??
  12. ????????}?? ??
  13. ?????????? ??
  14. ????};?? ??
  15. ??
  16. ????TimerTask?task?=? new ?TimerTask(){???? ??
  17. ???????? public ? void ?run()?{?? ??
  18. ????????????Message?message?=? new ?Message();?????? ??
  19. ????????????message.what?=? 1 ;?????? ??
  20. ????????????handler.sendMessage(message);???? ??
  21. ????????}???????????? ??
  22. ????};?? ??
  23. ??
  24. ???? public ? void ?onCreate(Bundle?savedInstanceState)?{?? ??
  25. ???????? super .onCreate(savedInstanceState);?? ??
  26. ????????setContentView(R.layout.main);?? ??
  27. ?????? ??
  28. ????????timer.schedule(task,? 10000 );?? ??
  29. ????}?? ??
  30. }????
      public class TestTimer extends Activity {  
  
    Timer timer = new Timer();  
    Handler handler = new Handler(){   
        public void handleMessage(Message msg) {  
            switch (msg.what) {      
            case 1:      
                setTitle("hear me?");  
                break;      
            }      
            super.handleMessage(msg);  
        }  
          
    };  

    TimerTask task = new TimerTask(){    
        public void run() {  
            Message message = new Message();      
            message.what = 1;      
            handler.sendMessage(message);    
        }            
    };  

    public void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.main);  
      
        timer.schedule(task, 10000);  
    }  
}  
    

方法五:( Runnable + Handler.postDelayed(runnable,time) )
在Android里定時更新 UI,通常使用的是 java.util.Timer, java.util.TimerTask, android.os.Handler組合。實際上Handler 自身已經提供了定時的功能。
Java代碼 復制代碼 ? 收藏代碼
  1. private ?Handler?handler?=? new ?Handler();?? ??
  2. ? ??
  3. ??? private ?Runnable?myRunnable=? new ?Runnable()?{???? ??
  4. ??????? public ? void ?run()?{?? ??
  5. ???????????? ??
  6. ??????????? if ?(run)?{?? ??
  7. ???????????????handler.postDelayed( this ,? 1000 );?? ??
  8. ???????????????count++;?? ??
  9. ???????????}?? ??
  10. ???????????tvCounter.setText( "Count:?" ?+?count);?? ??
  11. ??
  12. ???????}?? ??
  13. ???};????
       private Handler handler = new Handler();  
  
    private Runnable myRunnable= new Runnable() {    
        public void run() {  
             
            if (run) {  
                handler.postDelayed(this, 1000);  
                count++;  
            }  
            tvCounter.setText("Count: " + count);  

        }  
    };  

    

然后在其他地方調用
handler.post(myRunnable);
handler.post(myRunnable,time);
案例看: http://shaobin0604.javaeye.com/blog/515820
============================================================================
知識點總結補充:
?? 很多初入Android或Java開發的新手對Thread、Looper、Handler和Message仍然比較迷惑,衍生的有HandlerThread、java.util.concurrent、Task、AsyncTask由于目前市面上的書籍等資料都沒有談到這些問題,今天就這一問題做更系統性的總結。我們創建的Service、Activity以及Broadcast均是一個主線程處理,這里我們可以理解為UI線程。但是在操作一些耗時操作時,比如I/O讀寫的大文件讀寫,數據庫操作以及網絡下載需要很長時間,為了不阻塞用戶界面,出現ANR的響應提示窗口,這個時候我們可以考慮使用Thread線程來解決。
?? 對于從事過J2ME開發的程序員來說Thread比較簡單,直接匿名創建重寫run方法,調用start方法執行即可。或者從Runnable接口繼承,但對于Android平臺來說UI控件都沒有設計成為線程安全類型,所以需要引入一些同步的機制來使其刷新,這點Google在設計Android時倒是參考了下Win32的消息處理機制。
1. 對于線程中的刷新一個View為基類的界面,可以使用postInvalidate()方法在線程中來處理,其中還提供了一些重寫方法比如postInvalidate(int left,int top,int right,int bottom) 來刷新一個矩形區域,以及延時執行,比如postInvalidateDelayed(long delayMilliseconds)或postInvalidateDelayed(long delayMilliseconds,int left,int top,int right,int bottom) 方法,其中第一個參數為毫秒
2. 當然推薦的方法是通過一個Handler來處理這些,可以在一個線程的run方法中調用handler對象的 postMessage或sendMessage方法來實現,Android程序內部維護著一個消息隊列,會輪訓處理這些,如果你是Win32程序員可以很好理解這些消息處理,不過相對于Android來說沒有提供 PreTranslateMessage這些干涉內部的方法。
3. Looper又是什么呢? ,其實Android中每一個Thread都跟著一個Looper,Looper可以幫助Thread維護一個消息隊列,但是Looper和Handler沒有什么關系,我們從開源的代碼可以看到Android還提供了一個Thread繼承類HanderThread可以幫助我們處理,在HandlerThread對象中可以通過getLooper方法獲取一個Looper對象控制句柄,我們可以將其這個Looper對象映射到一個Handler中去來實現一個線程同步機制,Looper對象的執行需要初始化Looper.prepare方法就是昨天我們看到的問題,同時推出時還要釋放資源,使用Looper.release方法。
4.Message 在Android是什么呢? 對于Android中Handler可以傳遞一些內容,通過Bundle對象可以封裝String、Integer以及Blob二進制對象,我們通過在線程中使用Handler對象的sendEmptyMessage或sendMessage方法來傳遞一個Bundle對象到Handler處理器。對于Handler類提供了重寫方法handleMessage(Message msg) 來判斷,通過msg.what來區分每條信息。將Bundle解包來實現Handler類更新UI線程中的內容實現控件的刷新操作。相關的Handler對象有關消息發送sendXXXX相關方法如下,同時還有postXXXX相關方法,這些和Win32中的道理基本一致,一個為發送后直接返回,一個為處理后才返回 .
5. java.util.concurrent對象分析,對于過去從事Java開發的程序員不會對Concurrent對象感到陌生吧,他是JDK 1.5以后新增的重要特性作為掌上設備,我們不提倡使用該類,考慮到Android為我們已經設計好的Task機制,這里不做過多的贅述,相關原因參考下面的介紹:
6. 在Android中還提供了一種有別于線程的處理方式,就是Task以及AsyncTask,從開源代碼中可以看到是針對Concurrent的封裝,開發人員可以方便的處理這些異步任務。
摘錄自: http://www.android123.com.cn/androidkaifa/422.html

Android的線程使用來更新UI----Thread、Handler、Looper、TimerTask等


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国产亚洲精品九九久在线观看 | 天天色天天拍 | 九九香蕉 | 日本色综合网 | 全黄h全肉边做边吃奶在线观看 | 99色99| 男人叼女人的痛爽视频免费 | 久久精品国产精品亚洲毛片 | 亚洲欧美综合网站 | 视频一区二区在线 | 97免费看 | www.黄黄黄 | 亚洲人成依人成综合网 | 日韩精品久久不卡中文字幕 | 日本黄色网址视频 | 国产香蕉一区二区在线观看 | 欧美精品亚洲精品日韩一区 | 久久一本色道综合 | 久久婷婷激情综合中文字幕 | 九一国产 | 欧美亚洲h在线一区二区 | 色综合天天| 国产成人精品日本亚洲语音2 | 国产精品久久大陆 | 久久久久久久国产精品 | 国产自愉怕一区二区三区 | 毛片黄 | 欧美亚洲国产精品久久久 | 国产91在线播放 | 青青青视频自偷自拍视频1 青青青手机版视频在线观看 | 国产午夜精品福利视频 | 91精品成人免费国产 | 亚洲合集综合久久性色 | 国产69精品久久久久99不卡 | 欧美成人片在线 | 高清成人综合 | 久久久毛片| 亚洲精品乱码久久久久久蜜桃 | 老司机午夜永久在线观看 | 97久久免费视频 | 成人夜色视频网站在线观看 |