第十一章 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——只有一個核心線程,解決線程同步問題。