<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁 > 醫(yī)療電子 > 設(shè)計應(yīng)用 > Android異步任務(wù)處理

          Android異步任務(wù)處理

          作者: 時間:2017-06-07 來源:網(wǎng)絡(luò) 收藏

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

          本文引用地址:http://www.ex-cimer.com/article/201706/350389.htm

          任務(wù)分析

          移動護理開發(fā)初期,對一些比較耗時的操作,我們沒有考慮異步任務(wù)處理的方式,造成程序假死的問題,用戶執(zhí)行某個操作后十幾秒程序才有反應(yīng),嚴重影響用戶體驗。現(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ù)庫訪問都會造成這種長時間等待。

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

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

          解決方案

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

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

          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的四個方法(至少重載一個)。詳細如下:

          AsyncTask的四個方法

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

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



          評論


          相關(guān)推薦

          技術(shù)專區(qū)

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();