《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 嵌入式技術(shù) > 設(shè)計應(yīng)用 > 基于Android的移動護理異步任務(wù)處理解決方案
基于Android的移動護理異步任務(wù)處理解決方案
摘要: 移動護理系統(tǒng)開發(fā)采用異步處理的方式,可以縮短執(zhí)行操作的時間,避免UI線程阻塞。筆者介紹了采用異步處理方式開發(fā)移動護理程序的方法,并以移動護理中的病人列表異步任務(wù)處理為例進行分析。任務(wù)分析移動護理開發(fā)初期,對一些
Abstract:
Key words :

移動護理系統(tǒng)開發(fā)采用異步處理的方式,可以縮短執(zhí)行操作的時間,避免UI線程阻塞。筆者介紹了采用異步處理方式開發(fā)移動護理程序的方法,并以移動護理中的病人列表異步任務(wù)處理為例進行分析。

任務(wù)分析


移動護理開發(fā)初期,對一些比較耗時的操作,我們沒有考慮異步任務(wù)處理的方式,造成程序假死的問題,用戶執(zhí)行某個操作后十幾秒程序才有反應(yīng),嚴(yán)重影響用戶體驗。現(xiàn)在程序已支持異步任務(wù)處理,本文將簡單介紹移動護理中異步任務(wù)處理方式。

移動護理系統(tǒng)通過訪問網(wǎng)絡(luò)獲取數(shù)據(jù),在獲取數(shù)據(jù)過程中,訪問網(wǎng)絡(luò)和解析大量XML數(shù)據(jù)是不可避免的,這個過程需要耗費較長的時間,在我們未采用異步任務(wù)處理之前,執(zhí)行一個操作需要等待5-10秒甚至更長的時間,這樣程序就得等待很久才能正常操作。一般情況下,網(wǎng)絡(luò)連接、XML解析、數(shù)據(jù)庫訪問都會造成這種長時間等待。

原因很簡單,當(dāng)一個程序第一次啟動時,Android會同時啟動一個對應(yīng)的主線程,主線程主要負(fù)責(zé)處理與UI相關(guān)的事件,如:用戶的按鍵事件、用戶觸摸屏幕的事件等,并把相關(guān)的時間分發(fā)到對應(yīng)的組件進行處理,這個主線程也叫UI線程。我們之前的方式就是使用UI線程完成所有操作,包括UI事件處理、網(wǎng)絡(luò)連接、解析XML,這樣就會造成UI阻塞,表現(xiàn)為程序假死的現(xiàn)象。

為了解決程序假死的問題,我們必須使用異步任務(wù)處理,以確保在UI線程只處理UI事件,避免UI線程阻塞。

解決方案

Android 1.5已經(jīng)提供了一個工具類——AsyncTask,使用AsyncTask可以是創(chuàng)建需要與用戶界面交互的長時間運行的任務(wù)變得更簡單,所以我們使用它來處理網(wǎng)絡(luò)訪問、XML解析這兩個耗時操作來避免移動護理程序假死的問題。

AsyncTask 是一個抽象類,他提供了三個泛型參數(shù),詳細(xì)如下

         AsyncTask的三個泛型參數(shù)

1.       Param 任務(wù)執(zhí)行需要的參數(shù)

2.       Progress 后臺任務(wù)執(zhí)行的進度單位數(shù)據(jù)

3.       Result 后臺任務(wù)執(zhí)行最終返回的數(shù)據(jù)類型

注意:在設(shè)置參數(shù)時通暢是:String …params,這表示方法可以有0個或多個String類型的參數(shù);不使用參數(shù)時可設(shè)置為 Void…
        
使用AsyncTask類,必須重載AsyncTask的四個方法(至少重載一個)。詳細(xì)如下:

          AsyncTask的四個方法

1.       onPreExecute() 這個方法主要用于執(zhí)行一些預(yù)處理操作,它運行于UI線程,一般用來為后臺任務(wù)做一些準(zhǔn)備工作,如在界面上顯示一個進度條。

2.       doInBackground() 這個方法運行在后臺線程中,主要負(fù)責(zé)執(zhí)行那些很耗時的操作,如移動護理系統(tǒng)中的網(wǎng)絡(luò)連接、解析XML等操作。這個方法在onPreExecute()方法后執(zhí)行,該方法是抽象方法,也是AsyncTask的關(guān)鍵,所以該方法必須重載。另外,在這個方法中可以使用 publishProgress(Progress…)來改變當(dāng)前的進度值。

3.       doProgressUpdate(Progress…) 這個方法運行于UI線程。如果在doInBackground(Params…)中使用了publishProgress(Progress…),UI線程就會調(diào)用這個方法對進度條控件的進度值進行控制。


4.       onPostExecute(Result) 這個方法也運行于UI線程,在doInBackground(Params…)方法執(zhí)行后調(diào)用,該方法用于處理后臺任務(wù)執(zhí)行后返回的結(jié)果。

實例解析

以移動護理中的病人列表異步任務(wù)處理為例:
 
@Override

       protected void onPreExecute() {

           super.onPreExecute();

           // 獲取Wifi網(wǎng)絡(luò)連接狀態(tài)

           isNetWorkConnected = NetWorkActivity

                  .isNetworkAvailable(PatiListActivity.this);

           if (isNetWorkConnected)

              // 彈出提示對話框

              mDialog.show();

    }

onPreExecute()方法主要用于檢查網(wǎng)絡(luò)連接是否成功,如果成功則彈出進度條對話框。該方法運行于UI線程。

       @Override

       protected Object doInBackground(Object... arg0) {

           if (isNetWorkConnected) {

              // 獲取病人列表數(shù)據(jù)

              patientList = getPatiList();

           }

           return null;

       }

doInBackground()方法主要進行網(wǎng)絡(luò)訪問和XML解析,以獲取病人列表數(shù)據(jù),它運行于后臺線程。這里沒有調(diào)用 publishProgress() 方法,因為我們的進度條不需要顯示百分比,因此我們也沒必要重載doProgressUpdate(Progress…)方法。

       @Override

       protected void onPostExecute(Object result) {

           super.onPostExecute(result);

           if (isNetWorkConnected) {

              try {

                  // 加載頁面控件

                  drawPage();

                  // 關(guān)閉提示對話框

                  mDialog.dismiss();

              } catch (Exception e) {

                  e.printStackTrace();

                  Toast.makeText(PatiListActivity.this, errorMsg,

                         Toast.LENGTH_SHORT).show();

              }

           }

       }

OnPostExecute()運行于UI線程,通過doInBackgroud()方法獲取的病人列表來加載頁面控件,完成后關(guān)閉對話框。至此,異步任務(wù)處理整個過程結(jié)束。
 

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。