最近學(xué)到用AsyncTask來處理有關(guān)網(wǎng)絡(luò)的操作。雖然代碼看上去不是很復(fù)雜,但仍有很多地方有疑惑。所以研讀了一下API文檔,在這里把我學(xué)到的和練習(xí)的代碼展示出來。如有錯(cuò)誤,歡迎指出!
一、關(guān)于AsyncTask的<Params, Progress, Result>
在創(chuàng)建AsyncTask的子類時(shí),必須給出這三個(gè)具體的類型值,尖括號(hào)是泛型的意思。我不太理解API文檔的解釋,但往下看
doInBackground(Params...)
publishProgress(Progress...)
onProgressUpdate(Progress...)
onPostExecute(Result)
可以知道它們都是傳遞給誰的,而圓括號(hào)里有...的參數(shù)可以理解為數(shù)組。
二、AsyncTask的四個(gè)步驟
1、onPreExecute():這個(gè)方法是在任務(wù)開始前進(jìn)行的,它由UI線程(主線程)調(diào)用,即可以進(jìn)行UI操作。在最后,我會(huì)給出Log的打印信息。
2、doInBackground(Params...):這個(gè)方法是onPreExecute()完成后,立即在后臺(tái)進(jìn)行的,用以執(zhí)行任務(wù),并將Result傳給onPostExecute(Result)。另外,在此期間,可以調(diào)用publishProgress(Progress...),這個(gè)方法能夠傳遞一些數(shù)據(jù)給onProgressUpdate(Progress...)。
3、onProgressUpdate(Progress...):在publishProgress(Progress...)被調(diào)用之后,此方法會(huì)由UI線程調(diào)用。所以利用publishProgress(Progress...)和onProgressUpdate(Progress...)就能夠做出在加載或讀取網(wǎng)絡(luò)數(shù)據(jù)時(shí)的等待或緩沖的UI效果。我在最后給出的效果圖有類似的功能。
4、onPostExecute(Result):在doInBackground(Params...)完成后,由UI線程調(diào)用,在這里處理Result。
三、我練習(xí)時(shí)寫的代碼
這是啟動(dòng)任務(wù),這里的execute(),可以傳進(jìn)多個(gè)參數(shù),如execute(url1,url2,url3)

然后在doInBackground中就可以處理多個(gè)任務(wù),publishProgress和onProgressUpdate也類似

四、最終效果圖
在確認(rèn)前,該TextView是空的,在確認(rèn)后,獲取的信息加載出來前,該TextView是顯示Loading的,可能gif做得不好,看上去有點(diǎn)怪。另外,在正常情況下,Loading是一閃而過的。我這里是斷點(diǎn)調(diào)試時(shí),截圖做的。

最后是上面介紹的四個(gè)方法的Log信息


以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時(shí)也希望多多支持武林網(wǎng)!
新聞熱點(diǎn)
疑難解答
圖片精選