3 Android的消息隊列的原理: android 有一種叫消息隊列的說法,這里我們可以這樣理解:假如一個隧道就是一個消息隊列,那么里面的每一部汽車就是一個一個消息,這里我們先忽略掉超車等種種因素,只那么先進(jìn)隧道的車將會先出,這個機(jī)制跟我們android 的消息機(jī)制是一樣的。 角色描述實現(xiàn): 1.Looper:(相當(dāng)于隧道) 一個線程可以產(chǎn)生一個Looper 對象,由它來管理此線程里的Message Queue( 車隊,消息隧道) 。 2.Handler: 你可以構(gòu)造Handler 對象來與Looper 溝通,以便push 新消息到Message Queue 里;或者接收Looper( 從Message Queue 取出) 所送來的消息。 3. Message Queue( 消息隊列): 用來存放線程放入的消息。 4 .線程:UI thread 通常就是main thread ,而Android 啟動程序時會替它建立一個Message Queue 。 每一個線程里可含有一個Looper 對象以及一個MessageQueue 數(shù)據(jù)結(jié)構(gòu)。在你的應(yīng)用程序里,可以定義Handler 的子類別來接收Looper 所送出的消息。 在你的Android 程序里,新誕生一個線程,或執(zhí)行 (Thread) 時,并不會自動建立其Message Loop 。 Android 里并沒有Global 的Message Queue 數(shù)據(jù)結(jié)構(gòu),例如,不同APK 里的對象不能透過Massage Queue 來交換訊息(Message) 。 例如:線程A 的Handler 對象可以傳遞消息給別的線程,讓別的線程B 或C 等能送消息來給線程A( 存于A 的Message Queue 里) 。 線程A 的Message Queue 里的訊息,只有線程A 所屬的對象可以處理。 使用Looper.myLooper 可以取得當(dāng)前線程的Looper 對象。 使用mHandler = new EevntHandler(Looper.myLooper()); 可用來構(gòu)造當(dāng)前線程的Handler 對象;其中,EevntHandler 是自已實現(xiàn)的Handler 的子類別。 使用mHandler = new EevntHandler(Looper.getMainLooper()); 可誕生用來處理main 線程的Handler 對象;其中,EevntHandler 是自已實現(xiàn)的Handler 的子類別。 每一個線程里可含有一個Looper 對象以及一個MessageQueue 數(shù)據(jù)結(jié)構(gòu)。在你的應(yīng)用程序里,可以定義Handler 的子類別來接收Looper 所送出的消息。 這樣描述可能太抽像,下面舉幾個實際的例子來說明: 1. 同線程內(nèi)不同組件間的消息傳遞 Looper 類用來管理特定線程內(nèi)對象之間的消息交換(Message Exchange) 。你的應(yīng)用程序可以產(chǎn)生許多個線程。而一個線程可以有許多個組件,這些組件之間常常需要互相交換訊息。如果有這種需要,您可以替線程構(gòu)造一個Looper 對象,來擔(dān)任訊息交換的管理工作。Looper 對象會建立一個MessageQueue 數(shù)據(jù)結(jié)構(gòu)來存放各對象傳來的消息( 包括UI 事件或System 事件等) 。如下圖: 下面一個簡單的例子來解釋線程之間的通訊的原理: 實現(xiàn)的代碼: Main.xml <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" > <TextView android:id="@+id/content" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_alignParentTop="true" android:layout_alignRight="@+id/btn" android:layout_marginTop="65dp" android:text="TextView" /> <Button android:id="@+id/btn" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentLeft="true" android:layout_alignParentTop="true" android:layout_marginLeft="100dp" android:layout_marginTop="156dp" android:text="Button" /> </RelativeLayout> </div |