日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > Android >内容正文

Android

Android后台杀死系列之二:ActivityManagerService与App现场恢复机制

發布時間:2025/3/15 Android 50 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Android后台杀死系列之二:ActivityManagerService与App现场恢复机制 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本篇是Android后臺殺死系列的第二篇,主要講解ActivityMangerService是如何恢復被后臺殺死的進程的(基于4.3 ),在開篇?FragmentActivity及PhoneWindow后臺殺死處理機制?中,簡述了后臺殺死所引起的一些常見問題,還有Android系統控件對后臺殺死所做的一些兼容,以及onSaveInstance跟onRestoreInstance的作用于執行時機,最后說了如何應對后臺殺死,但是對于被后臺殺死的進程如何恢復的并沒有講解,本篇不涉及后臺殺死,比如LowmemoryKiller機制,只講述被殺死的進程如何恢復的。假設,一個應用被后臺殺死,再次從最近的任務列表喚起App時候,系統是如何處理的呢?有這么幾個問題可能需要解決:

  • Android框架層(AMS)如何知道App被殺死了

  • App被殺前的場景是如何保存的

  • 系統(AMS)如何恢復被殺的App

  • 被后臺殺死的App的啟動流程跟普通的啟動有什么區別

  • Activity的恢復順序為什么是倒序恢復

系統(AMS)如何知道App被殺死了

首先來看第一個問題,系統如何知道Application被殺死了,Android使用了Linux的oomKiller機制,只是簡單的做了個變種,采用分等級的LowmemoryKiller,但這個其實是內核層面的,LowmemoryKiller殺死進程后,不會像用戶空間發送通知,也就是說框架層的ActivityMangerService無法知道App是否被殺死,但是,只有知道App或者Activity是否被殺死,AMS(ActivityMangerService)才能正確的走喚起流程,那么AMS究竟是在什么時候知道App或者Activity被后臺殺死了呢?我們先看一下從最近的任務列表進行喚起的時候,究竟發生了什么。

從最近的任務列表或者Icon再次喚起App的流程

在系統源碼systemUi的包里,有個RecentActivity,這個其實就是最近的任務列表的入口,而其呈現界面是通過RecentsPanelView來展現的,點擊最近的App其執行代碼如下:

