Android開發藝術探索學習筆記(十一)

第十一章  Android的線程和線程池
java

  從用途上來講,線程分爲子線程和主線程,主線程主要處理和界面相關的事情,而子線程每每用於執行耗時的操做。AsyncTask,IntentService,HandlerThread均可以扮演線程的角色。數組

  AsyncTask封裝了線程池和Handler,主要是爲了方便開發者在主線程中更新UI。
網絡

  HandlerThread是一種具備消息循環的線程,在它的內部可使用Handler。
併發

  IntentService是一個服務,系統對其進行了封裝,使其能夠更方便的執行後臺任務,IntentService內部採用了HandlerThread來執行任務,當任務執行完畢後IntentService會自動退出,因爲其優先級較高,不容易被系統殺死。
異步

  11.1 主線程和子線程
性能

  主線程-處理界面交互相關的邏輯,運行四大組件以及處理它們和用戶的交互。
url

  子線程-執行耗時的任務,好比網絡請求,IO操做等。(3.0開始網絡訪問不能在主線程中,不然NetworkOnMainThreadException)
spa

  11.2 Android中的線程形態
線程

    11.2.1 AsyncTaskcode

    一種輕量級的異步任務類,在線城池中執行後臺任務,而後把執行的君度和最終的結果傳遞給主線程並在主線程中更新 UI,不建議用於執行特別耗時的任務。

    類聲明以下:

public abstract class AsyncTask<Params,Progress,Result>

 

     Params:參數類型;

    Progress:後臺任務執行進度類型;

    Result:後臺任務的返回結果類型。

    以上參數若是不須要傳遞能夠用Void代替。

    四個核心方法:

    (1)onPreExecute()——初始化的準備工做,主線程中執行;

    (2)doInBackground(Params...params)——執行異步任務,線程池中執行,執行過程當中經過publishProgress方法更新任務進度,publishProgress方法會觸發onProgressUpdate();

    (3)onProgressUpdate(Progress...values)——更新任務進度,主線程中執行。

    (4)onPostExecute(Result result)——異步任務返回結果,主線程執行。

    注意:...在java中表示參數不固定,數組型參數。

    執行異步任務經過如下方法:

new MyAsyncTask().execute(url1,url2,url3);

     AsyncTask使用的限制條件:

    (1)AsyncTask的類必須在主線程中加載(默認);

    (2)AsyncTask對象必須在主線程中建立;

    (3)execute方法必須在主線程中調用;

    (4)不要直接調用四種核心方法;

    (5)一個AsyncTask對象只能執行一次,即只能調用一次execute方法,不然會報運行時異常。

    11.2.3 HandlerThread

    HandlerThread繼承自Thread,是一種可使用handler 的Thread,具體使用場景是IntentService。

    11.2.4 IntentService

    IntentService一種特殊的Service,封裝了HandlerThread和Handler,用於執行後臺耗時的任務,任務執行後會自動中止;比較適合執行一些高優先級的後臺任務。

  11.3 Android中的線程池

  線程池的優勢:

  (1)重用線程池中的線程可減小性能開銷;

  (2)能有效控制線程池的最大併發數,避免大量線程之間因互相搶佔系統資源而致使的阻塞現象。

  (3)可以對線程進行簡單的管理,提供定時執行以及指定間隔循環執行等功能。

  Android 中的線程池都是直接或者間接經過配置ThreadPoolExecute來實現的。

  11.3.1 ThreadPoolExecute

  線程池的構造方法:

public ThreadPoolExecutor(int corePoolSize,int maximumPoolSize,long keepAliveTime,TileUnit unit,BlockingQueue<Runnable> workQueue,THreadFactory threadFactory)

  corePoolSize:核心線程數;

  maximumPoolSize:最大線程數;

  keepAliveTime:非核心線程閒置時的超時時長;

  unit:keepAliveTime的時間單位,如TimeUnit.MILLISECONDS(毫秒),TimeUnit.SECONDS(秒),TimeUnit.MINUTES(分鐘)

  workQueue:線程池中的任務隊列。

  threadFactory:線程工廠,用於爲線程池建立新線程。

  11.3.2 線程池的分類

  (1)FixedThreadPool——只有核心線程;

  (2)CachedThreadPool——只有非核心線程,適合執行大量的耗時較少的任務;

  (3)ScheduledThreadPool——核心線程數量固定,非核心線程數量無限制,用於執行定時任務和具備固定週期的重複任務;

  (4)SingleThreadExecutor——只有一個核心線程,解決線程同步問題。

相關文章
相關標籤/搜索