Navigation之详细聊聊Fragment的实现原理,完美讲解内存缓存LruCache实现原理

scheduleCommit();

}

}

该方法最终调用到scheduleCommit()方法

2. FragmentManager.scheduleCommit()

void scheduleCommit() {

synchronized (mPendingActions) {

boolean postponeReady =

mPostponedTransactions != null && !mPostponedTransactions.isEmpty();

boolean pendingReady = mPendingActions.size() == 1;

if (postponeReady || pendingReady) {

mHost.getHandler().removeCallbacks(mExecCommit);

mHost.getHandler().post(mExecCommit);

updateOnBackPressedCallbackEnabled();

}

}

}

该方法最终通过Handler执行mExecCommit

3. FragmentManager.mExecCommit

private Runnable mExecCommit = new Runnable() {

@Override

public void run() {

execPendingActions(true);

}

};

该方法最终调用execPendingActions

4. FragmentManager.execPendingActions()

boolean execPendingActions(boolean allowStateLoss) {

ensureExecReady(allowStateLoss);

boolean didSomething = false;

while (generateOpsForPendingActions(mTmpRecords, mTmpIsPop)) {

mExecutingActions = true;

try {

removeRedundantOperationsAndExecute(mTmpRecords, mTmpIsPop);

} finally {

cleanupExec();

}

didSomething = true;

}

updateOnBackPressedCallbackEnabled();

doPendingDeferredStart();

mFragmentStore.burpActive();

return didSomething;

}

重点关注removeRedundantOperationsAndExecute(mTmpRecords, mTmpIsPop)

5. FragmentManager.removeRedundantOperationsAndExecute()

private void removeRedundantOperationsAndExecute(@NonNull ArrayList records,

@NonNull ArrayList isRecordPop) {

}

方法比较长省略代码,最终调用executeOpsTogether

6. FragmentManager.executeOpsTogether

private void executeOpsTogether(@NonNull ArrayList records,

@NonNull ArrayList isRecordPop, int startIndex, int endIndex) {

}

方法比较长省略代码,最终调用executeOps方法

7. FragmentManager.executeOps()

private static void executeOps(@NonNull ArrayList records,

@NonNull ArrayList isRecordPop, int startIndex, int endIndex) {

for (int i = startIndex; i < endIndex; i++) {

final BackStackRecord record = records.get(i);

final boolean isPop = isRecordPop.get(i);

if (isPop) {

record.bumpBackStackNesting(-1);

// Only execute the add operations at the end of

// all transactions.

boolean moveToState = i == (endIndex - 1);

record.executePopOps(moveToState);

} else {

record.bumpBackStackNesting(1);

record.executeOps();

}

}

}

该方法分为两种情况,入栈和出栈,对应commit()和FragmentManager.popBackStack()操作。

8. FragmentManager.executeOps()

void executeOps

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值