Android 使用AsyncTask 后監(jiān)聽異步加載完畢方法
出處:lsjiang 發(fā)布于:2011-08-25 11:00:25
Android一詞的本義指"機(jī)器人",同時也是Google于2007年11月5日宣布的基于Linux平臺的開源手機(jī)操作系統(tǒng)的名稱,該平臺由操作系統(tǒng)、中間件、用戶界面和應(yīng)用軟件組成,號稱是為移動終端打造的真正開放和完整的移動軟件。
Android以Java為編程語言,從接口到功能,都有層出不窮的變化,其中Activity等同于J2ME的MIDlet,一個 Activity 類(class)負(fù)責(zé)創(chuàng)建視窗(window),一個活動中的Activity就是在 foreground(前景)模式,背景運行的程序叫做Service.兩者之間通過由ServiceConnection和AIDL連結(jié),達(dá)到復(fù)數(shù)程序同時運行的效果。如果運行中的 Activity 全部畫面被其他 Activity 取代時,該 Activity 便被停止(STopped),甚至被系統(tǒng)清除(kill)。
AsyncTask 的使用方法網(wǎng)上有很多例子,使用起來也非常的方便。這里就不詳細(xì)說具體的使用方法了,同學(xué)可以Google 一下,很多。
場景模擬 當(dāng)我們在加載一個列表的時候。而這一操作可能會產(chǎn)生一個問題,比如你有一個列表更新數(shù)據(jù)庫使用到的是AsyncTask 異步操作的方式更新UI,而你的需求是當(dāng)我一進(jìn)來這個列表就統(tǒng)計這個列表的數(shù)據(jù)的數(shù)量或者讓某一行數(shù)據(jù)的狀態(tài)為選中狀態(tài)。之后會再操作UI.想法是對的,可能會報空指針。
這個問題的產(chǎn)生是,我們都知道代碼的執(zhí)行是自上而下執(zhí)行,當(dāng)你使用異步加載數(shù)據(jù)的時候,代碼讓你去執(zhí)行異步操作就不管了,異步加載數(shù)據(jù)還沒有結(jié)束還沒有對你的UI進(jìn)行更新,這些你的列表應(yīng)該是空的,而操作一個空的列表就會報空指針。
分析問題
使用過AsyncTask 的同學(xué)都知道一個異步加載數(shù)據(jù)少要重寫以下這兩個方法:
doInBackground 后臺執(zhí)行,比較耗時的操作都可以放在這里。注意這里不能直接操作UI.
onPostExecute 相當(dāng)于Handler 處理UI的方式,在這里面可以使用在doInBackground 得到的結(jié)果處理操作UI.
有必要的話你還得重寫以下這三個方法,但不是必須的:
onProgressUpdate 可以使用進(jìn)度條增加用戶體驗度。
onPreExecute 這里是終用戶調(diào)用Excute時的接口
onCancelled 用戶調(diào)用取消時,要做的操作
根據(jù)上面的思路,可以看出,終數(shù)據(jù)加載并顯示出來這一系列的操作都在onPostExecute 這個方法里面,那么如何監(jiān)聽所有UI都己經(jīng)在onPostExecute 里面處理完成了,再去執(zhí)行我們自己要操作呢?
解決問題
這里給出我自己解決這一問題的思路,有更好想法的朋友歡迎跟貼共同探討。
首先創(chuàng)建一個接口
private interface isLoadDataListener {
public void loadComplete();
}
聲明這一接口變量
private isLoadDataListener loadLisneter;
給接口賦值,得到接口對象
public void setLoadDataComplete(isLoadDataListener dataComplete) {
this.loadLisneter = dataComplete;
}
之后在AsyncTask 的onPostExecute處理UI完成后調(diào)用該接口,下面給出一個我以前項目使用到的AsyncTask 類:
class loadGridAsyncTask extends AsyncTask《Integer, Integer, AppsAdapter》 {
private int poindex;
public loadGridAsyncTask(int positionindex) {
this.poindex = positionindex;
}
@Override
protected AppsAdapter doInBackground(Integer… params) {
// TODO Auto-generated method stub
// mAppsModel.clear();
Cursor temp = dbHelper.queryPageById(poindex);
loadPage(mApps, temp);
temp.close();
return new AppsAdapter(STB.this, mAppsModel);
}
@Override
protected void onPostExecute(AppsAdapter result) {
gridViewExt itemGrid = (gridViewExt) viewFlipper
.getChildAt(poindex);
itemGrid.setColumnCount(pageColumnCount);
itemGrid.setAdapter(result);
if (loadLisneter != null) {
loadLisneter.loadComplete();
}
}
}
通過上面的代碼,我們就得到一個數(shù)據(jù)加載完成后返回的接口,接下來的問題就是我們利用這個接口來處理我們的UI了,比如讓某一UI選中,得到這個列表的UI數(shù)量等,看下面的代碼:
new loadGridAsyncTask(1)。execute();
setLoadDataComplete(new isLoadDataListener() {
@Override
public void loadComplete() {
// TODO Auto-generated method stub
//這里執(zhí)行你要的操作,當(dāng)UI更新完成后會自動調(diào)用這里面的代碼 }
});
版權(quán)與免責(zé)聲明
凡本網(wǎng)注明“出處:維庫電子市場網(wǎng)”的所有作品,版權(quán)均屬于維庫電子市場網(wǎng),轉(zhuǎn)載請必須注明維庫電子市場網(wǎng),http://www.hbjingang.com,違反者本網(wǎng)將追究相關(guān)法律責(zé)任。
本網(wǎng)轉(zhuǎn)載并注明自其它出處的作品,目的在于傳遞更多信息,并不代表本網(wǎng)贊同其觀點或證實其內(nèi)容的真實性,不承擔(dān)此類作品侵權(quán)行為的直接責(zé)任及連帶責(zé)任。其他媒體、網(wǎng)站或個人從本網(wǎng)轉(zhuǎn)載時,必須保留本網(wǎng)注明的作品出處,并自負(fù)版權(quán)等法律責(zé)任。
如涉及作品內(nèi)容、版權(quán)等問題,請在作品發(fā)表之日起一周內(nèi)與本網(wǎng)聯(lián)系,否則視為放棄相關(guān)權(quán)利。
- 數(shù)字電源控制與傳統(tǒng)模擬控制的深度對比2026/2/2 11:06:56
- 模擬信號調(diào)理電路技術(shù)設(shè)計與選型運維指南2025/12/30 10:08:16
- 運算放大器壓擺率的核心要點2025/9/5 16:27:55
- 深度剖析放大器穩(wěn)定系數(shù) K 與 Mu 的差異2025/9/2 16:44:05
- 什么是運算放大器失調(diào)電流2025/9/1 17:01:22
- 高速PCB信號完整性(SI)設(shè)計核心實操規(guī)范
- 鎖相環(huán)(PLL)中的環(huán)路濾波器:參數(shù)計算與穩(wěn)定性分析
- MOSFET反向恢復(fù)特性對系統(tǒng)的影響
- 電源IC在惡劣環(huán)境中的防護(hù)設(shè)計
- 連接器耐腐蝕性能測試方法
- PCB電磁兼容(EMC)設(shè)計與干擾抑制核心實操規(guī)范
- 用于相位噪聲測量的低通濾波器設(shè)計與本振凈化技術(shù)
- MOSFET在高頻開關(guān)中的EMI問題
- 電源IC在便攜式設(shè)備中的設(shè)計要點
- 連接器結(jié)構(gòu)設(shè)計常見問題分析









