溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

handler消息處理機制的用法

發(fā)布時間:2020-06-05 15:23:40 來源:億速云 閱讀:198 作者:Leah 欄目:移動開發(fā)

這篇文章運用了實例代碼展示了handler消息處理機制的使用方法,代碼非常詳細,解讀可供感興趣的小伙伴們參考借鑒,希望對大家有所幫助。        

Android系統(tǒng)的消息隊列和消息循環(huán)都是針對具體線程的,一個線程可以存在(當然也可以不存在)一個消息隊列(Message Queue)和一個消息循環(huán)(Looper)。Android中除了UI線程(主線程),創(chuàng)建的工作線程默認是沒有消息循環(huán)和消息隊列的。如果想讓該線程具有消息隊列和消息循環(huán),并具有消息處理機制,就需要在線程中首先調用Looper.prepare()來創(chuàng)建消息隊列,然后調用Looper.loop()進入消息循環(huán)。

class LooperThread extends Thread {  

   public Handler mHandler;  

   public void run() {  

         Looper.prepare();  

         mHandler = new Handler() {  

           public void handleMessage(Message msg) {  

               // process incoming messages here

            }  

         };  

        Looper.loop();  

    }  

}

Handler可以把一個Message對象或者Runnable對象壓入到消息隊列中,進而在UI線程中獲取Message或者執(zhí)行Runnable對象,所以Handler把壓入消息隊列有兩大體系,Post和sendMessage。

Post:Post允許把一個Runnable對象入隊到消息隊列中。它的方法有:post(Runnable)、      postAtTime(Runnable,long)、postDelayed(Runnable,long)。

sendMessage:sendMessage允許把一個包含消息數(shù)據(jù)的Message對象壓入到消息隊列中。它的方法有:sendEmptyMessage(int)、sendMessage(Message)、sendMessageAtTime(Message,long)、sendMessageDelayed(Message,long)。


Message:Message是一個final類,所以不可被繼承。使用Message.obtain()這個靜態(tài)的方法或者Handler.obtainMessage()獲取。Message.obtain()方法具有多個重載方法,大致可以分為為兩類,一類是無需傳遞Handler對象,對于這類的方法,當填充好消息后,需要調用Handler.sendMessage()方法來發(fā)送消息到消息隊列中。第二類需要傳遞一個Handler對象,這類方法可以直接使用Message.sendToTarget()方法發(fā)送消息到消息隊列中,這是因為在Message對象中有一個私有的Handler類型的屬性Target,當時obtain方法傳遞進一個Handler對象的時候,會給Target屬性賦值,當調用sendToTarget()方法的時候,實際在它內部還是調用的Target.sendMessage()方法。


總結:一個Looper對應一個MessageQueue,一個線程對應一個Looper,一個線程可以有多個looper。


Handler handler = new Handler(){...}創(chuàng)建Handler。這樣創(chuàng)建的handler是在主線程即UI線程下的Handler,即這個Handler是與UI線程下的默認Looper綁定的。HandlerThread實際上就一個Thread,只不過它比普通的Thread多了一個Looper。創(chuàng)建HandlerThread時要把它啟動了,即調用start()方法。然后創(chuàng)建Handler時將HandlerThread中的looper對象傳入。

HandlerThread thread = new HandlerThread("MyHandlerThread");
thread.start();
mHandler = new Handler(thread.getLooper());
mHandler.post(new Runnable(){...});
那么這個Handler對象就是與HandlerThread這個線程綁定了(這時就不再是與UI線程綁定了,這樣它處理耗時操作將不會阻塞UI)。

上文描述的就是handler消息處理機制的用法,具體使用情況還需要大家自己動手實驗使用過才能領會。如果想了解更多相關內容,歡迎關注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。

AI