【移動應(yīng)用開發(fā)技術(shù)】Android的Handler Looper Message機(jī)制應(yīng)用實(shí)例與詳解(一)_第1頁
【移動應(yīng)用開發(fā)技術(shù)】Android的Handler Looper Message機(jī)制應(yīng)用實(shí)例與詳解(一)_第2頁
【移動應(yīng)用開發(fā)技術(shù)】Android的Handler Looper Message機(jī)制應(yīng)用實(shí)例與詳解(一)_第3頁
【移動應(yīng)用開發(fā)技術(shù)】Android的Handler Looper Message機(jī)制應(yīng)用實(shí)例與詳解(一)_第4頁
【移動應(yīng)用開發(fā)技術(shù)】Android的Handler Looper Message機(jī)制應(yīng)用實(shí)例與詳解(一)_第5頁
已閱讀5頁,還剩6頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

【移動應(yīng)用開發(fā)技術(shù)】Android的HandlerLooperMessage機(jī)制應(yīng)用實(shí)例與詳解(一)

Android的UI操作不是線程安全的(出于提高性能考慮,避免實(shí)現(xiàn)多線程同步等機(jī)制所引入的延時),若多個線程同時對UI元素進(jìn)行操作,可能導(dǎo)致線程安全問題。因此,Android中做了嚴(yán)格的規(guī)定:只有UI主線程才能對UI進(jìn)行設(shè)置與操作。

在實(shí)際編程中,為了避免UI界面長時間得不到響應(yīng)而導(dǎo)致的ANR(ApplicationNotResponding)異常,通常將網(wǎng)絡(luò)訪問、復(fù)雜運(yùn)算等一些耗時的操作被放在子線程中執(zhí)行。這就需要子線程在運(yùn)行完畢后將結(jié)果返回到主線程并通過UI進(jìn)行顯示。在Android中,是通過Handler+Loop+MessageQueue實(shí)現(xiàn)線程間通信的。

先看兩個實(shí)例:

實(shí)例1:模擬通過網(wǎng)絡(luò)下載數(shù)據(jù)并返回UI顯示。

操作過程為:1.UI線程獲得用戶請求。2.啟動子線程完成網(wǎng)絡(luò)數(shù)據(jù)下載(網(wǎng)絡(luò)下載過程通過強(qiáng)制子線程休眠若干秒來模擬)。3.子線程將下載的數(shù)據(jù)返回UI線程并顯示。

主要代碼如下:public

class

MainActivity

extends

ActionBarActivity

{

private

Button

mButton;

private

TextView

mTextView;

private

Handler

mHandler;

private

Thread

mNetAccessThread;

private

ProgressDialog

mProgressDialog;

private

int

mDownloadCount

=

0;

@Override

protected

void

onCreate(Bundle

savedInstanceState)

{

super.onCreate(savedInstanceState);

setContentView(R.layout.fragment_main);

mButton

=

(Button)

findViewById(R.id.btReqNet);

mTextView

=

(TextView)

findViewById(R.id.tvDownload);

//設(shè)置按鈕的點(diǎn)擊事件監(jiān)聽器

mButton.setOnClickListener(new

OnClickListener()

{

@Override

public

void

onClick(View

v)

{

showProgressDialog("","正在下載...");

//啟動子線程進(jìn)行網(wǎng)絡(luò)訪問模擬

mNetAccessThread

=

new

ChildTread();

mNetAccessThread.start();

}

});

//繼承Handler類并覆蓋其handleMessage方法

mHandler

=

new

Handler(){

//覆蓋Handler類的handleMessage方法

//接收子線程傳遞的數(shù)據(jù)并在UI顯示

@Override

public

void

handleMessage(Message

msg)

{

switch

(msg.what)

{

case

1:

mTextView.setText((String)

msg.obj);

dismissProgressDialog();

break;

//可以添加其他情況,如網(wǎng)絡(luò)傳輸錯誤

//case...

default:

break;

}

}

};

}

class

ChildTread

extends

Thread

{

@Override

public

void

run()

{

//休眠6秒,模擬網(wǎng)絡(luò)訪問延遲

try

{

Thread.sleep(6000);

}

catch

(InterruptedException

e)

{

e.printStackTrace();

}

//將結(jié)果通過消息返回主線程

Message

msg

=

new

Message();

msg.what

=

1;

mDownloadCount

++;

msg.obj

=

new

String("第"+mDownloadCount+"次從網(wǎng)上下載的數(shù)據(jù)");

mHandler.sendMessage(msg);

}

};

/**

*

開啟progressDialog.

*

*

@param

title

對話框標(biāo)題.

*

@param

content

對話框正文.

*/

protected

void

showProgressDialog(String

title,String

content)

{

mProgressDialog

=

new

ProgressDialog(this);

if(title

!=

null)

mProgressDialog.setTitle(title);

if(content

!=

null)

mProgressDialog.setMessage(content);

mProgressDialog.show();

}

/**

*

關(guān)閉progressDialog.

*

*/

protected

void

dismissProgressDialog()

{

if(mProgressDialog

!=

null)

{

mProgressDialog.dismiss();

}

}

}

程序運(yùn)行效果:

點(diǎn)擊下載按鈕,UI線程通過handler.sendMessage()向子線程發(fā)送消息,子線程收到消息后啟動數(shù)據(jù)下載(通過休眠線程模擬)。

下載完畢,子線程將下載數(shù)據(jù)返回主線程并顯示。

實(shí)例2:模擬子線程向主線程發(fā)送消息。

操作過程為:1.UI線程獲得用戶輸入的消息內(nèi)容。2.通過Handler將消息發(fā)送給子線程。3.子線程獲得消息并通過Toast將內(nèi)容打印。

主要代碼如下:public

class

MainActivity

extends

ActionBarActivity

{

private

EditText

mEditText;

private

Button

mButton;

private

Handler

mHandler;

private

Thread

mChildTread;

@Override

protected

void

onCreate(Bundle

savedInstanceState)

{

super.onCreate(savedInstanceState);

setContentView(R.layout.fragment_main);

mEditText

=

(EditText)

findViewById(R.id.etEditText);

mButton

=

(Button)

findViewById(R.id.btButton);

//

設(shè)置按鈕的點(diǎn)擊事件監(jiān)聽器

mButton.setOnClickListener(new

OnClickListener()

{

@Override

public

void

onClick(View

v)

{

Message

msg

=

new

Message();

msg.what

=

1;

msg.obj

=

mEditText.getText();

//將消息發(fā)送到子線程

mHandler.sendMessage(msg);

mEditText.setText("");

}

});

//啟動子線程進(jìn)行msg接收

mChildTread

=

new

ChildTread();

mChildTread.start();

}

/**

*

子線程為內(nèi)部類,可以直接訪問其外部類的mHandler變量

*

*/

class

ChildTread

extends

Thread

{

@Override

public

void

run()

{

//以下三步是handler

looper機(jī)制工作的固定模式

Looper.prepare();

mHandler

=

new

Handler()

{

public

void

handleMessage(Message

msg)

{

//

process

incoming

messages

here

switch

(msg.what)

{

case

1:

//子線程無權(quán)操作UI,只能通過Toast.makeText將收到的消息顯示

String

st

=

msg.obj.toString();

if

(st

==

null

||

st.equals(""))

st

=

"收到的消息內(nèi)容為空";

else

st

=

"收到來自主線程的消息:"

+

st;

Toast.makeText(MainActivity.this,

st,

6000).show();

break;

//可以添加其他情況,如傳輸錯誤

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論