public void handleOnClick(View view) {ViewHolder holder = (ViewHolder)view.getTag();TaskDescription ad = holder.taskDescription;final Context context = view.getContext();final ActivityManager am = (ActivityManager)context.getSystemService(Context.ACTIVITY_SERVICE);Bitmap bm = holder.thumbnailViewImageBitmap;...// 關鍵點 1 如果TaskDescription沒有被主動關閉,正常關閉,ad.taskId就是>=0if (ad.taskId >= 0) {// This is an active task; it should just go to the foreground.am.moveTaskToFront(ad.taskId, ActivityManager.MOVE_TASK_WITH_HOME,opts);} else {Intent intent = ad.intent;intent.addFlags(Intent.FLAG_ACTIVITY_LAUNCHED_FROM_HISTORY| Intent.FLAG_ACTIVITY_TASK_ON_HOME| Intent.FLAG_ACTIVITY_NEW_TASK);try {context.startActivityAsUser(intent, opts,new UserHandle(UserHandle.USER_CURRENT));}... }

在上面的代碼里面,有個判斷ad.taskId >= 0,如果滿足這個條件,就通過moveTaskToFront喚起APP,那么ad.taskId是如何獲取的?recent包里面有各類RecentTasksLoader,這個類就是用來加載最近任務列表的一個Loader,看一下它的源碼,主要看一下加載:

@Overrideprotected Void doInBackground(Void... params) {// We load in two stages: first, we update progress with just the first screenful// of items. Then, we update with the rest of the itemsfinal int origPri = Process.getThreadPriority(Process.myTid());Process.setThreadPriority(Process.THREAD_PRIORITY_BACKGROUND);final PackageManager pm = mContext.getPackageManager();final ActivityManager am = (ActivityManager)mContext.getSystemService(Context.ACTIVITY_SERVICE);final List<ActivityManager.RecentTaskInfo> recentTasks =am.getRecentTasks(MAX_TASKS, ActivityManager.RECENT_IGNORE_UNAVAILABLE);....TaskDescription item = createTaskDescription(recentInfo.id,recentInfo.persistentId, recentInfo.baseIntent,recentInfo.origActivity, recentInfo.description);....}

可以看到,其實就是通過ActivityManger的getRecentTasks向AMS請求最近的任務信息,然后通過createTaskDescription創建TaskDescription,這里傳遞的recentInfo.id其實就是TaskDescription的taskId,來看一下它的意義:

public List<ActivityManager.RecentTaskInfo> getRecentTasks(int maxNum,int flags, int userId) {... IPackageManager pm = AppGlobals.getPackageManager();final int N = mRecentTasks.size();...for (int i=0; i<N && maxNum > 0; i++) {TaskRecord tr = mRecentTasks.get(i);if (i == 0|| ((flags&ActivityManager.RECENT_WITH_EXCLUDED) != 0)|| (tr.intent == null)|| ((tr.intent.getFlags()&Intent.FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS) == 0)) {ActivityManager.RecentTaskInfo rti= new ActivityManager.RecentTaskInfo();rti.id = tr.numActivities > 0 ? tr.taskId : -1;rti.persistentId = tr.taskId;rti.baseIntent = new Intent(tr.intent != null ? tr.intent : tr.affinityIntent);if (!detailed) {rti.baseIntent.replaceExtras((Bundle)null);}

可以看出RecentTaskInfo的id是由TaskRecord決定的,如果TaskRecord中numActivities > 0就去TaskRecord的Id,否則就取-1,這里的numActivities其實就是TaskRecode中記錄的ActivityRecord的數目,更具體的細節可以自行查看ActivityManagerService及ActivityStack,那么這里就容易解釋了,只要是存活的APP、或者被LowmemoryKiller殺死的APP,其AMS的ActivityRecord是完整保存的,這就是恢復的依據。RecentActivity獲取的數據其實就是AMS中的翻版,RecentActivity并不知道將要喚起的APP是否是存活的,只要TaskRecord告訴RecentActivity是存貨的,那么久直接走喚起流程,也就是通過ActivityManager的moveTaskToFront喚起App,至于后續的工作,就完全交給AMS來處理。現看一下到這里的流程圖:

整個APP被后臺殺死的情況下AMS是如何恢復現場的

AMS與客戶端的通信是通過Binder來進行的,并且通信是”全雙工“的,且互為客戶端跟服務器,也就說AMS向客戶端發命令的時候,AMS是客戶端,反之亦然。注意?Binder有個訃告的功能的:如果基于Binder通信的服務端(S)如果掛掉了,客戶端(C)能夠收到Binder驅動發送的一份訃告,告知客戶端Binder服務掛了,可以把Binder驅動看作是第三方不死郵政機構,專門向客戶端發偶像死亡通知。對于APP被異常殺死的情況下,這份訃告是發送給AMS的,AMS在收到通知后,就會針對APP被異常殺死的情況作出整理,這里牽扯到Binder驅動的代碼有興趣可以自己翻一下。之類直接沖訃告接受后端處理邏輯來分析,在AMS源碼中,入口其實就是appDiedLocked.

final void appDiedLocked(ProcessRecord app, int pid,IApplicationThread thread) {...if (app.pid == pid && app.thread != null &&app.thread.asBinder() == thread.asBinder()) {boolean doLowMem = app.instrumentationClass == null;關鍵點1 handleAppDiedLocked(app, false, true);// 如果是被后臺殺了,怎么處理關鍵點2 if (doLowMem) {boolean haveBg = false;for (int i=mLruProcesses.size()-1; i>=0; i--) {ProcessRecord rec = mLruProcesses.get(i);if (rec.thread != null && rec.setAdj >= ProcessList.HIDDEN_APP_MIN_ADJ) {haveBg = true;break;}}if (!haveBg) {<!--如果被LowmemoryKiller殺了,就說明內存緊張,這個時候就會通知其他后臺APP,小心了,趕緊釋放資源-->EventLog.writeEvent(EventLogTags.AM_LOW_MEMORY, mLruProcesses.size());long now = SystemClock.uptimeMillis();for (int i=mLruProcesses.size()-1; i>=0; i--) {ProcessRecord rec = mLruProcesses.get(i);if (rec != app && rec.thread != null &&(rec.lastLowMemory+GC_MIN_INTERVAL) <= now) {if (rec.setAdj <= ProcessList.HEAVY_WEIGHT_APP_ADJ) {rec.lastRequestedGc = 0;} else {rec.lastRequestedGc = rec.lastLowMemory;}rec.reportLowMemory = true;rec.lastLowMemory = now;mProcessesToGc.remove(rec);addProcessToGcListLocked(rec);}}mHandler.sendEmptyMessage(REPORT_MEM_USAGE);<!--縮減資源-->scheduleAppGcsLocked();}}}...}

先看關鍵點1:在進程被殺死后,AMS端要選擇性清理進程相關信息,清理后,再根據是不是內存低引起的后臺殺死,決定是不是需要清理其他后臺進程。接著看handleAppDiedLocked如何清理的,這里有重建時的依據:ActivityRecord不清理,但是為它設置個APP未綁定的標識

private final void handleAppDiedLocked(ProcessRecord app,boolean restarting, boolean allowRestart) {關鍵點1cleanUpApplicationRecordLocked(app, restarting, allowRestart, -1);...關鍵點2// Remove this application's activities from active lists.boolean hasVisibleActivities = mMainStack.removeHistoryRecordsForAppLocked(app);app.activities.clear();...關鍵點3if (!restarting) {if (!mMainStack.resumeTopActivityLocked(null)) {// If there was nothing to resume, and we are not already// restarting this process, but there is a visible activity that// is hosted by the process... then make sure all visible// activities are running, taking care of restarting this// process.if (hasVisibleActivities) {mMainStack.ensureActivitiesVisibleLocked(null, 0);}}} }

看關鍵點1,cleanUpApplicationRecordLocked,主要負責清理一些Providers,receivers,service之類的信息,并且在清理過程中根據配置的一些信息決定是否需要重建進程并啟動,關鍵點2 就是關系到喚起流程的判斷,關鍵點3,主要是被殺的進程是否是當前前臺進程,如果是,需要重建,并立即顯示:先簡單看cleanUpApplicationRecordLocked的清理流程

private final void cleanUpApplicationRecordLocked(ProcessRecord app,boolean restarting, boolean allowRestart, int index) {<!--清理service-->mServices.killServicesLocked(app, allowRestart);...boolean restart = false;<!--清理Providers.-->if (!app.pubProviders.isEmpty()) {Iterator<ContentProviderRecord> it = app.pubProviders.values().iterator();while (it.hasNext()) {ContentProviderRecord cpr = it.next();。。。app.pubProviders.clear();} ...<!--清理receivers.-->// Unregister any receivers.if (app.receivers.size() > 0) {Iterator<ReceiverList> it = app.receivers.iterator();while (it.hasNext()) {removeReceiverLocked(it.next());}app.receivers.clear();}... 關鍵點1,進程是夠需要重啟,if (restart && !app.isolated) {// We have components that still need to be running in the// process, so re-launch it.mProcessNames.put(app.processName, app.uid, app);startProcessLocked(app, "restart", app.processName);} ... }

從關鍵點1就能知道,這里是隱藏了進程是否需要重啟的邏輯,比如一個Service設置了START_STICKY,被殺后,就需要重新喚起,這里也是流氓軟件肆虐的原因。再接著看mMainStack.removeHistoryRecordsForAppLocked(app),對于直觀理解APP重建,這句代碼處于核心的地位,

boolean removeHistoryRecordsForAppLocked(ProcessRecord app) {...while (i > 0) {i--;ActivityRecord r = (ActivityRecord)mHistory.get(i);if (r.app == app) {boolean remove;<!--關鍵點1-->if ((!r.haveState && !r.stateNotNeeded) || r.finishing) {remove = true;} else if (r.launchCount > 2 &&remove = true;} else {//一般來講,走falseremove = false;}<!--關鍵點2-->if (remove) {...removeActivityFromHistoryLocked(r);} else {...r.app = null;...}return hasVisibleActivities; }

在Activity跳轉的時候,準確的說,在stopActivity之前,會保存Activity的現場,這樣在AMS端r.haveState==true,也就是說,其ActivityRecord不會被從ActivityStack中移除,同時ActivityRecord的app字段被置空,這里在恢復的時候,是決定resume還是重建的關鍵。接著往下看moveTaskToFrontLocked,這個函數在ActivityStack中,主要管理ActivityRecord棧的,所有start的Activity都在ActivityStack中保留一個ActivityRecord,這個也是AMS管理Activiyt的一個依據,最終moveTaskToFrontLocked會調用resumeTopActivityLocked來喚起Activity,AMS獲取即將resume的Activity信息的方式主要是通過ActivityRecord,它并不知道Activity本身是否存活,獲取之后,AMS在喚醒Activity的環節才知道App或者Activity被殺死,具體看一下resumeTopActivityLocked源碼:

final boolean resumeTopActivityLocked(ActivityRecord prev, Bundle options) {...關鍵點1 if (next.app != null && next.app.thread != null) { ...} else {// Whoops, need to restart this activity!...startSpecificActivityLocked(next, true, true);}return true;}

看關鍵點1的判斷條件,由于已經將ActivityRecord的app字段置空,AMS就知道了這個APP或者Activity被異常殺死過,因此,就會走startSpecificActivityLocked進行重建。 其實仔細想想很簡單,對于主動調用finish的,AMS并不會清理掉ActivitRecord,在喚起APP的時候,如果AMS檢測到APP還存活,就走scheduleResumeActivity進行喚起上一個Activity,但是如果APP或者Activity被異常殺死過,那么AMS就通過startSpecificActivityLocked再次將APP重建,并且將最后的Activity重建。

APP存活,但是Activity被后臺殺死的情況下AMS是如何恢復現場的

還有一種可能,APP沒有被kill,但是Activity被Kill掉了,這個時候會怎么樣?首先,Activity的管理是一定通過AMS的,Activity的kill一定是是AMS操刀的,是有記錄的,嚴格來說,這種情況并不屬于后臺殺死,因為這屬于AMS正常的管理,在可控范圍,比如打開了開發者模式中的“不保留活動”,這個時候,雖然會殺死Activity,但是仍然保留了ActivitRecord,所以再喚醒,或者回退的的時候仍然有跡可循,看一下ActivityStack的Destroy回調代碼,

final boolean destroyActivityLocked(ActivityRecord r,boolean removeFromApp, boolean oomAdj, String reason) {...if (hadApp) {...boolean skipDestroy = false;try {關鍵代碼 1r.app.thread.scheduleDestroyActivity(r.appToken, r.finishing,r.configChangeFlags);...if (r.finishing && !skipDestroy) {if (DEBUG_STATES) Slog.v(TAG, "Moving to DESTROYING: " + r+ " (destroy requested)");r.state = ActivityState.DESTROYING;Message msg = mHandler.obtainMessage(DESTROY_TIMEOUT_MSG);msg.obj = r;mHandler.sendMessageDelayed(msg, DESTROY_TIMEOUT);} else {關鍵代碼 2r.state = ActivityState.DESTROYED;if (DEBUG_APP) Slog.v(TAG, "Clearing app during destroy for activity " + r);r.app = null;}} return removedFromHistory;}

這里有兩個關鍵啊你單,1是告訴客戶端的AcvitityThread清除Activity,2是標記如果AMS自己非正常關閉的Activity,就將ActivityRecord的state設置為ActivityState.DESTROYED,并且清空它的ProcessRecord引用:r.app = null。這里是喚醒時候的一個重要標志,通過這里AMS就能知道Activity被自己異常關閉了,設置ActivityState.DESTROYED是為了讓避免后面的清空邏輯。

final void activityDestroyed(IBinder token) {synchronized (mService) {final long origId = Binder.clearCallingIdentity();try {ActivityRecord r = ActivityRecord.forToken(token);if (r != null) {mHandler.removeMessages(DESTROY_TIMEOUT_MSG, r);}int index = indexOfActivityLocked(r);if (index >= 0) {1 <!--這里會是否從history列表移除ActivityRecord-->if (r.state == ActivityState.DESTROYING) {cleanUpActivityLocked(r, true, false);removeActivityFromHistoryLocked(r);}}resumeTopActivityLocked(null);} finally {Binder.restoreCallingIdentity(origId);}} }

看代碼關鍵點1,只有r.state == ActivityState.DESTROYING的時候,才會移除ActivityRecord,但是對于不非正常finish的Activity,其狀態是不會被設置成ActivityState.DESTROYING,是直接跳過了ActivityState.DESTROYING,被設置成了ActivityState.DESTROYED,所以不會removeActivityFromHistoryLocked,也就是保留了ActivityRecord現場,好像也是依靠異常來區分是否是正常的結束掉Activity。這種情況下是如何啟動Activity的呢? 通過上面兩點分析,就知道了兩個關鍵點

  • ActivityRecord沒有動HistoryRecord列表中移除

  • ActivityRecord 的ProcessRecord字段被置空,r.app = null

  • 這樣就保證了在resumeTopActivityLocked的時候,走startSpecificActivityLocked分支

    final boolean resumeTopActivityLocked(ActivityRecord prev, Bundle options) {...if (next.app != null && next.app.thread != null) { ...} else {// Whoops, need to restart this activity!...startSpecificActivityLocked(next, true, true);}return true;}

    到這里,AMS就知道了這個APP或者Activity是不是被異常殺死過,從而,決定是走resume流程還是restore流程。

    App被殺前的場景是如何保存的: 新Activity啟動跟舊Activity的保存

    App現場的保存流程相對是比較簡單的,入口基本就是startActivity的時候,只要是界面的跳轉基本都牽扯到Activity的切換跟當前Activity場景的保存:先畫個簡單的圖形,開偏里面講FragmentActivity的時候,簡單說了一些onSaveInstance的執行時機,這里詳細看一下AMS是如何管理這些跳轉以及場景保存的,模擬場景:Activity A 啟動Activity B的時候,這個時候A不可見,可能會被銷毀,需要保存A的現場,這個流程是什么樣的:簡述如下

    • ActivityA startActivity ActivityB

    • ActivityA pause

    • ActivityB create

    • ActivityB start

    • ActivityB resume

    • ActivityA onSaveInstance

    • ActivityA stop

    流程大概是如下樣子:

    現在我們通過源碼一步一步跟一下,看看AMS在新Activity啟動跟舊Activity的保存的時候,到底做了什么:跳過簡單的startActivity,直接去AMS中去看

    ActivityManagerService

    public final int startActivityAsUser(IApplicationThread caller, String callingPackage,Intent intent, String resolvedType, IBinder resultTo,String resultWho, int requestCode, int startFlags,String profileFile, ParcelFileDescriptor profileFd, Bundle options, int userId) {enforceNotIsolatedCaller("startActivity");...return mMainStack.startActivityMayWait(caller, -1, callingPackage, intent, resolvedType,resultTo, resultWho, requestCode, startFlags, profileFile, profileFd,null, null, options, userId); }

    ActivityStack

    final int startActivityMayWait(IApplicationThread caller, int callingUid,int res = startActivityLocked(caller, intent, resolvedType,aInfo, resultTo, resultWho, requestCode, callingPid, callingUid,callingPackage, startFlags, options, componentSpecified, null);。。。 }

    這里通過startActivityMayWait啟動新的APP,或者新Activity,這里只看簡單的,至于從桌面啟動App的流程,可以去參考更詳細的文章,比如老羅的startActivity流程,大概就是新建ActivityRecord,ProcessRecord之類,并加入AMS中相應的堆棧等,resumeTopActivityLocked是界面切換的統一入口,第一次進來的時候,由于ActivityA還在沒有pause,因此需要先暫停ActivityA,這些完成后,

    ActivityStack

    final boolean resumeTopActivityLocked(ActivityRecord prev, Bundle options) { ...<!--必須將當前Resume的Activity設置為pause 然后stop才能繼續-->// We need to start pausing the current activity so the top one// can be resumed...if (mResumedActivity != null) { if (next.app != null && next.app.thread != null) {mService.updateLruProcessLocked(next.app, false);}startPausingLocked(userLeaving, false);return true;}.... }

    其實這里就是暫停ActivityA,AMS通過Binder告訴ActivityThread需要暫停的ActivityA,ActivityThread完成后再通過Binder通知AMS,AMS會開始resume ActivityB,

    private final void startPausingLocked(boolean userLeaving, boolean uiSleeping) {if (prev.app != null && prev.app.thread != null) {...try {prev.app.thread.schedulePauseActivity(prev.appToken, prev.finishing,userLeaving, prev.configChangeFlags);

    ActivityThread

    private void handlePauseActivity(IBinder token, boolean finished,boolean userLeaving, int configChanges) {ActivityClientRecord r = mActivities.get(token);if (r != null) {...performPauseActivity(token, finished, r.isPreHoneycomb());...// Tell the activity manager we have paused.try {ActivityManagerNative.getDefault().activityPaused(token);} catch (RemoteException ex) {}}}

    AMS收到ActivityA發送過來的pause消息之后,就會喚起ActivityB,入口還是resumeTopActivityLocked,喚醒B,之后還會A給進一步stop掉,這個時候就牽扯到現場的保存,

    ActivityStack

    private final void completePauseLocked() {if (!mService.isSleeping()) {resumeTopActivityLocked(prev);} else {... }

    ActivityB如何啟動的,本文不關心,只看ActivityA如何保存現場的,ActivityB起來后,會通過ActivityStack的stopActivityLocked去stop ActivityA,

    private final void stopActivityLocked(ActivityRecord r) {...if (mMainStack) {r.app.thread.scheduleStopActivity(r.appToken, r.visible, r.configChangeFlags);...}

    回看APP端,看一下ActivityThread中的調用:首先通過callActivityOnSaveInstanceState,將現場保存到Bundle中去,

    private void performStopActivityInner(ActivityClientRecord r,StopInfo info, boolean keepShown, boolean saveState) {...// Next have the activity save its current state and managed dialogs...if (!r.activity.mFinished && saveState) {if (r.state == null) {state = new Bundle();state.setAllowFds(false);mInstrumentation.callActivityOnSaveInstanceState(r.activity, state);r.state = state;。。。}

    之后,通過ActivityManagerNative.getDefault().activityStopped,通知AMS Stop動作完成,在通知的時候,還會將保存的現場數據帶過去。

    private static class StopInfo implements Runnable {ActivityClientRecord activity;Bundle state;Bitmap thumbnail;CharSequence description;@Override public void run() {// Tell activity manager we have been stopped.try {ActivityManagerNative.getDefault().activityStopped(activity.token, state, thumbnail, description);} catch (RemoteException ex) {}} }

    通過上面流程,AMS不僅啟動了新的Activity,同時也將上一個Activity的現場進行了保存,及時由于種種原因上一個Actiivity被殺死,在回退,或者重新喚醒的過程中AMS也能知道如何喚起Activiyt,并恢復。

    現在解決兩個問題,1、如何保存現場,2、AMS怎么判斷知道APP或者Activity是否被異常殺死,那么就剩下最后一個問題了,AMS如何恢復被異常殺死的APP或者Activity呢。

    整個Application被后臺殺死情況下的恢復邏輯

    其實在講解AMS怎么判斷知道APP或者Activity是否被異常殺死的時候,就已經涉及了恢復的邏輯,也知道了一旦AMS知道了APP被后臺殺死了,那就不是正常的resuem流程了,而是要重新laucher,先來看一下整個APP被干掉的會怎么處理,看resumeTopActivityLocked部分,從上面的分析已知,這種場景下,會因為Binder通信拋異常走異常分支,如下:

    final boolean resumeTopActivityLocked(ActivityRecord prev, Bundle options) {....if (next.app != null && next.app.thread != null) {if (DEBUG_SWITCH) Slog.v(TAG, "Resume running: " + next);... try {...} catch (Exception e) {// Whoops, need to restart this activity!這里是知道整個app被殺死的Slog.i(TAG, "Restarting because process died: " + next);next.state = lastState;mResumedActivity = lastResumedActivity;Slog.i(TAG, "Restarting because process died: " + next);startSpecificActivityLocked(next, true, false);return true;}

    從上面的代碼可以知道,其實就是走startSpecificActivityLocked,這根第一次從桌面喚起APP沒多大區別,只是有一點需要注意,那就是這種時候啟動的Activity是有上一次的現場數據傳遞過得去的,因為上次在退到后臺的時候,所有Activity界面的現場都是被保存了,并且傳遞到AMS中去的,那么這次的恢復啟動就會將這些數據返回給ActivityThread,再來仔細看一下performLaunchActivity里面關于恢復的特殊處理代碼:

    private Activity performLaunchActivity(ActivityClientRecord r, Intent customIntent) { ActivityInfo aInfo = r.activityInfo;Activity activity = null;try {java.lang.ClassLoader cl = r.packageInfo.getClassLoader();activity = mInstrumentation.newActivity(cl, component.getClassName(), r.intent);StrictMode.incrementExpectedActivityCount(activity.getClass());r.intent.setExtrasClassLoader(cl);if (r.state != null) {r.state.setClassLoader(cl);}} catch (Exception e) {...}try {Application app = r.packageInfo.makeApplication(false, mInstrumentation);...關鍵點 1 mInstrumentation.callActivityOnCreate(activity, r.state);...r.activity = activity;r.stopped = true;if (!r.activity.mFinished) {activity.performStart();r.stopped = false;}關鍵點 1 if (!r.activity.mFinished) {if (r.state != null) {mInstrumentation.callActivityOnRestoreInstanceState(activity, r.state);}}if (!r.activity.mFinished) {activity.mCalled = false;mInstrumentation.callActivityOnPostCreate(activity, r.state);...}

    看一下關鍵點1跟2,先看關鍵點1,mInstrumentation.callActivityOnCreate會回調Actiivyt的onCreate,這個函數里面其實主要針對FragmentActivity做一些Fragment恢復的工作,ActivityClientRecord中的r.state是AMS傳給APP用來恢復現場的,正常啟動的時候,這些都是null。再來看關鍵點2 ,在r.state != null非空的時候執行mInstrumentation.callActivityOnRestoreInstanceState,這個函數默認主要就是針對Window做一些恢復工作,比如ViewPager恢復之前的顯示位置等,也可以用來恢復用戶保存數據。

    Application沒有被后臺殺死,Activity被殺死的恢復

    打開開發者模式”不保留活動“,就是這種場景,在上面的分析中,知道,AMS主動異常殺死Activity的時候,將AcitivityRecord的app字段置空,因此resumeTopActivityLocked同整個APP被殺死不同,會走下面的分支

    final boolean resumeTopActivityLocked(ActivityRecord prev, Bundle options) {...if (next.app != null && next.app.thread != null) { ...} else {關鍵點 1 只是重啟Activity,可見這里其實是知道的,進程并沒死,// Whoops, need to restart this activity!startSpecificActivityLocked(next, true, true);}return true; }

    雖然不太一樣,但是同樣走startSpecificActivityLocked流程,只是不新建APP進程,其余的都是一樣的,不再講解。到這里,我們應該就了解了,

    • Android是如何在預防的情況下保存場景

    • AMS如何知道APP是否被后臺殺死

    • AMS如何根據ActivityStack重建APP被殺死時的場景

    到這里ActivityManagerService恢復APP場景的邏輯就應該講完了。再碎碎念一些問題,可能是一些面試的點。

    • 主動清除最近任務跟異常殺死的區別:ActivityStack是否正常清楚

    • 恢復的時候,為什么是倒序恢復:因為這是ActivityStack中的HistoryRecord中棧的順序,嚴格按照AMS端來

    • 一句話概括Android后臺殺死恢復原理:Application進程被Kill,但現場被AMS保存,AMS能根據保存恢復Application現場

    僅供參考,歡迎指正

    參考文檔

    Android應用程序啟動過程源代碼分析?
    Android Framework架構淺析之【近期任務】?
    Android Low Memory Killer介紹?
    Android開發之InstanceState詳解?
    對Android近期任務列表(Recent Applications)的簡單分析?
    Android——內存管理-lowmemorykiller 機制?
    Android 操作系統的內存回收機制?
    Android LowMemoryKiller原理分析?
    Android進程生命周期與ADJ?
    Linux下/proc目錄簡介?
    startActivity啟動過程分析 精
    Activity銷毀流程


    原文地址:https://segmentfault.com/a/1190000008085504

    總結

    以上是生活随笔為你收集整理的Android后台杀死系列之二:ActivityManagerService与App现场恢复机制的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    天堂av网站 | 久草五月 | 欧美美女视频在线观看 | 欧美日本一二三 | 五月婷婷免费 | 99热在线国产精品 | 久草在线欧美 | 天天躁日日躁狠狠躁av麻豆 | 国产日韩欧美在线 | 国产精品美女久久久久久免费 | 激情伊人五月天久久综合 | 久久久久亚洲精品成人网小说 | 一区二区三区在线免费播放 | 成人一级免费视频 | 亚洲欧美经典 | 色综合激情网 | 国产一区在线视频观看 | 色婷婷丁香 | av在线h | 亚洲精品456在线播放乱码 | 91高清完整版在线观看 | 久久午夜色播影院免费高清 | av色一区 | 国产日韩视频在线播放 | av在线免费在线 | 97在线影视 | 日韩av中文字幕在线 | 亚洲最新视频在线播放 | 亚洲国产成人久久 | 天海翼一区二区三区免费 | 国产精品久久久久久久久久免费 | 狠狠色伊人亚洲综合成人 | 九九精品无码 | 免费看国产一级片 | 国产精品成人免费精品自在线观看 | 亚洲欧美日韩国产一区二区三区 | 人人搞人人爽 | 美女免费视频一区二区 | 8090yy亚洲精品久久 | 国产免费a | 日本三级在线观看中文字 | av福利在线免费观看 | 一级片视频在线 | 伊人国产视频 | 四虎在线观看 | 国产精品色婷婷视频 | 在线观看色网站 | 久草观看 | 国产v在线 | 91传媒在线 | 日韩在线网址 | 久久久久99精品成人片三人毛片 | 中文字幕av最新 | 91精品国产91久久久久久三级 | 在线观看免费91 | 亚州欧美精品 | 黄色官网在线观看 | 婷婷性综合 | 92国产精品久久久久首页 | 久久久久欠精品国产毛片国产毛生 | 激情综合五月 | 一区二区三区四区五区在线视频 | 国产美女黄网站免费 | 国产剧在线观看片 | 少妇bbw搡bbbb搡bbb | 丁香5月婷婷 | 天天玩夜夜操 | 亚洲视频免费在线观看 | 97在线免费 | 久久国产剧场电影 | 国产成人精品一区二区三区免费 | 色吊丝av中文字幕 | 日韩av中文在线 | 免费一级片在线 | 国产精品3 | 97国产精品一区二区 | 在线免费黄色毛片 | 国产69精品久久99不卡的观看体验 | 在线观看日韩免费视频 | 国产精品黄色影片导航在线观看 | 特级毛片网站 | 亚洲精品乱码久久久一二三 | 欧美日韩国产一区二区三区在线观看 | 91精品视频一区二区三区 | 久久久久成人精品 | 天天干天天射天天插 | 激情欧美国产 | 久久久久黄| 国产成人精品午夜在线播放 | 免费看黄网站在线 | 成年人免费看av | 精品黄色片 | 日韩理论电影在线观看 | 九九免费精品视频 | 国产成人av在线影院 | 99精品国产免费久久久久久下载 | 国产精品自产拍在线观看蜜 | 久久久蜜桃 | 久久国产精品精品国产色婷婷 | 国产精品一区免费在线观看 | 日本中文字幕在线 | 日韩伦理片hd | 久久精品综合一区 | 久久精品国产免费看久久精品 | 久久国精品 | 精品欧美一区二区精品久久 | 国产黄a三级三级三级三级三级 | 久久av免费观看 | 日韩精品播放 | 一二三区高清 | 国产成人精品一区在线 | 视频一区在线免费观看 | 最新日韩视频 | 久久婷婷丁香 | 日本公妇在线观看 | 黄色aa久久 | 色五月成人 | 久久国产精品影片 | 欧美日韩3p | 亚洲视频免费视频 | 欧美电影在线观看 | 激情综合五月网 | 99精品国自产在线 | 99日韩精品| 97超碰国产在线 | 一区二区成人国产精品 | 中文字幕资源在线观看 | 久久久国产视频 | 国产视频久 | 欧美伦理一区二区三区 | 亚洲一区免费在线 | 欧美日韩在线观看一区 | 国产高清av在线播放 | av成人资源 | 国产剧情一区二区 | 激情久久网| 青青河边草手机免费 | 免费看污在线观看 | 99视频精品视频高清免费 | 日韩视频在线不卡 | 久久久久久久久久国产精品 | 国产精品99久久免费黑人 | 9999免费视频| 国产免费视频一区二区裸体 | 激情综合色综合久久 | 久久综合九色综合97_ 久久久 | 中文一区二区三区在线观看 | 蜜臀av性久久久久av蜜臀三区 | 91九色在线观看视频 | 91精品国产成 | 国产不卡av在线 | 一区二区三区在线电影 | 在线观看精品一区 | 国产手机av | 日日夜夜操av | 久久免费激情视频 | 久久久久久欧美二区电影网 | 天天综合成人网 | 日韩高清www | 在线观看91视频 | 93久久精品日日躁夜夜躁欧美 | 亚州视频在线 | 视频一区二区三区视频 | 在线天堂视频 | 另类老妇性bbwbbw高清 | 一区二区三区中文字幕在线观看 | 免费网址你懂的 | 韩国三级一区 | av色一区 | 午夜久久成人 | av天天色 | 久久,天天综合 | 久久99精品久久久久久清纯直播 | 国产精品av久久久久久无 | 麻豆成人在线观看 | 欧美视频18| 91精品1区| 天堂av在线网址 | 国产成人免费av电影 | 韩国三级一区 | 久久久久免费精品 | 国产精品九九九九九九 | 婷婷激情综合五月天 | 贫乳av女优大全 | 久久午夜色播影院免费高清 | 天天色天天射综合网 | 精品一区电影 | 深夜精品福利 | 观看免费av | 亚洲黄色片在线 | 日日夜夜天天操 | 久久99视频| 日韩欧美不卡 | 天天曰视频| 亚洲精品18日本一区app | 在线国产激情视频 | 亚洲天天在线日亚洲洲精 | 亚洲精品自拍视频在线观看 | 国产精品福利视频 | 成人av免费播放 | 精品免费观看视频 | 97视频在线免费播放 | 久久久99精品免费观看app | 日本久热| 国产欧美最新羞羞视频在线观看 | 免费看黄色91 | 99久久婷婷国产综合亚洲 | 亚洲爱爱视频 | 五月婷婷六月丁香 | 欧美天天干 | 天天天天爱天天躁 | 青青草华人在线视频 | 亚洲欧美日韩国产 | 国产黄影院色大全免费 | 在线观看视频一区二区三区 | 夜夜婷婷 | av福利电影 | 国产午夜三级一区二区三桃花影视 | 激情电影影院 | 一区二区三区四区影院 | 久久免费黄色大片 | 亚洲欧美日韩国产一区二区三区 | 超碰九九 | 欧美一级特黄aaaaaa大片在线观看 | 国产剧情一区 | 在线观看日本韩国电影 | 久久国产精品一国产精品 | 色综合狠狠干 | 国产 中文 日韩 欧美 | 久久精品xxx | 免费看wwwwwwwwwww的视频 久久久久久99精品 91中文字幕视频 | 天天草天天插 | 日韩v欧美v日本v亚洲v国产v | 日日弄天天弄美女bbbb | 玖玖视频 | 欧美日韩国产三级 | 日本中文不卡 | 男女免费av | 久久免费视频3 | 日韩一区二区三区不卡 | 国产精品久久99 | 国产精品久久av | 久久情侣偷拍 | 亚洲国产欧美一区二区三区丁香婷 | 中文字幕免费在线看 | 国产成人免费在线 | 天天操天天怕 | 亚洲黄色小说网 | 国产精品久久久久久久av大片 | 国产一区在线免费观看视频 | 国产在线播放一区二区三区 | 九九热视频在线免费观看 | 欧美一级免费在线 | 亚洲午夜精品久久久 | 天天爽天天爽天天爽 | 日韩区视频 | 色丁香婷婷| 日韩色在线| 日韩免费精品 | 日日干激情五月 | 精品免费久久久久久 | 亚洲在线日韩 | 日韩在线精品 | 在线免费黄色毛片 | 五月婷婷综合激情网 | 亚洲欧美成人网 | 伊人久久电影网 | 日韩r级在线| 国产黄色精品在线观看 | 超碰大片 | 欧美一级免费在线 | 天天综合网 天天 | 国产精品自产拍在线观看桃花 | 久久欧美综合 | 一区二区三区免费网站 | 日本精品在线看 | 男女视频国产 | 人人插人人插 | 四虎在线免费观看 | 亚州精品一二三区 | 黄色国产高清 | 日韩伦理一区二区三区av在线 | 国产精品一区二区麻豆 | 天天操天天爽天天干 | 91在线看黄 | 国产a国产 | 777xxx欧美 | 久久综合婷婷国产二区高清 | av免费线看 | 正在播放国产一区 | 日本精品一 | 久久新| 国产裸体bbb视频 | 在线 视频 一区二区 | av免费看在线 | 国产精品理论片在线观看 | 中文字幕第| 婷婷色网| 视频成人免费 | 久久久综合电影 | 综合网天天 | 国内成人精品2018免费看 | av动态图片 | 免费看的黄色的网站 | 福利电影一区二区 | 麻豆久久久久久久 | 国产精品不卡 | 亚洲精品系列 | 在线观看视频97 | 国产高清视频免费最新在线 | 日韩欧美一区视频 | 精品中文字幕在线 | 青青河边草免费视频 | 亚州免费视频 | 免费进去里的视频 | 国产免费一区二区三区网站免费 | 色婷婷综合视频在线观看 | 精品久久久久亚洲 | 国产裸体视频网站 | 人人插人人费 | 免费网站在线 | 看av免费 | 精品人人人 | 丁香视频 | 97伊人网 | 日韩成人精品在线观看 | 综合网伊人 | 久久久久久久久久网站 | 久久久久久免费毛片精品 | 国产精品人人做人人爽人人添 | 欧美另类性 | 日韩三级视频在线观看 | 国产尤物在线视频 | 天天操天天综合网 | 九九九九九国产 | 激情综合网天天干 | 经典三级一区 | 国产色女人 | 久久成人精品视频 | 操操操人人 | 国产精美视频 | jizz18欧美18 | 欧美日韩午夜爽爽 | 亚洲dvd| 日操操 | 手机成人免费视频 | 丁香婷婷激情啪啪 | 在线视频日韩 | 人人干在线 | 91毛片在线观看 | 天天干天天操 | 91男人影院 | 人人爽夜夜爽 | 九九热中文字幕 | 国产精品久久久久久婷婷天堂 | 能在线观看的日韩av | av女优中文字幕在线观看 | 国产亚洲情侣一区二区无 | 四虎成人精品永久免费av | 久久精品99久久久久久 | 国产免费成人av | 久热免费在线观看 | 欧美黄网站 | 欧美午夜精品久久久久久浪潮 | bbw av| 久久精品视频在线观看免费 | 国产精品午夜久久久久久99热 | 九九在线高清精品视频 | 久久一本综合 | 国产精品不卡av | 日日爱视频 | 精品久久1 | av视屏在线 | 国产一级黄色片免费看 | 91在线看黄 | 成人中文字幕+乱码+中文字幕 | 午夜视频在线观看一区二区三区 | 国模精品在线 | 91色视频| av在线精品 | 深爱激情五月婷婷 | 免费人成在线观看网站 | 国产人在线成免费视频 | 一区二区在线不卡 | 久久久久久久av | 黄色片免费看 | 干狠狠 | 精品在线播放 | 国产不卡在线 | 欧美夫妻生活视频 | 日韩精品中字 | 91豆花在线 | 99r在线精品 | 在线岛国av | 四虎永久免费 | 亚洲免费国产视频 | 999超碰 | 高清av中文在线字幕观看1 | 黄色av一级片 | 插综合网 | 国产精品乱码在线 | 精品国产乱码 | 久久成年人网站 | 一区二区三区视频 | 亚洲在线激情 | 久久久精品综合 | 国产精品久久久久久久久久久久冷 | 成人禁用看黄a在线 | 毛片网在线观看 | 精品国模一区二区三区 | 国产在线小视频 | 国产极品尤物在线 | 亚洲aⅴ在线 | 日韩av电影免费在线观看 | 综合久久综合久久 | 国产精品成人av电影 | 久草剧场 | 日韩欧美综合 | 91豆麻精品91久久久久久 | 欧美特一级 | 国产精品久久久久久久婷婷 | 久久精品999 | 在线91av| 91免费高清观看 | 偷拍精偷拍精品欧洲亚洲网站 | 国产成人专区 | 色爽网站| 激情欧美丁香 | 成人在线免费观看网站 | 91麻豆精品国产91久久久久久久久 | 日日夜夜亚洲 | 国产v在线观看 | 亚洲jizzjizz日本少妇 | 日韩精品一区二区在线 | 亚洲国产精品一区二区久久hs | 成人av影视观看 | 91成人免费观看视频 | 一区三区在线欧 | 日批网站免费观看 | 国产 字幕 制服 中文 在线 | 91免费观看视频网站 | 成人精品电影 | 色婷婷狠狠18 | 久久欧美在线电影 | 99久久这里有精品 | 天天狠狠干| 欧美久久九九 | 国产精品国产三级国产aⅴ入口 | 高潮久久久 | 天海翼一区二区三区免费 | 深爱开心激情网 | 91精品91 | 久久99精品热在线观看 | 又黄又爽又刺激的视频 | 日韩在线不卡 | 国产精品自产拍在线观看 | 人人超在线公开视频 | 就要色综合 | 中文字幕中文字幕 | 操操综合网 | 国产精品专区在线观看 | 国产一区二区三区午夜 | 91中文字幕一区 | 日韩电影一区二区三区 | 日本精品久久久一区二区三区 | 青草视频网 | 欧美污污视频 | 国产亚洲免费观看 | 国模一区二区三区四区 | 人人爽人人澡 | 中国美女一级看片 | 久久久久久久免费 | 久草视频免费看 | 超碰97成人 | 国产精品欧美在线 | 91黄视频在线观看 | 黄色特一级 | 黄a在线看 | 国产分类视频 | 精品久久久久国产免费第一页 | 91久久久国产精品 | 欧美一区成人 | 在线一区二区三区 | 日韩成人xxxx | 久久精品5| 午夜的福利 | 国产在线更新 | 黄色特级毛片 | 四虎成人精品在永久免费 | 日韩在线激情 | 国产偷v国产偷∨精品视频 在线草 | 精品国产电影一区 | 人人澡人人草 | 国产黄a三级三级 | 国产一区电影在线观看 | 毛片网免费 | av网站地址| 超黄视频网站 | 99麻豆久久久国产精品免费 | 中文字幕视频网站 | 中文字幕在线网址 | 操久| 国产一级片免费观看 | 精品国产a | 国产一级淫片免费看 | 成人影音在线 | 久久久福利视频 | 欧美精品乱码久久久久久按摩 | 国产自产高清不卡 | 三日本三级少妇三级99 | 麻豆国产精品一区二区三区 | 亚洲综合最新在线 | 欧美日韩国产网站 | 黄色小说在线观看视频 | 又色又爽的网站 | av在线播放网址 | 久久久婷 | 美女黄频视频大全 | 国产v在线播放 | 成人在线视频免费看 | 91精品伦理 | 久久免费看视频 | 亚洲国产一区二区精品专区 | 免费日韩 | 欧美激情第八页 | 亚洲精品66 | 久久精品精品电影网 | 欧洲精品久久久久毛片完整版 | 精品免费一区二区三区 | 日本在线h | 日韩欧美一区二区三区在线 | 亚洲黄色小说网址 | 欧美成人精品三级在线观看播放 | 国产亚洲婷婷免费 | 天天操天天干天天干 | 久久激情综合网 | 精品国产一区二区三区久久久蜜臀 | 日韩精品一区二区免费 | 欧美性视频网站 | 精品伊人久久久 | 在线视频 国产 日韩 | 一本一本久久aa综合精品 | 天天综合人人 | 最新精品国产 | 国产福利在线免费 | 日本久久久久久科技有限公司 | 久久久久久久久久久久电影 | 国产精品国产三级国产aⅴ无密码 | 亚洲欧美日韩精品久久奇米一区 | 激情婷婷欧美 | 美女网站视频免费都是黄 | 中文字幕丰满人伦在线 | 九九国产视频 | 欧美日本日韩aⅴ在线视频 插插插色综合 | 亚洲综合视频在线播放 | 免费美女久久99 | 国产精品久久久久久久久软件 | 18pao国产成视频永久免费 | 天天操天天舔天天干 | 中文字幕视频免费观看 | 高清国产在线一区 | 国产原创91 | 国内一级片在线观看 | 久久综合九色欧美综合狠狠 | 在线播放日韩 | 中文字幕资源在线观看 | 国产99久久九九精品免费 | av超碰在线 | 狠狠躁18三区二区一区ai明星 | 国产视频精品视频 | av黄色一级片 | 91精品啪在线观看国产线免费 | 久久综合免费视频影院 | 综合色中文| 成年人国产精品 | 亚洲天堂网在线观看视频 | 欧美a视频 | 午夜精品久久久久久久99热影院 | 亚洲传媒在线 | 欧美日韩电影在线播放 | 免费看黄色小说的网站 | 美女黄濒| 久久精品免费观看 | 黄色毛片在线观看 | 婷婷丁香激情综合 | 色婷婷免费视频 | 少妇性色午夜淫片aaaze | 成人在线视频一区 | 欧美影院久久 | 婷婷五天天在线视频 | 99久久精品国 | 欧美极品在线播放 | 麻豆综合网 | 亚洲电影影音先锋 | 久久久免费少妇 | 久久99深爱久久99精品 | 日精品在线观看 | 亚洲在线看 | 91成品人影院 | 成人av高清在线 | 国内精品99| av在线免费不卡 | 久久久影院官网 | 亚洲国产网址 | 伊人婷婷色 | 丁香六月天 | 亚洲理论视频 | 99久久精品视频免费 | 中文av在线免费观看 | 国产精品美女久久 | 久久手机免费观看 | 天天干天天拍天天操天天拍 | 中文字幕在线成人 | 成 人 黄 色 免费播放 | 激情综合亚洲 | 国产片免费在线观看视频 | 久久中文字幕导航 | 亚洲精品动漫久久久久 | 日韩黄色一区 | 97av影院| 成人免费在线网 | 天天干天天在线 | 国产精品久久久久久久久费观看 | 成人亚洲综合 | 亚洲日本va中文字幕 | 国产一级在线播放 | 91精品在线播放 | 激情小说久久 | 久久国产精品久久w女人spa | 日韩免费观看视频 | 国产裸体bbb视频 | 五月婷婷香蕉 | 四虎永久国产精品 | 亚洲精品高清视频 | 激情在线五月天 | 成人一级片在线观看 | 久久精品综合视频 | 亚洲综合涩 | 九九三级毛片 | 久草视频免费在线播放 | 成人在线免费视频观看 | 久草精品网| 亚洲国产精品久久久久 | 国产又粗又硬又长又爽的视频 | a√天堂资源| av黄免费看 | 91自拍91 | 国产一区二区久久 | 久久精品欧美一区 | 丁香五婷 | 国产中文字幕视频在线观看 | 国产精品高潮呻吟久久久久 | 成人黄色电影视频 | 婷婷激情小说网 | 91av美女| www.97视频| 日韩欧美电影在线 | 久久久久久久久综合 | 精品国产乱码久久久久久天美 | 久草在线资源观看 | 伊人久久国产精品 | 久久久久久久av麻豆果冻 | 国产精品免费视频久久久 | 91av网址| 亚洲国产精品电影 | 久草在线资源观看 | 国产精品观看在线亚洲人成网 | 亚洲九九九 | 精品在线视频一区 | 中文字幕专区高清在线观看 | 国产成人精品国内自产拍免费看 | 亚洲精品国产精品国自产观看 | 91免费在线| 狠狠操狠狠干天天操 | 欧美一区二区精美视频 | 久久激情视频 久久 | 国产在线成人 | 最近中文字幕在线播放 | 欧美污在线观看 | 日韩草比 | 黄色片网站av | 亚洲人成免费网站 | 久久永久免费视频 | 456免费视频 | 2024国产精品视频 | 国产精品永久在线 | 在线看片视频 | 99久久精品国产一区二区成人 | 亚洲精品色视频 | 99精品久久只有精品 | 午夜精品中文字幕 | 婷婷丁香狠狠爱 | 91视频免费国产 | 97夜夜澡人人爽人人免费 | 色吊丝在线永久观看最新版本 | 国产日韩欧美视频在线观看 | 国产精品一区二区三区四区在线观看 | 九九导航| 精品久久久国产 | 亚洲精品国产精品乱码在线观看 | 伊人狠狠干 | 三上悠亚一区二区在线观看 | 色综合天天干 | 五月婷婷一区 | 麻豆系列在线观看 | 免费在线观看中文字幕 | 黄色av电影| 亚洲精品国产第一综合99久久 | a黄色影院| 亚洲成a人片77777kkkk1在线观看 | 新版资源中文在线观看 | 国产精品久久久久久久午夜片 | 国产欧美久久久精品影院 | 亚洲成av人影片在线观看 | 欧美孕交vivoestv另类 | 日韩在线视频一区 | 国产精品毛片久久久久久久 | 最近中文字幕第一页 | 97理论电影| 亚洲色图 校园春色 | 波多野结衣小视频 | 国产资源在线免费观看 | 91精品国产成人观看 | 五月天狠狠操 | 91精品视频免费看 | 热久久在线视频 | 黄网站a | 美女黄频在线观看 | 国产午夜精品一区 | 91福利社在线观看 | 中文字幕国产精品一区二区 | 精品在线免费观看 | 黄色国产在线 | 久久免费视频4 | 九九九九热精品免费视频点播观看 | 欧美视频日韩视频 | 999在线精品 | 又大又硬又黄又爽视频在线观看 | 黄色小说免费在线观看 | 久久久久免费精品视频 | 91丨九色丨首页 | 午夜精品久久久久久久99热影院 | 中文字幕91视频 | 亚洲精品小视频在线观看 | 五月色婷 | 亚av在线| 激情综合国产 | 成人丁香花 | 91片黄在线观 | bbw av| 天天草夜夜 | 在线日韩亚洲 | 色在线免费 | 天天射天 | 久久精品国产一区 | 色综合小说 | 日日夜夜骑 | 欧美日韩精品在线播放 | 久久免费资源 | 婷婷在线网| 玖玖精品视频 | 成人久久久久久久久 | 区一区二区三在线观看 | 欧美激情综合色综合啪啪五月 | 国产精品热| 亚洲性少妇性猛交wwww乱大交 | 狠狠干狠狠操 | 国产黄色片一级三级 | 午夜精品久久久久 | 欧美一级性视频 | av色综合网 | 99久久影院| 99精品99 | 一级大片在线观看 | 午夜精品av在线 | 亚洲一区二区三区miaa149 | 亚洲五月六月 | 九色视频自拍 | www.国产毛片 | 国产一级大片免费看 | 色综合久久综合中文综合网 | 亚洲成人av影片 | 中文字幕在线专区 | 91精品国产高清自在线观看 | 手机成人av | 国产在线一区观看 | 久久久久久久久久久久亚洲 | 色久av| 亚洲砖区区免费 | 日韩欧美一区二区不卡 | 夜夜夜夜夜夜操 | 日本午夜免费福利视频 | 九九九九九精品 | 国产成人精品亚洲 | 亚洲精品乱码久久久久久9色 | 黄色一区二区在线观看 | 在线天堂中文www视软件 | 免费h精品视频在线播放 | 欧美精品中文在线免费观看 | 亚洲久草网 | 午夜精品久久久久久久久久久 | 中文字幕第一 | 日本在线观看视频一区 | 亚洲国产精品500在线观看 | 欧美人牲 | aav在线| 久久精品男人的天堂 | 操一草| www.天天操 | 欧美aⅴ在线观看 | 久久伦理电影网 | 欧美一级在线观看视频 | 国产无吗一区二区三区在线欢 | 国产美女免费视频 | 婷婷丁香激情五月 | 国产在线999 | 国产品久精国精产拍 | 伊人视频| 免费视频97 | 久久www免费人成看片高清 | 国产精品岛国久久久久久久久红粉 | 97碰碰视频| 69人人| 黄色软件大全网站 | 久久久久久久久久久久久久电影 | 男女激情免费网站 | 日韩免费一区二区三区 | 天天看天天操 | 色狠狠久久av五月综合 | 久久人操 | 色之综合网 | 中文字幕制服丝袜av久久 | 国产精品综合av一区二区国产馆 | 久久久久久高潮国产精品视 | 国产看片免费 | 综合色伊人 | 午夜久久久影院 | 国产麻豆视频在线观看 | 久草免费在线视频观看 | 免费久久99精品国产 | 91视频在线看 | 国产精品你懂的在线观看 | 中文字幕乱码视频 | 久久精品黄 | 俺要去色综合狠狠 | 麻豆91精品91久久久 | 手机av电影在线观看 | 国产又黄又爽又猛视频日本 | 婷婷综合视频 | 国产精品 欧美 日韩 | 天天干天天干天天操 | 一区二区精品在线视频 | 91亚洲精品久久久蜜桃 | 97超碰总站 | 日韩精品视频网站 | 波多野结衣视频一区 | 特级西西444www高清大视频 | 在线观看香蕉视频 | 996久久国产精品线观看 | 色久综合| 成人免费精品 | 免费av黄色| 91爱爱中文字幕 | 国产资源精品在线观看 | 亚洲国产三级在线 | 国内久久| 五月婷婷天堂 | 亚洲精品在线观看不卡 | 国产主播大尺度精品福利免费 | 日韩精品一区二区三区免费视频观看 | 国产高清精品在线观看 | 99 久久久久 | 日韩精品一区二区三区免费观看 | 欧美在线观看小视频 | 四虎影视精品永久在线观看 | 人人爱爱 | 国产热re99久久6国产精品 | 亚洲色综合 | 国产一级精品视频 | 99久久精品免费看国产免费软件 | 国产精品白虎 | 色之综合网 | 高潮毛片无遮挡高清免费 | 久久一二区 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 亚洲 欧美 国产 va在线影院 | 日韩国产精品一区 | 九九热国产 | 色播五月激情综合网 | 日韩视频中文字幕在线观看 | 日韩中文三级 | av日韩不卡 | 精品国产欧美 | 天天干天天搞天天射 | 久久久久激情电影 | 国产精品美女久久久久久久久久久 | 欧美日韩综合在线观看 | 欧美一级黄大片 | 精品成人a区在线观看 | 五月婷婷欧美 | 91久久国产综合精品女同国语 | 日本中文字幕在线 | 久久精品久久精品久久39 | 一区二区电影在线观看 | 亚洲特级片 | 人人爱人人做人人爽 | 久久久久久久久久久网 | 国产精品电影一区 | 精品国产精品久久一区免费式 | 国产精品免费一区二区三区 | 国产一级免费av | 国产福利一区二区三区视频 | 日韩美在线观看 | 五月天久久久久久 | 中文字幕在线观看视频网站 | 天天综合网 天天综合色 | 亚洲午夜不卡 | 亚洲在线高清 | 亚洲精品www久久久 www国产精品com | 中文字幕精品久久 | 婷婷色网 | 中文字幕一区二区三区四区在线视频 | 国产高清在线观看av | 免费男女羞羞的视频网站中文字幕 | 日躁夜躁狠狠躁2001 | 成人国产精品电影 | 精品国产美女 | 91完整版观看 | 欧美一二三专区 | 最近免费在线观看 | 一级黄色av| 国产极品尤物在线 | 免费在线色视频 | av线上免费看| 日韩精品你懂的 | 免费av片在线 | 免费看毛片在线 | 国产精彩视频一区二区 | 免费一级特黄录像 | 日韩夜夜爽 | 国产成人精品在线 | 国产精品免费久久久久久久久久中文 | 国产一级视频在线观看 | 又黄又爽又色无遮挡免费 | 在线观看亚洲免费视频 | 日韩精品无码一区二区三区 | 国产视频精品网 | 天天操天天爱天天爽 | 色噜噜在线观看视频 | 国产一区二区在线免费播放 | av在线观 | 免费在线观看一级片 | 欧美美女视频在线观看 | 人人草人人草 | 久久国产欧美日韩 | 黄色av电影在线观看 | 久久黄色免费视频 | 久久久久久久久久久免费视频 | 亚洲精品乱码久久久久久写真 | 中文字幕日本电影 | 伊人一级 | 日韩视频a| 亚洲激情在线观看 | 欧美va电影| 最近中文字幕在线中文高清版 | 欧美视频www | 日韩精品一区二区三区三炮视频 | 中文在线 | 婷婷在线视频 | 中文字幕你懂的 | 成人黄色国产 | 麻豆视频成人 | 久久精品香蕉 | 91九色在线 | av中文在线观看 | 久久久国产电影 | 激情视频一区二区 | 日韩精品一区二区在线观看 | 911久久香蕉国产线看观看 | 最新99热 | 在线视频日韩欧美 | 久久这里精品视频 | 久久视频这里有久久精品视频11 | 亚洲激情av | 国产黄色一级大片 | 91精品国产综合久久福利不卡 | 涩涩网站在线播放 | 日韩高清毛片 | 日本在线成人 | 日韩电影在线观看一区二区 | 久久激情视频 | 美女网站视频免费都是黄 | 在线亚洲天堂网 | 不卡日韩av | 日韩高清成人在线 | 久久久精品小视频 | 色婷婷国产精品一区在线观看 | 一区二区三区国产精品 |