Android Loader原始碼分析(二)
在Android Loader原始碼分析(一)中說道在start方法的最後,會呼叫mLoader.startLoading();
startLoading方法又會呼叫onStartLoading方法
//在Loader.java檔案中
public final void startLoading() {
mStarted = true;
mReset = false;
mAbandoned = false;
onStartLoading();
}
//在CursorLoader.java 檔案中
@Override
protected void onStartLoading() {
if (mCursor != null) {
deliverResult(mCursor);
}
if (takeContentChanged() || mCursor == null) {
forceLoad();
}
}
public void forceLoad() {
onForceLoad();
}
在資料還未載入時,mCursor為null,此時會執行forceLoad()
forceLoad()會執行onForceLoad(),此方法的實現是在AsyncTaskLoader.java中
@Override
protected void onForceLoad() {
super.onForceLoad();
cancelLoad();
mTask = new LoadTask();
if (DEBUG) Log.v(TAG, "Preparing load: mTask=" + mTask);
executePendingTask();
}
(1)、forceLoad()會呼叫onForceLoad()。而onForceLoad()中會新建LoadTask物件,然後執行executePendingTask()。
(2)、在executePendingTask()中會呼叫LoadTask物件的executeOnExecutor()。
void executePendingTask() {
if (mCancellingTask == null && mTask != null) {
if (mTask.waiting) {
mTask.waiting = false;
mHandler.removeCallbacks(mTask);
}
if (mUpdateThrottle > 0) {
long now = SystemClock.uptimeMillis();
if (now < (mLastLoadCompleteTime+mUpdateThrottle)) {
// Not yet time to do another load.
mTask.waiting = true;
mHandler.postAtTime(mTask, mLastLoadCompleteTime+mUpdateThrottle);
return;
}
}
mTask.executeOnExecutor(mExecutor, (Void[]) null);
}
}
//LoadTask的實現
final class LoadTask extends AsyncTask<Void, Void, D> implements Runnable {
private final CountDownLatch mDone = new CountDownLatch(1);
boolean waiting;
/* Runs on a worker thread */
@Override
protected D doInBackground(Void... params) {
try {
D data = AsyncTaskLoader.this.onLoadInBackground();
return data;
} catch (OperationCanceledException ex) {
if (!isCancelled()) {
throw ex;
}
return null;
}
}
/* Runs on the UI thread */
@Override
protected void onPostExecute(D data) {
try {
AsyncTaskLoader.this.dispatchOnLoadComplete(this, data);
} finally {
mDone.countDown();
}
}
/* Runs on the UI thread */
@Override
protected void onCancelled(D data) {
try {
AsyncTaskLoader.this.dispatchOnCancelled(this, data);
} finally {
mDone.countDown();
}
}
/* Runs on the UI thread, when the waiting task is posted to a handler.
* This method is only executed when task execution was deferred (waiting was true). */
@Override
public void run() {
waiting = false;
AsyncTaskLoader.this.executePendingTask();
}
/* Used for testing purposes to wait for the task to complete. */
public void waitForLoader() {
try {
mDone.await();
} catch (InterruptedException e) {
// Ignore
}
}
}
- LoadTask是AsyncTaskLoader的內部類。實際上,它是AsyncTask的子類,executeOnExecutor()會將任務提交到執行緒池中去執行;
- 這個被提交到執行緒池的任務會執行AsyncTask的doInBackground()。
- LoadTask的doInBackground()會呼叫onLoadInBackground()
- onLoadInBackground()方法會呼叫loadInBackground() 這個方法是在CursorLoader中實現的
/* Runs on a worker thread */
@Override
public Cursor loadInBackground() {
synchronized (this) {
if (isLoadInBackgroundCanceled()) {
throw new OperationCanceledException();
}
mCancellationSignal = new CancellationSignal();
}
try {
Cursor cursor = getContext().getContentResolver().query(mUri, mProjection, mSelection,
mSelectionArgs, mSortOrder, mCancellationSignal);
if (cursor != null) {
try {
// Ensure the cursor window is filled.
cursor.getCount();
cursor.registerContentObserver(mObserver);
} catch (RuntimeException ex) {
cursor.close();
throw ex;
}
}
return cursor;
} finally {
synchronized (this) {
mCancellationSignal = null;
}
}
}
- 當AsyncTask中的任務執行完時,會通過onPostExecute()反饋執行結果。
- onPostExecute()會執行dispatchOnLoadComplete(),而後者會呼叫deliverResult()來分發訊息。
- 最終會執行mListener.onLoadComplete()。mListener是什麼呢?它是我們在執行LoaderManager.java的start()函式時,通過mLoader.registerListener(mId, this)註冊到Loader上的。也就是說,mListener是LoaderManager中的LoaderInfo物件。
相關文章
- Android 開源專案原始碼解析 -->Android Universal Image Loader 原始碼分析(十四)Android原始碼
- Android 原始碼分析(二)handler 機制Android原始碼
- Android 原始碼分析之 AsyncTask 原始碼分析Android原始碼
- 【Android原始碼】Fragment 原始碼分析Android原始碼Fragment
- 【Android原始碼】Intent 原始碼分析Android原始碼Intent
- MyBatis原始碼分析(二)MyBatis原始碼
- 原始碼分析二:LeakCanary原始碼
- Backbone原始碼分析(二)原始碼
- YYCache 原始碼分析(二)原始碼
- vue-loader 原始碼解析系列之 整體分析Vue原始碼
- 【Android原始碼】AlertDialog 原始碼分析Android原始碼
- 原始碼|jdk原始碼之HashMap分析(二)原始碼JDKHashMap
- Android主流三方庫原始碼分析(二、深入理解Retrofit原始碼)Android原始碼
- redis原始碼分析(二)、redis原始碼分析之sds字串Redis原始碼字串
- Android Choreographer 原始碼分析Android原始碼
- Android RecycleView原始碼分析AndroidView原始碼
- Android——Handler原始碼分析Android原始碼
- 【Android原始碼】Handler 機制原始碼分析Android原始碼
- LinkedList原始碼分析(二)原始碼
- Volley原始碼分析(二)原始碼
- Webpack Loader原始碼導讀之css-loaderWeb原始碼CSS
- Webpack Loader原始碼導讀之less-loaderWeb原始碼
- Webpack Loader原始碼導讀之babel-loaderWeb原始碼Babel
- Android 原始碼分析之 EventBus 的原始碼解析Android原始碼
- Android原始碼分析--CircleImageView 原始碼詳解Android原始碼View
- 【PHP】CI框架原始碼分析核心檔案之Loader.phpPHP框架原始碼
- 基於Android5.0的Camera Framework原始碼分析 (二)AndroidFramework原始碼
- Android中IntentService原始碼分析AndroidIntent原始碼
- Android開源原始碼分析Android原始碼
- 【Android原始碼】LayoutInflater 分析Android原始碼
- Android JiaoZiVideoPlayer原始碼分析AndroidIDE原始碼
- Android的AsyncTask原始碼分析Android原始碼
- Android SharedPreferences 原始碼分析Android原始碼
- android view layout原始碼分析AndroidView原始碼
- Android 原始碼結構分析Android原始碼
- Android Volley原始碼分析Android原始碼
- Retrofit原始碼分析二 代理模式原始碼模式
- Tinker接入及原始碼分析(二)原始碼