3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問 生活随笔!

生活随笔

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

Android

Android应用程序消息处理机制(Looper、Handler)分析

發布時間:2023/12/20 Android 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Android应用程序消息处理机制(Looper、Handler)分析 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章轉載至CSDN社區羅升陽的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6817933

Android應用程序是通過消息來驅動的,系統為每一個應用程序維護一個消息隊例,應用程序的主線程不斷地從這個消息 隊例中獲取消息(Looper),然后對這些消息進行處理(Handler),這樣就實現了通過消息來驅動應用程序的執行,本文將詳細分析Android 應用程序的消息處理機制。

?? ? ? ?前面我們學習Android應用程序中的Activity啟動(Android應用程序啟動過程源代碼分析和Android應用程序內部啟動Activity過程(startActivity)的源代碼分析)、Service啟動(Android系統在新進程中啟動自定義服務過程(startService)的原理分析和Android應用程序綁定服務(bindService)的過程源代碼分析)以及廣播發送(Android應用程序發送廣播(sendBroadcast)的過程分析)時,它們都有一個共同的特點,當ActivityManagerService需要與應用程序進行并互時,如加載Activity和Service、處理廣播待,會通過Binder進程間通信機制來 知會應用程序,應用程序接收到這個請求時,它不是馬上就處理這個請求,而是將這個請求封裝成一個消息,然后把這個消息放在應用程序的消息隊列中去,然后再 通過消息循環來處理這個消息。這樣做的好處就是消息的發送方只要把消息發送到應用程序的消息隊列中去就行了,它可以馬上返回去處理別的事情,而不需要等待 消息的接收方去處理完這個消息才返回,這樣就可以提高系統的并發性。實質上,這就是一種異步處理機制。

?? ? ? ?這樣說可能還是比較籠統,我們以Android應用程序啟動過程源代碼分析一文中所介紹的應用程序啟動過程的一個片斷來具體看看是如何這種消息處理機制的。在這篇文章中,要啟動的應用程序稱為Activity,它的默認Activity是MainActivity,它是由Launcher來負責啟動的,而Launcher又是通過ActivityManagerService來啟動的,當ActivityManagerService為這個即將要啟的應用程序準備好新的進程后,便通過一個Binder進程間通信過程來通知這個新的進程來加載MainActivity,如下圖所示:

?? ? ? ?它對應Android應用程序啟動過程中的Step 30到Step 35,有興趣的讀者可以回過頭去參考Android應用程序啟動過程源代碼分析一文。這里的Step 30中的scheduleLaunchActivity是ActivityManagerService通過Binder進程間通信機制發 送過來的請求,它請求應用程序中的ActivityThread執行Step 34中的performLaunchActivity操作,即啟動MainActivity的操作。這里我們就可以看到,Step 30的這個請求并沒有等待Step 34這個操作完成就返回了,它只是把這個請求封裝成一個消息,然后通過Step 31中的queueOrSendMessage操作把這個消息放到應用程序的消息隊列中,然后就返回了。應用程序發現消息隊列中有消息時,就會通過 Step 32中的handleMessage操作來處理這個消息,即調用Step 33中的handleLaunchActivity來執行實際的加載MainAcitivy類的操作。

?? ? ? ?了解Android應用程序的消息處理過程之后,我們就開始分樣它的實現原理了。與Windows應用程序的消息處理過程一樣,Android應用程序 的消息處理機制也是由消息循環、消息發送和消息處理這三個部分組成的,接下來,我們就詳細描述這三個過程。

?? ? ? ?1. 消息循環

?? ? ? ?在消息處理機制中,消息都是存放在一個消息隊列中去,而應用程序的主線程就是圍繞這個消息隊列進入一個無限循環的,直到應用程序退出。如果隊列中有消 息,應用程序的主線程就會把它取出來,并分發給相應的Handler進行處理;如果隊列中沒有消息,應用程序的主線程就會進入空閑等待狀態,等待下一個消 息的到來。在Android應用程序中,這個消息循環過程是由Looper類來實現的,它定義在frameworks/base/core/java /android/os/Looper.java文件中,在分析這個類之前,我們先看一下Android應用程序主線程是如何進入到這個消息循環中去的。

?? ? ? ?在Android應用程序進程啟動過程的源代碼分析一 文中,我們分析了Android應用程序進程的啟動過程,Android應用程序進程在啟動的時候,會在進程中加載ActivityThread類,并且 執行這個類的main函數,應用程序的消息循環過程就是在這個main函數里面實現的,我們來看看這個函數的實現,它定義在 frameworks/base/core/java/android/app/ActivityThread.java文件中:

[java] view plaincopy
  • public?final?class?ActivityThread?{??
  • ????......??
  • ??
  • ????public?static?final?void?main(String[]?args)?{??
  • ????????......??
  • ??
  • ????????Looper.prepareMainLooper();??
  • ??
  • ????????......??
  • ??
  • ????????ActivityThread?thread?=?new?ActivityThread();??
  • ????????thread.attach(false);??
  • ??????????
  • ????????......??
  • ??
  • ????????Looper.loop();??
  • ??
  • ????????......??
  • ??
  • ????????thread.detach();??
  • ??
  • ????????......??
  • ????}??
  • }??
  • ?? ? ? ?這個函數做了兩件事情,一是在主線程中創建了一個ActivityThread實例,二是通過Looper類使主線程進入消息循環中,這里我們只關注后者。

    ?? ? ? ?首先看Looper.prepareMainLooper函數的實現,這是一個靜態成員函數,定義在frameworks/base/core/java/android/os/Looper.java文件中:

    [java] view plaincopy
  • public?class?Looper?{??
  • ????......??
  • ??
  • ????private?static?final?ThreadLocal?sThreadLocal?=?new?ThreadLocal();??
  • ??
  • ????final?MessageQueue?mQueue;??
  • ??
  • ????......??
  • ??
  • ????/**?Initialize?the?current?thread?as?a?looper.?
  • ????*?This?gives?you?a?chance?to?create?handlers?that?then?reference?
  • ????*?this?looper,?before?actually?starting?the?loop.?Be?sure?to?call?
  • ????*?{@link?#loop()}?after?calling?this?method,?and?end?it?by?calling?
  • ????*?{@link?#quit()}.?
  • ????*/??
  • ????public?static?final?void?prepare()?{??
  • ????????if?(sThreadLocal.get()?!=?null)?{??
  • ????????????throw?new?RuntimeException("Only?one?Looper?may?be?created?per?thread");??
  • ????????}??
  • ????????sThreadLocal.set(new?Looper());??
  • ????}??
  • ??
  • ????/**?Initialize?the?current?thread?as?a?looper,?marking?it?as?an?application's?main??
  • ????*??looper.?The?main?looper?for?your?application?is?created?by?the?Android?environment,?
  • ????*??so?you?should?never?need?to?call?this?function?yourself.?
  • ????*?{@link?#prepare()}?
  • ????*/??
  • ??
  • ????public?static?final?void?prepareMainLooper()?{??
  • ????????prepare();??
  • ????????setMainLooper(myLooper());??
  • ????????if?(Process.supportsProcesses())?{??
  • ????????????myLooper().mQueue.mQuitAllowed?=?false;??
  • ????????}??
  • ????}??
  • ??
  • ????private?synchronized?static?void?setMainLooper(Looper?looper)?{??
  • ????????mMainLooper?=?looper;??
  • ????}??
  • ??
  • ????/**?
  • ????*?Return?the?Looper?object?associated?with?the?current?thread.??Returns?
  • ????*?null?if?the?calling?thread?is?not?associated?with?a?Looper.?
  • ????*/??
  • ????public?static?final?Looper?myLooper()?{??
  • ????????return?(Looper)sThreadLocal.get();??
  • ????}??
  • ??
  • ????private?Looper()?{??
  • ????????mQueue?=?new?MessageQueue();??
  • ????????mRun?=?true;??
  • ????????mThread?=?Thread.currentThread();??
  • ????}??
  • ??
  • ????......??
  • }??
  • ?? ? ? ?函數prepareMainLooper做的事情其實就是在線程中創建一個Looper對象,這個Looper對象是存放在sThreadLocal成 員變量里面的,成員變量sThreadLocal的類型為ThreadLocal,表示這是一個線程局部變量,即保證每一個調用了 prepareMainLooper函數的線程里面都有一個獨立的Looper對象。在線程是創建Looper對象的工作是由prepare函數來完成 的,而在創建Looper對象的時候,會同時創建一個消息隊列MessageQueue,保存在Looper的成員變量mQueue中,后續消息就是存放 在這個隊列中去。消息隊列在Android應用程序消息處理機制中最重要的組件,因此,我們看看它的創建過程,即它的構造函數的實現,實現 frameworks/base/core/java/android/os/MessageQueue.java文件中:

    [java] view plaincopy
  • public?class?MessageQueue?{??
  • ????......??
  • ??
  • ????private?int?mPtr;?//?used?by?native?code??
  • ??
  • ????private?native?void?nativeInit();??
  • ??
  • ????MessageQueue()?{??
  • ????????nativeInit();??
  • ????}??
  • ??
  • ????......??
  • }??
  • ?? ? ? ?它的初始化工作都交給JNI方法nativeInit來實現了,這個JNI方法定義在frameworks/base/core/jni/android_os_MessageQueue.cpp文件中:

    [cpp] view plaincopy
  • static?void?android_os_MessageQueue_nativeInit(JNIEnv*?env,?jobject?obj)?{??
  • ????NativeMessageQueue*?nativeMessageQueue?=?new?NativeMessageQueue();??
  • ????if?(!?nativeMessageQueue)?{??
  • ????????jniThrowRuntimeException(env,?"Unable?to?allocate?native?queue");??
  • ????????return;??
  • ????}??
  • ??
  • ????android_os_MessageQueue_setNativeMessageQueue(env,?obj,?nativeMessageQueue);??
  • }??
  • ?? ? ? ?在JNI中,也相應地創建了一個消息隊列NativeMessageQueue,NativeMessageQueue類也是定義在 frameworks/base/core/jni/android_os_MessageQueue.cpp文件中,它的創建過程如下所示:

    [cpp] view plaincopy
  • NativeMessageQueue::NativeMessageQueue()?{??
  • ????mLooper?=?Looper::getForThread();??
  • ????if?(mLooper?==?NULL)?{??
  • ????????mLooper?=?new?Looper(false);??
  • ????????Looper::setForThread(mLooper);??
  • ????}??
  • }??
  • ?? ? ? ?它主要就是在內部創建了一個Looper對象,注意,這個Looper對象是實現在JNI層的,它與上面Java層中的Looper是不一樣的,不過它們是對應的,下面我們進一步分析消息循環的過程的時候,讀者就會清楚地了解到它們之間的關系。

    ?? ? ? ?這個Looper的創建過程也很重要,不過我們暫時放一放,先分析完android_os_MessageQueue_nativeInit函數的執 行,它創建了本地消息隊列NativeMessageQueue對象之后,接著調用 android_os_MessageQueue_setNativeMessageQueue函數來把這個消息隊列對象保存在前面我們在Java層中創 建的MessageQueue對象的mPtr成員變量里面:

    [cpp] view plaincopy
  • static?void?android_os_MessageQueue_setNativeMessageQueue(JNIEnv*?env,?jobject?messageQueueObj,??
  • ????????NativeMessageQueue*?nativeMessageQueue)?{??
  • ????env->SetIntField(messageQueueObj,?gMessageQueueClassInfo.mPtr,??
  • ?????????????reinterpret_cast<jint>(nativeMessageQueue));??
  • }??
  • ?? ? ? ?這里傳進來的參數messageQueueObj即為我們前面在Java層創建的消息隊列對象,而 gMessageQueueClassInfo.mPtr即表示在Java類MessageQueue中,其成員變量mPtr的偏移量,通過這個偏移量, 就可以把這個本地消息隊列對象natvieMessageQueue保存在Java層創建的消息隊列對象的mPtr成員變量中,這是為了后續我們調用 Java層的消息隊列對象的其它成員函數進入到JNI層時,能夠方便地找回它在JNI層所對應的消息隊列對象。

    ?? ? ? ?我們再回到NativeMessageQueue的構造函數中,看看JNI層的Looper對象的創建過程,即看看它的構造函數是如何實現的,這個Looper類實現在frameworks/base/libs/utils/Looper.cpp文件中:

    [cpp] view plaincopy
  • Looper::Looper(bool?allowNonCallbacks)?:??
  • ????mAllowNonCallbacks(allowNonCallbacks),??
  • ????mResponseIndex(0)?{??
  • ????int?wakeFds[2];??
  • ????int?result?=?pipe(wakeFds);??
  • ????......??
  • ??
  • ????mWakeReadPipeFd?=?wakeFds[0];??
  • ????mWakeWritePipeFd?=?wakeFds[1];??
  • ??
  • ????......??
  • ??
  • #ifdef?LOOPER_USES_EPOLL??
  • ????//?Allocate?the?epoll?instance?and?register?the?wake?pipe.??
  • ????mEpollFd?=?epoll_create(EPOLL_SIZE_HINT);??
  • ????......??
  • ??
  • ????struct?epoll_event?eventItem;??
  • ????memset(&?eventItem,?0,?sizeof(epoll_event));?//?zero?out?unused?members?of?data?field?union??
  • ????eventItem.events?=?EPOLLIN;??
  • ????eventItem.data.fd?=?mWakeReadPipeFd;??
  • ????result?=?epoll_ctl(mEpollFd,?EPOLL_CTL_ADD,?mWakeReadPipeFd,?&?eventItem);??
  • ????......??
  • #else??
  • ????......??
  • #endif??
  • ??
  • ????......??
  • }??
  • ?? ? ? ?這個構造函數做的事情非常重要,它跟我們后面要介紹的應用程序主線程在消息隊列中沒有消息時要進入等待狀態以及當消息隊列有消息時要把應用程序主線程喚醒的這兩個知識點息息相關。它主要就是通過pipe系統調用來創建了一個管道了:

    [cpp] view plaincopy
  • int?wakeFds[2];??
  • int?result?=?pipe(wakeFds);??
  • ......??
  • ??
  • mWakeReadPipeFd?=?wakeFds[0];??
  • mWakeWritePipeFd?=?wakeFds[1];??
  • ?? ? ? ?管道是Linux系統中的一種進程間通信機制,具體可以參考前面一篇文章Android學習啟動篇推 薦的一本書《Linux內核源代碼情景分析》中的第6章--傳統的Uinx進程間通信。簡單來說,管道就是一個文件,在管道的兩端,分別是兩個打開文件文 件描述符,這兩個打開文件描述符都是對應同一個文件,其中一個是用來讀的,別一個是用來寫的,一般的使用方式就是,一個線程通過讀文件描述符中來讀管道的 內容,當管道沒有內容時,這個線程就會進入等待狀態,而另外一個線程通過寫文件描述符來向管道中寫入內容,寫入內容的時候,如果另一端正有線程正在等待管 道中的內容,那么這個線程就會被喚醒。這個等待和喚醒的操作是如何進行的呢,這就要借助Linux系統中的epoll機制了。?Linux系統中的 epoll機制為處理大批量句柄而作了改進的poll,是Linux下多路復用IO接口select/poll的增強版本,它能顯著減少程序在大量并發連 接中只有少量活躍的情況下的系統CPU利用率。但是這里我們其實只需要監控的IO接口只有mWakeReadPipeFd一個,即前面我們所創建的管道的 讀端,為什么還需要用到epoll呢?有點用牛刀來殺雞的味道。其實不然,這個Looper類是非常強大的,它除了監控內部所創建的管道接口之外,還提供 了addFd接口供外界面調用,外界可以通過這個接口把自己想要監控的IO事件一并加入到這個Looper對象中去,當所有這些被監控的IO接口上面有事 件發生時,就會喚醒相應的線程來處理,不過這里我們只關心剛才所創建的管道的IO事件的發生。

    ?? ? ? ?要使用Linux系統的epoll機制,首先要通過epoll_create來創建一個epoll專用的文件描述符:

    [cpp] view plaincopy
  • mEpollFd?=?epoll_create(EPOLL_SIZE_HINT);??
  • ?? ? ? 傳入的參數EPOLL_SIZE_HINT是在這個mEpollFd上能監控的最大文件描述符數。

    ?? ? ? 接著還要通過epoll_ctl函數來告訴epoll要監控相應的文件描述符的什么事件:

    [cpp] view plaincopy
  • struct?epoll_event?eventItem;??
  • memset(&?eventItem,?0,?sizeof(epoll_event));?//?zero?out?unused?members?of?data?field?union??
  • eventItem.events?=?EPOLLIN;??
  • eventItem.data.fd?=?mWakeReadPipeFd;??
  • result?=?epoll_ctl(mEpollFd,?EPOLL_CTL_ADD,?mWakeReadPipeFd,?&?eventItem);??
  • ?? ? ? 這里就是告訴mEpollFd,它要監控mWakeReadPipeFd文件描述符的EPOLLIN事件,即當管道中有內容可讀時,就喚醒當前正在等待管道中的內容的線程。
    ?? ? ? C++層的這個Looper對象創建好了之后,就返回到JNI層的NativeMessageQueue的構造函數,最后就返回到Java層的消息隊列 MessageQueue的創建過程,這樣,Java層的Looper對象就準備好了。有點復雜,我們先小結一下這一步都做了些什么事情:

    ?? ? ? A. 在Java層,創建了一個Looper對象,這個Looper對象是用來進入消息循環的,它的內部有一個消息隊列MessageQueue對象mQueue;

    ?? ? ? B. 在JNI層,創建了一個NativeMessageQueue對象,這個NativeMessageQueue對象保存在Java層的消息隊列對象mQueue的成員變量mPtr中;

    ?? ? ? C. 在C++層,創建了一個Looper對象,保存在JNI層的NativeMessageQueue對象的成員變量mLooper中,這個對象的作用是,當 Java層的消息隊列中沒有消息時,就使Android應用程序主線程進入等待狀態,而當Java層的消息隊列中來了新的消息后,就喚醒Android應 用程序的主線程來處理這個消息。

    ?? ? ? 回到ActivityThread類的main函數中,在上面這些工作都準備好之后,就調用Looper類的loop函數進入到消息循環中去了:

    [cpp] view plaincopy
  • public?class?Looper?{??
  • ????......??
  • ??
  • ????public?static?final?void?loop()?{??
  • ????????Looper?me?=?myLooper();??
  • ????????MessageQueue?queue?=?me.mQueue;??
  • ??
  • ????????......??
  • ??
  • ????????while?(true)?{??
  • ????????????Message?msg?=?queue.next();?//?might?block??
  • ????????????......??
  • ??
  • ????????????if?(msg?!=?null)?{??
  • ????????????????if?(msg.target?==?null)?{??
  • ????????????????????//?No?target?is?a?magic?identifier?for?the?quit?message.??
  • ????????????????????return;??
  • ????????????????}??
  • ??
  • ????????????????......??
  • ??
  • ????????????????msg.target.dispatchMessage(msg);??
  • ??????????????????
  • ????????????????......??
  • ??
  • ????????????????msg.recycle();??
  • ????????????}??
  • ????????}??
  • ????}??
  • ??
  • ????......??
  • }??
  • ?? ? ? ?這里就是進入到消息循環中去了,它不斷地從消息隊列mQueue中去獲取下一個要處理的消息msg,如果消息的target成員變量為null,就表示 要退出消息循環了,否則的話就要調用這個target對象的dispatchMessage成員函數來處理這個消息,這個target對象的類型為 Handler,下面我們分析消息的發送時會看到這個消息對象msg是如設置的。

    ?? ? ? ?這個函數最關鍵的地方便是從消息隊列中獲取下一個要處理的消息了,即MessageQueue.next函數,它實現frameworks/base/core/java/android/os/MessageQueue.java文件中:

    [java] view plaincopy
  • public?class?MessageQueue?{??
  • ????......??
  • ??
  • ????final?Message?next()?{??
  • ????????int?pendingIdleHandlerCount?=?-1;?//?-1?only?during?first?iteration??
  • ????????int?nextPollTimeoutMillis?=?0;??
  • ??
  • ????????for?(;;)?{??
  • ????????????if?(nextPollTimeoutMillis?!=?0)?{??
  • ????????????????Binder.flushPendingCommands();??
  • ????????????}??
  • ????????????nativePollOnce(mPtr,?nextPollTimeoutMillis);??
  • ??
  • ????????????synchronized?(this)?{??
  • ????????????????//?Try?to?retrieve?the?next?message.??Return?if?found.??
  • ????????????????final?long?now?=?SystemClock.uptimeMillis();??
  • ????????????????final?Message?msg?=?mMessages;??
  • ????????????????if?(msg?!=?null)?{??
  • ????????????????????final?long?when?=?msg.when;??
  • ????????????????????if?(now?>=?when)?{??
  • ????????????????????????mBlocked?=?false;??
  • ????????????????????????mMessages?=?msg.next;??
  • ????????????????????????msg.next?=?null;??
  • ????????????????????????if?(Config.LOGV)?Log.v("MessageQueue",?"Returning?message:?"?+?msg);??
  • ????????????????????????return?msg;??
  • ????????????????????}?else?{??
  • ????????????????????????nextPollTimeoutMillis?=?(int)?Math.min(when?-?now,?Integer.MAX_VALUE);??
  • ????????????????????}??
  • ????????????????}?else?{??
  • ????????????????????nextPollTimeoutMillis?=?-1;??
  • ????????????????}??
  • ??
  • ????????????????//?If?first?time,?then?get?the?number?of?idlers?to?run.??
  • ????????????????if?(pendingIdleHandlerCount?<?0)?{??
  • ????????????????????pendingIdleHandlerCount?=?mIdleHandlers.size();??
  • ????????????????}??
  • ????????????????if?(pendingIdleHandlerCount?==?0)?{??
  • ????????????????????//?No?idle?handlers?to?run.??Loop?and?wait?some?more.??
  • ????????????????????mBlocked?=?true;??
  • ????????????????????continue;??
  • ????????????????}??
  • ??
  • ????????????????if?(mPendingIdleHandlers?==?null)?{??
  • ????????????????????mPendingIdleHandlers?=?new?IdleHandler[Math.max(pendingIdleHandlerCount,?4)];??
  • ????????????????}??
  • ????????????????mPendingIdleHandlers?=?mIdleHandlers.toArray(mPendingIdleHandlers);??
  • ????????????}??
  • ??
  • ????????????//?Run?the?idle?handlers.??
  • ????????????//?We?only?ever?reach?this?code?block?during?the?first?iteration.??
  • ????????????for?(int?i?=?0;?i?<?pendingIdleHandlerCount;?i++)?{??
  • ????????????????final?IdleHandler?idler?=?mPendingIdleHandlers[i];??
  • ????????????????mPendingIdleHandlers[i]?=?null;?//?release?the?reference?to?the?handler??
  • ??
  • ????????????????boolean?keep?=?false;??
  • ????????????????try?{??
  • ????????????????????keep?=?idler.queueIdle();??
  • ????????????????}?catch?(Throwable?t)?{??
  • ????????????????????Log.wtf("MessageQueue",?"IdleHandler?threw?exception",?t);??
  • ????????????????}??
  • ??
  • ????????????????if?(!keep)?{??
  • ????????????????????synchronized?(this)?{??
  • ????????????????????????mIdleHandlers.remove(idler);??
  • ????????????????????}??
  • ????????????????}??
  • ????????????}??
  • ??
  • ????????????//?Reset?the?idle?handler?count?to?0?so?we?do?not?run?them?again.??
  • ????????????pendingIdleHandlerCount?=?0;??
  • ??
  • ????????????//?While?calling?an?idle?handler,?a?new?message?could?have?been?delivered??
  • ????????????//?so?go?back?and?look?again?for?a?pending?message?without?waiting.??
  • ????????????nextPollTimeoutMillis?=?0;??
  • ????????}??
  • ????}??
  • ??
  • ????......??
  • }??
  • ?? ? ? ?調用這個函數的時候,有可能會讓線程進入等待狀態。什么情況下,線程會進入等待狀態呢?兩種情況,一是當消息隊列中沒有消息時,它會使線程進入等待狀 態;二是消息隊列中有消息,但是消息指定了執行的時間,而現在還沒有到這個時間,線程也會進入等待狀態。消息隊列中的消息是按時間先后來排序的,后面我們 在分析消息的發送時會看到。

    ?? ? ? ?執行下面語句是看看當前消息隊列中有沒有消息:

    [java] view plaincopy
  • nativePollOnce(mPtr,?nextPollTimeoutMillis);??
  • ?? ? ? ?這是一個JNI方法,我們等一下再分析,這里傳入的參數mPtr就是指向前面我們在JNI層創建的NativeMessageQueue對象了,而參數 nextPollTimeoutMillis則表示如果當前消息隊列中沒有消息,它要等待的時候,for循環開始時,傳入的值為0,表示不等待。

    ?? ? ? ?當前nativePollOnce返回后,就去看看消息隊列中有沒有消息:

    [java] view plaincopy
  • final?Message?msg?=?mMessages;??
  • if?(msg?!=?null)?{??
  • ????final?long?when?=?msg.when;??
  • ????if?(now?>=?when)?{??
  • ????????mBlocked?=?false;??
  • ????????mMessages?=?msg.next;??
  • ????????msg.next?=?null;??
  • ????????if?(Config.LOGV)?Log.v("MessageQueue",?"Returning?message:?"?+?msg);??
  • ????????return?msg;??
  • ????}?else?{??
  • ????????nextPollTimeoutMillis?=?(int)?Math.min(when?-?now,?Integer.MAX_VALUE);??
  • ????}??
  • }?else?{??
  • ????nextPollTimeoutMillis?=?-1;??
  • }??
  • ?? ? ? ?如果消息隊列中有消息,并且當前時候大于等于消息中的執行時間,那么就直接返回這個消息給Looper.loop消息處理,否則的話就要等待到消息的執行時間:

    [java] view plaincopy
  • nextPollTimeoutMillis?=?(int)?Math.min(when?-?now,?Integer.MAX_VALUE);??
  • ?? ? ? ?如果消息隊列中沒有消息,那就要進入無窮等待狀態直到有新消息了:

    [java] view plaincopy
  • nextPollTimeoutMillis?=?-1;??
  • ?? ? ? ?-1表示下次調用nativePollOnce時,如果消息中沒有消息,就進入無限等待狀態中去。

    ?? ? ? ?這里計算出來的等待時間都是在下次調用nativePollOnce時使用的。

    ?? ? ? ?這里說的等待,是空閑等待,而不是忙等待,因此,在進入空閑等待狀態前,如果應用程序注冊了IdleHandler接口來處理一些事情,那么就會先執行 這里IdleHandler,然后再進入等待狀態。IdlerHandler是定義在MessageQueue的一個內部類:

    [java] view plaincopy
  • public?class?MessageQueue?{??
  • ????......??
  • ??
  • ????/**?
  • ????*?Callback?interface?for?discovering?when?a?thread?is?going?to?block?
  • ????*?waiting?for?more?messages.?
  • ????*/??
  • ????public?static?interface?IdleHandler?{??
  • ????????/**?
  • ????????*?Called?when?the?message?queue?has?run?out?of?messages?and?will?now?
  • ????????*?wait?for?more.??Return?true?to?keep?your?idle?handler?active,?false?
  • ????????*?to?have?it?removed.??This?may?be?called?if?there?are?still?messages?
  • ????????*?pending?in?the?queue,?but?they?are?all?scheduled?to?be?dispatched?
  • ????????*?after?the?current?time.?
  • ????????*/??
  • ????????boolean?queueIdle();??
  • ????}??
  • ??
  • ????......??
  • }??
  • ?? ? ? ?它只有一個成員函數queueIdle,執行這個函數時,如果返回值為false,那么就會從應用程序中移除這個IdleHandler,否則的話就會 在應用程序中繼續維護著這個IdleHandler,下次空閑時仍會再執會這個IdleHandler。MessageQueue提供了 addIdleHandler和removeIdleHandler兩注冊和刪除IdleHandler。

    ?? ? ? ?回到MessageQueue函數中,它接下來就是在進入等待狀態前,看看有沒有IdleHandler是需要執行的:

    [java] view plaincopy
  • //?If?first?time,?then?get?the?number?of?idlers?to?run.??
  • if?(pendingIdleHandlerCount?<?0)?{??
  • ????pendingIdleHandlerCount?=?mIdleHandlers.size();??
  • }??
  • if?(pendingIdleHandlerCount?==?0)?{??
  • ????//?No?idle?handlers?to?run.??Loop?and?wait?some?more.??
  • ????mBlocked?=?true;??
  • ????continue;??
  • }??
  • ??
  • if?(mPendingIdleHandlers?==?null)?{??
  • ????mPendingIdleHandlers?=?new?IdleHandler[Math.max(pendingIdleHandlerCount,?4)];??
  • }??
  • mPendingIdleHandlers?=?mIdleHandlers.toArray(mPendingIdleHandlers);??
  • ?? ? ? ?如果沒有,即pendingIdleHandlerCount等于0,那下面的邏輯就不執行了,通過continue語句直接進入下一次循環,否則就要 把注冊在mIdleHandlers中的IdleHandler取出來,放在mPendingIdleHandlers數組中去。

    ?? ? ? ?接下來就是執行這些注冊了的IdleHanlder了:

    [java] view plaincopy
  • //?Run?the?idle?handlers.??
  • //?We?only?ever?reach?this?code?block?during?the?first?iteration.??
  • for?(int?i?=?0;?i?<?pendingIdleHandlerCount;?i++)?{??
  • ??????final?IdleHandler?idler?=?mPendingIdleHandlers[i];??
  • ??????mPendingIdleHandlers[i]?=?null;?//?release?the?reference?to?the?handler??
  • ??
  • ??????boolean?keep?=?false;??
  • ??????try?{??
  • ????????????keep?=?idler.queueIdle();??
  • ??????}?catch?(Throwable?t)?{??
  • ????????????Log.wtf("MessageQueue",?"IdleHandler?threw?exception",?t);??
  • ??????}??
  • ??
  • ??????if?(!keep)?{??
  • ????????????synchronized?(this)?{??
  • ????????????????????mIdleHandlers.remove(idler);??
  • ????????????}??
  • ??????}??
  • }??
  • ?? ? ? ? 執行完這些IdleHandler之后,線程下次調用nativePollOnce函數時,就不設置超時時間了,因為,很有可能在執行 IdleHandler的時候,已經有新的消息加入到消息隊列中去了,因此,要重置nextPollTimeoutMillis的值:

    [java] view plaincopy
  • //?While?calling?an?idle?handler,?a?new?message?could?have?been?delivered??
  • //?so?go?back?and?look?again?for?a?pending?message?without?waiting.??
  • nextPollTimeoutMillis?=?0;??
  • ?? ? ? ?分析完MessageQueue的這個next函數之后,我們就要深入分析一下JNI方法nativePollOnce了,看看它是如何進入等待狀態 的,這個函數定義在frameworks/base/core/jni/android_os_MessageQueue.cpp文件中:

    [cpp] view plaincopy
  • static?void?android_os_MessageQueue_nativePollOnce(JNIEnv*?env,?jobject?obj,??
  • ????????jint?ptr,?jint?timeoutMillis)?{??
  • ????NativeMessageQueue*?nativeMessageQueue?=?reinterpret_cast<NativeMessageQueue*>(ptr);??
  • ????nativeMessageQueue->pollOnce(timeoutMillis);??
  • }??
  • ?? ? ? ?這個函數首先是通過傳進入的參數ptr取回前面在Java層創建MessageQueue對象時在JNI層創建的NatvieMessageQueue對象,然后調用它的pollOnce函數:

    [cpp] view plaincopy
  • void?NativeMessageQueue::pollOnce(int?timeoutMillis)?{??
  • ????mLooper->pollOnce(timeoutMillis);??
  • }??
  • ?? ? ? ?這里將操作轉發給mLooper對象的pollOnce函數處理,這里的mLooper對象是在C++層的對象,它也是在前面在JNI層創建的 NatvieMessageQueue對象時創建的,它的pollOnce函數定義在frameworks/base/libs/utils /Looper.cpp文件中:

    [cpp] view plaincopy
  • int?Looper::pollOnce(int?timeoutMillis,?int*?outFd,?int*?outEvents,?void**?outData)?{??
  • ????int?result?=?0;??
  • ????for?(;;)?{??
  • ????????......??
  • ??
  • ????????if?(result?!=?0)?{??
  • ????????????......??
  • ??
  • ????????????return?result;??
  • ????????}??
  • ??
  • ????????result?=?pollInner(timeoutMillis);??
  • ????}??
  • }??
  • ?? ? ? ?為了方便討論,我們把這個函數的無關部分都去掉,它主要就是調用pollInner函數來進一步操作,如果pollInner返回值不等于0,這個函數就可以返回了。

    ?? ? ? ?函數pollInner的定義如下:

    [cpp] view plaincopy
  • int?Looper::pollInner(int?timeoutMillis)?{??
  • ????......??
  • ??
  • ????int?result?=?ALOOPER_POLL_WAKE;??
  • ??
  • ????......??
  • ??
  • #ifdef?LOOPER_USES_EPOLL??
  • ????struct?epoll_event?eventItems[EPOLL_MAX_EVENTS];??
  • ????int?eventCount?=?epoll_wait(mEpollFd,?eventItems,?EPOLL_MAX_EVENTS,?timeoutMillis);??
  • ????bool?acquiredLock?=?false;??
  • #else??
  • ????......??
  • #endif??
  • ??
  • ????if?(eventCount?<?0)?{??
  • ????????if?(errno?==?EINTR)?{??
  • ????????????goto?Done;??
  • ????????}??
  • ??
  • ????????LOGW("Poll?failed?with?an?unexpected?error,?errno=%d",?errno);??
  • ????????result?=?ALOOPER_POLL_ERROR;??
  • ????????goto?Done;??
  • ????}??
  • ??
  • ????if?(eventCount?==?0)?{??
  • ????????......??
  • ????????result?=?ALOOPER_POLL_TIMEOUT;??
  • ????????goto?Done;??
  • ????}??
  • ??
  • ????......??
  • ??
  • #ifdef?LOOPER_USES_EPOLL??
  • ????for?(int?i?=?0;?i?<?eventCount;?i++)?{??
  • ????????int?fd?=?eventItems[i].data.fd;??
  • ????????uint32_t?epollEvents?=?eventItems[i].events;??
  • ????????if?(fd?==?mWakeReadPipeFd)?{??
  • ????????????if?(epollEvents?&?EPOLLIN)?{??
  • ????????????????awoken();??
  • ????????????}?else?{??
  • ????????????????LOGW("Ignoring?unexpected?epoll?events?0x%x?on?wake?read?pipe.",?epollEvents);??
  • ????????????}??
  • ????????}?else?{??
  • ????????????......??
  • ????????}??
  • ????}??
  • ????if?(acquiredLock)?{??
  • ????????mLock.unlock();??
  • ????}??
  • Done:?;??
  • #else??
  • ????......??
  • #endif??
  • ??
  • ????......??
  • ??
  • ????return?result;??
  • }??
  • ?? ? ? ?這里,首先是調用epoll_wait函數來看看epoll專用文件描述符mEpollFd所監控的文件描述符是否有IO事件發生,它設置監控的超時時間為timeoutMillis:

    [cpp] view plaincopy
  • int?eventCount?=?epoll_wait(mEpollFd,?eventItems,?EPOLL_MAX_EVENTS,?timeoutMillis);??
  • ?? ? ? ?回憶一下前面的Looper的構造函數,我們在里面設置了要監控mWakeReadPipeFd文件描述符的EPOLLIN事件。

    ?? ? ? ?當mEpollFd所監控的文件描述符發生了要監控的IO事件后或者監控時間超時后,線程就從epoll_wait返回了,否則線程就會在epoll_wait函數中進入睡眠狀態了。返回后如果eventCount等于0,就說明是超時了:

    [cpp] view plaincopy
  • if?(eventCount?==?0)?{??
  • ????......??
  • ????result?=?ALOOPER_POLL_TIMEOUT;??
  • ????goto?Done;??
  • }??
  • ?? ? ? 如果eventCount不等于0,就說明發生要監控的事件:

    [cpp] view plaincopy
  • for?(int?i?=?0;?i?<?eventCount;?i++)?{??
  • ????int?fd?=?eventItems[i].data.fd;??
  • ????uint32_t?epollEvents?=?eventItems[i].events;??
  • ????if?(fd?==?mWakeReadPipeFd)?{??
  • ????????if?(epollEvents?&?EPOLLIN)?{??
  • ????????????awoken();??
  • ????????}?else?{??
  • ????????????LOGW("Ignoring?unexpected?epoll?events?0x%x?on?wake?read?pipe.",?epollEvents);??
  • ????????}??
  • ????}?else?{??
  • ????????????......??
  • ????}??
  • }??
  • ?? ? ? ?這里我們只關注mWakeReadPipeFd文件描述符上的事件,如果在mWakeReadPipeFd文件描述符上發生了EPOLLIN就說明應用 程序中的消息隊列里面有新的消息需要處理了,接下來它就會先調用awoken函數清空管道中把內容,以便下次再調用pollInner函數時,知道自從上 次處理完消息隊列中的消息后,有沒有新的消息加進來。

    ?? ? ? ?函數awoken的實現很簡單,它只是把管道中的內容都讀取出來:

    [cpp] view plaincopy
  • void?Looper::awoken()?{??
  • ????......??
  • ??
  • ????char?buffer[16];??
  • ????ssize_t?nRead;??
  • ????do?{??
  • ????????nRead?=?read(mWakeReadPipeFd,?buffer,?sizeof(buffer));??
  • ????}?while?((nRead?==?-1?&&?errno?==?EINTR)?||?nRead?==?sizeof(buffer));??
  • }??
  • ?? ? ? ?因為當其它的線程向應用程序的消息隊列加入新的消息時,會向這個管道寫入新的內容來通知應用程序主線程有新的消息需要處理了,下面我們分析消息的發送的時候將會看到。

    ?? ? ? ?這樣,消息的循環過程就分析完了,這部分邏輯還是比較復雜的,它利用Linux系統中的管道(pipe)進程間通信機制來實現消息的等待和處理,不過,了解了這部分內容之后,下面我們分析消息的發送和處理就簡單多了。

    ?? ? ? ?2. 消息的發送
    ?? ? ? ?應用程序的主線程準備就好消息隊列并且進入到消息循環后,其它地方就可以往這個消息隊列中發送消息了。我們繼續以文章開始介紹的Android應用程序啟動過程源代碼分析一文中的應用程序啟動過為例,說明應用程序是如何把消息加入到應用程序的消息隊列中去的。

    ?? ? ? ?在Android應用程序啟動過程源代碼分析這 篇文章的Step 30中,ActivityManagerService通過調用ApplicationThread類的scheduleLaunchActivity函 數通知應用程序,它可以加載應用程序的默認Activity了,這個函數定義在frameworks/base/core/java/android /app/ActivityThread.java文件中:

    [java] view plaincopy
  • public?final?class?ActivityThread?{????
  • ????
  • ????......????
  • ????
  • ????private?final?class?ApplicationThread?extends?ApplicationThreadNative?{????
  • ????
  • ????????......????
  • ????
  • ????????//?we?use?token?to?identify?this?activity?without?having?to?send?the????
  • ????????//?activity?itself?back?to?the?activity?manager.?(matters?more?with?ipc)????
  • ????????public?final?void?scheduleLaunchActivity(Intent?intent,?IBinder?token,?int?ident,????
  • ????????????????ActivityInfo?info,?Bundle?state,?List<ResultInfo>?pendingResults,????
  • ????????????????List<Intent>?pendingNewIntents,?boolean?notResumed,?boolean?isForward)?{????
  • ????????????ActivityClientRecord?r?=?new?ActivityClientRecord();????
  • ????
  • ????????????r.token?=?token;????
  • ????????????r.ident?=?ident;????
  • ????????????r.intent?=?intent;????
  • ????????????r.activityInfo?=?info;????
  • ????????????r.state?=?state;????
  • ????
  • ????????????r.pendingResults?=?pendingResults;????
  • ????????????r.pendingIntents?=?pendingNewIntents;????
  • ????
  • ????????????r.startsNotResumed?=?notResumed;????
  • ????????????r.isForward?=?isForward;????
  • ????
  • ????????????queueOrSendMessage(H.LAUNCH_ACTIVITY,?r);????
  • ????????}????
  • ????
  • ????????......????
  • ????
  • ????}????
  • ????
  • ????......????
  • }????
  • ?? ? ? ?這里把相關的參數都封裝成一個ActivityClientRecord對象r,然后調用queueOrSendMessage函數來往應用程序的消息 隊列中加入一個新的消息(H.LAUNCH_ACTIVITY),這個函數定義在frameworks/base/core/java/android /app/ActivityThread.java文件中:

    [java] view plaincopy
  • public?final?class?ActivityThread?{????
  • ????
  • ????......????
  • ????
  • ????private?final?class?ApplicationThread?extends?ApplicationThreadNative?{????
  • ????
  • ????????......????
  • ????
  • ????????//?if?the?thread?hasn't?started?yet,?we?don't?have?the?handler,?so?just????
  • ????????//?save?the?messages?until?we're?ready.????
  • ????????private?final?void?queueOrSendMessage(int?what,?Object?obj)?{????
  • ????????????queueOrSendMessage(what,?obj,?0,?0);????
  • ????????}????
  • ????
  • ????????......????
  • ????
  • ????????private?final?void?queueOrSendMessage(int?what,?Object?obj,?int?arg1,?int?arg2)?{????
  • ????????????synchronized?(this)?{????
  • ????????????????......????
  • ????????????????Message?msg?=?Message.obtain();????
  • ????????????????msg.what?=?what;????
  • ????????????????msg.obj?=?obj;????
  • ????????????????msg.arg1?=?arg1;????
  • ????????????????msg.arg2?=?arg2;????
  • ????????????????mH.sendMessage(msg);????
  • ????????????}????
  • ????????}????
  • ????
  • ????????......????
  • ????
  • ????}????
  • ????
  • ????......????
  • }????
  • ?? ? ? ?在queueOrSendMessage函數中,又進一步把上面傳進來的參數封裝成一個Message對象msg,然后通過 mH.sendMessage函數把這個消息對象msg加入到應用程序的消息隊列中去。這里的mH是ActivityThread類的成員變量,它的類型 為H,繼承于Handler類,它定義在frameworks/base/core/java/android/app /ActivityThread.java文件中:

    [java] view plaincopy
  • public?final?class?ActivityThread?{????
  • ????
  • ????......????
  • ????
  • ????private?final?class?H?extends?Handler?{????
  • ????
  • ????????......????
  • ????
  • ????????public?void?handleMessage(Message?msg)?{????
  • ????????????......????
  • ????????????switch?(msg.what)?{??????
  • ????????????......????
  • ????????????}????
  • ????
  • ????????......????
  • ????
  • ????}????
  • ????
  • ????......????
  • }???
  • ?? ? ? ?這個H類就是通過其成員函數handleMessage函數來處理消息的了,后面我們分析消息的處理過程時會看到。
    ?? ? ? ?ActivityThread類的這個mH成員變量是什么時候創建的呢?我們前面在分析應用程序的消息循環時,說到當應用程序進程啟動之后,就會加載 ActivityThread類的main函數里面,在這個main函數里面,在通過Looper類進入消息循環之前,會在當前進程中創建一個 ActivityThread實例:

    [java] view plaincopy
  • public?final?class?ActivityThread?{??
  • ????......??
  • ??
  • ????public?static?final?void?main(String[]?args)?{??
  • ????????......??
  • ??
  • ????????ActivityThread?thread?=?new?ActivityThread();??
  • ????????thread.attach(false);??
  • ??
  • ????????......??
  • ????}??
  • }??
  • ?? ? ? ?在創建這個實例的時候,就會同時創建其成員變量mH了:

    [java] view plaincopy
  • public?final?class?ActivityThread?{??
  • ????......??
  • ??
  • ????final?H?mH?=?new?H();??
  • ??
  • ????......??
  • }???
  • ?? ? ? ?前面說過,H類繼承于Handler類,因此,當創建這個H對象時,會調用Handler類的構造函數,這個函數定義在frameworks/base/core/java/android/os/Handler.java文件中:

    [java] view plaincopy
  • public?class?Handler?{??
  • ????......??
  • ??
  • ????public?Handler()?{??
  • ????????......??
  • ??
  • ????????mLooper?=?Looper.myLooper();??
  • ????????......??
  • ??
  • ????????mQueue?=?mLooper.mQueue;??
  • ????????......??
  • ????}??
  • ??
  • ??
  • ????final?MessageQueue?mQueue;??
  • ????final?Looper?mLooper;??
  • ????......??
  • }??
  • ?? ? ? ?在Hanlder類的構造函數中,主要就是初始成員變量mLooper和mQueue了。這里的myLooper是Looper類的靜態成員函數,通過 它來獲得一個Looper對象,這個Looper對象就是前面我們在分析消息循環時,在ActivityThread類的main函數中通過 Looper.prepareMainLooper函數創建的。Looper.myLooper函數實現在frameworks/base/core /java/android/os/Looper.java文件中:

    [java] view plaincopy
  • public?class?Looper?{??
  • ????......??
  • ??
  • ????public?static?final?Looper?myLooper()?{??
  • ????????return?(Looper)sThreadLocal.get();??
  • ????}??
  • ??
  • ????......??
  • }??
  • ?? ? ? ?有了這個Looper對象后,就可以通過Looper.mQueue來訪問應用程序的消息隊列了。

    ?? ? ? ?有了這個Handler對象mH后,就可以通過它來往應用程序的消息隊列中加入新的消息了。回到前面的queueOrSendMessage函數中,當 它準備好了一個Message對象msg后,就開始調用mH.sendMessage函數來發送消息了,這個函數定義在frameworks/base /core/java/android/os/Handler.java文件中:

    [java] view plaincopy
  • public?class?Handler?{??
  • ????......??
  • ??
  • ????public?final?boolean?sendMessage(Message?msg)??
  • ????{??
  • ????????return?sendMessageDelayed(msg,?0);??
  • ????}??
  • ??
  • ????public?final?boolean?sendMessageDelayed(Message?msg,?long?delayMillis)??
  • ????{??
  • ????????if?(delayMillis?<?0)?{??
  • ????????????delayMillis?=?0;??
  • ????????}??
  • ????????return?sendMessageAtTime(msg,?SystemClock.uptimeMillis()?+?delayMillis);??
  • ????}??
  • ??
  • ????public?boolean?sendMessageAtTime(Message?msg,?long?uptimeMillis)??
  • ????{??
  • ????????boolean?sent?=?false;??
  • ????????MessageQueue?queue?=?mQueue;??
  • ????????if?(queue?!=?null)?{??
  • ????????????msg.target?=?this;??
  • ????????????sent?=?queue.enqueueMessage(msg,?uptimeMillis);??
  • ????????}??
  • ????????else?{??
  • ????????????......??
  • ????????}??
  • ????????return?sent;??
  • ????}??
  • ??
  • ????......??
  • }??
  • ?? ? ? ?在發送消息時,是可以指定消息的處理時間的,但是通過sendMessage函數發送的消息的處理時間默認就為當前時間,即表示要馬上處理,因此,從 sendMessage函數中調用sendMessageDelayed函數,傳入的時間參數為0,表示這個消息不要延時處理,而在 sendMessageDelayed函數中,則會先獲得當前時間,然后加上消息要延時處理的時間,即得到這個處理這個消息的絕對時間,然后調用 sendMessageAtTime函數來把消息加入到應用程序的消息隊列中去。

    ?? ? ? ?在sendMessageAtTime函數,首先得到應用程序的消息隊列mQueue,這是在Handler對象構造時初始化好的,前面已經分析過了,接著設置這個消息的目標對象target,即這個消息最終是由誰來處理的:

    [java] view plaincopy
  • msg.target?=?this;??
  • ?? ? ? ?這里將它賦值為this,即表示這個消息最終由這個Handler對象來處理,即由ActivityThread對象的mH成員變量來處理。

    ?? ? ? ?函數最后調用queue.enqueueMessage來把這個消息加入到應用程序的消息隊列中去,這個函數實現在frameworks/base/core/java/android/os/MessageQueue.java文件中:

    [java] view plaincopy
  • public?class?MessageQueue?{??
  • ????......??
  • ??
  • ????final?boolean?enqueueMessage(Message?msg,?long?when)?{??
  • ????????......??
  • ??
  • ????????final?boolean?needWake;??
  • ????????synchronized?(this)?{??
  • ????????????......??
  • ??
  • ????????????msg.when?=?when;??
  • ????????????//Log.d("MessageQueue",?"Enqueing:?"?+?msg);??
  • ????????????Message?p?=?mMessages;??
  • ????????????if?(p?==?null?||?when?==?0?||?when?<?p.when)?{??
  • ????????????????msg.next?=?p;??
  • ????????????????mMessages?=?msg;??
  • ????????????????needWake?=?mBlocked;?//?new?head,?might?need?to?wake?up??
  • ????????????}?else?{??
  • ????????????????Message?prev?=?null;??
  • ????????????????while?(p?!=?null?&&?p.when?<=?when)?{??
  • ????????????????????prev?=?p;??
  • ????????????????????p?=?p.next;??
  • ????????????????}??
  • ????????????????msg.next?=?prev.next;??
  • ????????????????prev.next?=?msg;??
  • ????????????????needWake?=?false;?//?still?waiting?on?head,?no?need?to?wake?up??
  • ????????????}??
  • ??
  • ????????}??
  • ????????if?(needWake)?{??
  • ????????????nativeWake(mPtr);??
  • ????????}??
  • ????????return?true;??
  • ????}??
  • ??
  • ????......??
  • }??
  • ?? ? ? ?把消息加入到消息隊列時,分兩種情況,一種當前消息隊列為空時,這時候應用程序的主線程一般就是處于空閑等待狀態了,這時候就要喚醒它,另一種情況是應 用程序的消息隊列不為空,這時候就不需要喚醒應用程序的主線程了,因為這時候它一定是在忙著處于消息隊列中的消息,因此不會處于空閑等待的狀態。

    ?? ? ? ?第一種情況比較簡單,只要把消息放在消息隊列頭就可以了:

    [java] view plaincopy
  • msg.next?=?p;??
  • mMessages?=?msg;??
  • needWake?=?mBlocked;?//?new?head,?might?need?to?wake?up??
  • ?? ? ? ?第二種情況相對就比較復雜一些了,前面我們說過,當往消息隊列中發送消息時,是可以指定消息的處理時間的,而消息隊列中的消息,就是按照這個時間從小到 大來排序的,因此,當把新的消息加入到消息隊列時,就要根據它的處理時間來找到合適的位置,然后再放進消息隊列中去:

    [java] view plaincopy
  • Message?prev?=?null;??
  • while?(p?!=?null?&&?p.when?<=?when)?{??
  • ????prev?=?p;??
  • ????p?=?p.next;??
  • }??
  • msg.next?=?prev.next;??
  • prev.next?=?msg;??
  • needWake?=?false;?//?still?waiting?on?head,?no?need?to?wake?up??
  • ?? ? ? ?把消息加入到消息隊列去后,如果應用程序的主線程正處于空閑等待狀態,就需要調用natvieWake函數來喚醒它了,這是一個JNI方法,定義在 frameworks/base/core/jni/android_os_MessageQueue.cpp文件中:

    [java] view plaincopy
  • static?void?android_os_MessageQueue_nativeWake(JNIEnv*?env,?jobject?obj,?jint?ptr)?{??
  • ????NativeMessageQueue*?nativeMessageQueue?=?reinterpret_cast<NativeMessageQueue*>(ptr);??
  • ????return?nativeMessageQueue->wake();??
  • }??
  • ?? ? ? ?這個JNI層的NativeMessageQueue對象我們在前面分析消息循環的時候創建好的,保存在Java層的MessageQueue對象的 mPtr成員變量中,這里把它取回來之后,就調用它的wake函數來喚醒應用程序的主線程,這個函數也是定義在frameworks/base/core /jni/android_os_MessageQueue.cpp文件中:

    [java] view plaincopy
  • void?NativeMessageQueue::wake()?{??
  • ????mLooper->wake();??
  • }??
  • ?? ? ? ?這里它又通過成員變量mLooper的wake函數來執行操作,這里的mLooper成員變量是一個C++層實現的Looper對象,它定義在frameworks/base/libs/utils/Looper.cpp文件中:

    [java] view plaincopy
  • void?Looper::wake()?{??
  • ????......??
  • ??
  • ????ssize_t?nWrite;??
  • ????do?{??
  • ????????nWrite?=?write(mWakeWritePipeFd,?"W",?1);??
  • ????}?while?(nWrite?==?-1?&&?errno?==?EINTR);??
  • ??
  • ????.......??
  • }??
  • ?? ? ? ?這個wake函數很簡單,只是通過打開文件描述符mWakeWritePipeFd往管道的寫入一個"W"字符串。其實,往管道寫入什么內容并不重要, 往管道寫入內容的目的是為了喚醒應用程序的主線程。前面我們在分析應用程序的消息循環時說到,當應用程序的消息隊列中沒有消息處理時,應用程序的主線程就 會進入空閑等待狀態,而這個空閑等待狀態就是通過調用這個Looper類的pollInner函數來進入的,具體就是在pollInner函數中調用 epoll_wait函數來等待管道中有內容可讀的。

    ?? ? ? ?這時候既然管道中有內容可讀了,應用程序的主線程就會從這里的Looper類的pollInner函數返回到JNI層的nativePollOnce函 數,最后返回到Java層中的MessageQueue.next函數中去,這里它就會發現消息隊列中有新的消息需要處理了,于就會處理這個消息。

    ?? ? ? ?3. 消息的處理

    ?? ? ? ?前面在分析消息循環時,說到應用程序的主線程是在Looper類的loop成員函數中進行消息循環過程的,這個函數定義在frameworks/base/core/java/android/os/Looper.java文件中:

    [java] view plaincopy
  • public?class?Looper?{??
  • ????......??
  • ??
  • ????public?static?final?void?loop()?{??
  • ????????Looper?me?=?myLooper();??
  • ????????MessageQueue?queue?=?me.mQueue;??
  • ??
  • ????????......??
  • ??
  • ????????while?(true)?{??
  • ????????????Message?msg?=?queue.next();?//?might?block??
  • ????????????......??
  • ??
  • ????????????if?(msg?!=?null)?{??
  • ????????????????if?(msg.target?==?null)?{??
  • ????????????????????//?No?target?is?a?magic?identifier?for?the?quit?message.??
  • ????????????????????return;??
  • ????????????????}??
  • ??
  • ????????????????......??
  • ??
  • ????????????????msg.target.dispatchMessage(msg);??
  • ??????????????????
  • ????????????????......??
  • ??
  • ????????????????msg.recycle();??
  • ????????????}??
  • ????????}??
  • ????}??
  • ??
  • ????......??
  • }??
  • ?? ? ? ?它從消息隊列中獲得消息對象msg后,就會調用它的target成員變量的dispatchMessage函數來處理這個消息。在前面分析消息的發送時 說過,這個消息對象msg的成員變量target是在發送消息的時候設置好的,一般就通過哪個Handler來發送消息,就通過哪個Handler來處理 消息。

    ?? ? ? ?我們繼續以前面分析消息的發送時所舉的例子來分析消息的處理過程。前面說到,在Android應用程序啟動過程源代碼分析這 篇文章的Step 30中,ActivityManagerService通過調用ApplicationThread類的scheduleLaunchActivity函 數通知應用程序,它可以加載應用程序的默認Activity了,而ApplicationThread類的scheduleLaunchActivity 函數最終把這個請求封裝成一個消息,然后通過ActivityThread類的成員變量mH來把這個消息加入到應用程序的消息隊列中去。現在要對這個消息 進行處理了,于是就會調用H類的dispatchMessage函數進行處理。

    ?? ? ? ?H類沒有實現自己的dispatchMessage函數,但是它繼承了父類Handler的dispatchMessage函數,這個函數定義在 frameworks/base/core/java/android/os/ Handler.java文件中:

    [java] view plaincopy
  • public?class?Handler?{??
  • ????......??
  • ??
  • ????public?void?dispatchMessage(Message?msg)?{??
  • ????????if?(msg.callback?!=?null)?{??
  • ????????????handleCallback(msg);??
  • ????????}?else?{??
  • ????????????if?(mCallback?!=?null)?{??
  • ????????????????if?(mCallback.handleMessage(msg))?{??
  • ????????????????????return;??
  • ????????????????}??
  • ????????????}??
  • ????????????handleMessage(msg);??
  • ????????}??
  • ????}??
  • ??
  • ????......??
  • }??
  • ?? ? ? ?這里的消息對象msg的callback成員變量和Handler類的mCallBack成員變量一般都為null,于是,就會調用Handler類的 handleMessage函數來處理這個消息,由于H類在繼承Handler類時,重寫了handleMessage函數,因此,這里調用的實際上是H 類的handleMessage函數,這個函數定義在frameworks/base/core/java/android/app /ActivityThread.java文件中:

    [java] view plaincopy
  • public?final?class?ActivityThread?{????
  • ????
  • ????......????
  • ????
  • ????private?final?class?H?extends?Handler?{????
  • ????
  • ????????......????
  • ????
  • ????????public?void?handleMessage(Message?msg)?{????
  • ????????????......????
  • ????????????switch?(msg.what)?{????
  • ????????????case?LAUNCH_ACTIVITY:?{????
  • ????????????????ActivityClientRecord?r?=?(ActivityClientRecord)msg.obj;????
  • ????
  • ????????????????r.packageInfo?=?getPackageInfoNoCheck(????
  • ????????????????????r.activityInfo.applicationInfo);????
  • ????????????????handleLaunchActivity(r,?null);????
  • ????????????}?break;????
  • ????????????......????
  • ????????????}????
  • ????
  • ????????......????
  • ????
  • ????}????
  • ????
  • ????......????
  • }????
  • ?? ? ? ? 因為前面在分析消息的發送時所舉的例子中,發送的消息的類型為H.LAUNCH_ACTIVITY,因此,這里就會調用ActivityThread類的handleLaunchActivity函數來真正地處理這個消息了,后面的具體過程就可以參考Android應用程序啟動過程源代碼分析這篇文章了。

    ?? ? ? ? 至此,我們就從消息循環、消息發送和消息處理三個部分分析完Android應用程序的消息處理機制了,為了更深理解,這里我們對其中的一些要點作一個總結:

    ?? ? ? ? A. Android應用程序的消息處理機制由消息循環、消息發送和消息處理三個部分組成的。

    ?? ? ? ? B. Android應用程序的主線程在進入消息循環過程前,會在內部創建一個Linux管道(Pipe),這個管道的作用是使得Android應用程序主線程 在消息隊列為空時可以進入空閑等待狀態,并且使得當應用程序的消息隊列有消息需要處理時喚醒應用程序的主線程。

    ?? ? ? ? C. Android應用程序的主線程進入空閑等待狀態的方式實際上就是在管道的讀端等待管道中有新的內容可讀,具體來說就是是通過Linux系統的Epoll機制中的epoll_wait函數進行的。

    ?? ? ? ? D. 當往Android應用程序的消息隊列中加入新的消息時,會同時往管道中的寫端寫入內容,通過這種方式就可以喚醒正在等待消息到來的應用程序主線程。

    ?? ? ? ? E. 當應用程序主線程在進入空閑等待前,會認為當前線程處理空閑狀態,于是就會調用那些已經注冊了的IdleHandler接口,使得應用程序有機會在空閑的時候處理一些事情。

    老羅的新浪微博:http://weibo.com/shengyangluo,歡迎關注!

    轉載于:https://www.cnblogs.com/Free-Thinker/p/4142491.html

    總結

    以上是生活随笔為你收集整理的Android应用程序消息处理机制(Looper、Handler)分析的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    国内精品九九久久久精品 | 亚洲理论电影在线观看 | 成在人线av无码免观看麻豆 | 荫蒂被男人添的好舒服爽免费视频 | 荫蒂被男人添的好舒服爽免费视频 | 午夜福利试看120秒体验区 | 精品国产乱码久久久久乱码 | 国产精品亚洲а∨无码播放麻豆 | 久久久成人毛片无码 | 中文无码成人免费视频在线观看 | 国产深夜福利视频在线 | 捆绑白丝粉色jk震动捧喷白浆 | 免费看少妇作爱视频 | 人人妻人人澡人人爽欧美一区 | 最新国产乱人伦偷精品免费网站 | 永久免费观看国产裸体美女 | 成人亚洲精品久久久久 | 无码精品人妻一区二区三区av | 日本精品久久久久中文字幕 | 久久无码专区国产精品s | 欧美国产日韩久久mv | 男女猛烈xx00免费视频试看 | 亚洲综合无码一区二区三区 | 久久久无码中文字幕久... | 麻花豆传媒剧国产免费mv在线 | 丰满人妻一区二区三区免费视频 | √8天堂资源地址中文在线 | 亚洲色欲色欲欲www在线 | 国产色在线 | 国产 | 精品国产一区av天美传媒 | 伊人色综合久久天天小片 | 久久久婷婷五月亚洲97号色 | 无遮无挡爽爽免费视频 | 性欧美疯狂xxxxbbbb | 少妇无码av无码专区在线观看 | 亚洲精品一区二区三区四区五区 | 又大又硬又黄的免费视频 | 老熟女乱子伦 | 麻豆av传媒蜜桃天美传媒 | 欧美刺激性大交 | 装睡被陌生人摸出水好爽 | 2020久久超碰国产精品最新 | 日韩av激情在线观看 | 国产激情无码一区二区app | 青青青爽视频在线观看 | 中文字幕无码热在线视频 | 99久久婷婷国产综合精品青草免费 | 国产乱人偷精品人妻a片 | 夜夜影院未满十八勿进 | 日韩av无码一区二区三区 | 国产亚洲精品久久久久久国模美 | 欧美阿v高清资源不卡在线播放 | 国内综合精品午夜久久资源 | 无遮无挡爽爽免费视频 | 久久久久亚洲精品男人的天堂 | aⅴ亚洲 日韩 色 图网站 播放 | 鲁一鲁av2019在线 | 色五月丁香五月综合五月 | 久久精品国产99精品亚洲 | 极品尤物被啪到呻吟喷水 | 亚洲男人av香蕉爽爽爽爽 | 日欧一片内射va在线影院 | 亚洲性无码av中文字幕 | 国产偷抇久久精品a片69 | 日韩人妻无码一区二区三区久久99 | 欧美xxxx黑人又粗又长 | 亚洲精品久久久久avwww潮水 | 中文字幕乱码人妻二区三区 | 人妻少妇被猛烈进入中文字幕 | 色婷婷久久一区二区三区麻豆 | 欧美人与牲动交xxxx | 成人免费视频视频在线观看 免费 | 乱人伦中文视频在线观看 | 野狼第一精品社区 | 国产亚洲tv在线观看 | 国产麻豆精品精东影业av网站 | 亚洲中文字幕无码中字 | 亚洲国产精品无码久久久久高潮 | 天天拍夜夜添久久精品大 | www国产亚洲精品久久久日本 | 国产成人一区二区三区在线观看 | 精品成在人线av无码免费看 | 日日躁夜夜躁狠狠躁 | 色诱久久久久综合网ywww | 亚洲一区二区三区国产精华液 | 亚洲成色www久久网站 | 中文无码伦av中文字幕 | 成人av无码一区二区三区 | 日本熟妇乱子伦xxxx | 欧美国产日韩亚洲中文 | 国产香蕉尹人综合在线观看 | 久久伊人色av天堂九九小黄鸭 | 国产精品久久久av久久久 | 日韩视频 中文字幕 视频一区 | 奇米影视7777久久精品人人爽 | 日韩欧美中文字幕公布 | 国产精品美女久久久网av | 国产精品亚洲а∨无码播放麻豆 | 日日摸夜夜摸狠狠摸婷婷 | 国产免费久久精品国产传媒 | 亚洲天堂2017无码 | 亚洲爆乳无码专区 | 欧美午夜特黄aaaaaa片 | 欧美熟妇另类久久久久久多毛 | 天堂亚洲2017在线观看 | 国产成人人人97超碰超爽8 | 国产一区二区不卡老阿姨 | 中文字幕无码乱人伦 | 成人性做爰aaa片免费看不忠 | 麻豆md0077饥渴少妇 | 国产绳艺sm调教室论坛 | 一区二区三区乱码在线 | 欧洲 | 国产精品久久久久久亚洲影视内衣 | 一二三四在线观看免费视频 | 玩弄少妇高潮ⅹxxxyw | 久久国产精品精品国产色婷婷 | 中文字幕无码人妻少妇免费 | 日韩精品成人一区二区三区 | 日本熟妇浓毛 | 国产精品久久久久影院嫩草 | 亚洲小说春色综合另类 | 98国产精品综合一区二区三区 | 亚洲熟悉妇女xxx妇女av | 久久综合网欧美色妞网 | 午夜时刻免费入口 | 成熟人妻av无码专区 | 久久久久国色av免费观看性色 | 亚洲一区二区三区四区 | 国产精品久久精品三级 | 99久久精品午夜一区二区 | 狠狠cao日日穞夜夜穞av | 精品欧美一区二区三区久久久 | 熟女少妇人妻中文字幕 | 少妇高潮一区二区三区99 | 乌克兰少妇xxxx做受 | 成人动漫在线观看 | 国产午夜无码精品免费看 | 正在播放老肥熟妇露脸 | 日日天日日夜日日摸 | 精品国产青草久久久久福利 | 精品国产一区二区三区四区 | 无码人妻精品一区二区三区不卡 | 国精产品一品二品国精品69xx | 国产精品无码成人午夜电影 | 国产国产精品人在线视 | 天天摸天天碰天天添 | 熟女少妇人妻中文字幕 | 一二三四社区在线中文视频 | 色 综合 欧美 亚洲 国产 | 啦啦啦www在线观看免费视频 | 久久99精品久久久久婷婷 | 少妇性俱乐部纵欲狂欢电影 | 露脸叫床粗话东北少妇 | 3d动漫精品啪啪一区二区中 | 亚洲精品午夜无码电影网 | 巨爆乳无码视频在线观看 | 日本精品久久久久中文字幕 | 中文无码伦av中文字幕 | 高清国产亚洲精品自在久久 | 国内老熟妇对白xxxxhd | 国产综合色产在线精品 | 亚洲高清偷拍一区二区三区 | 少妇无码一区二区二三区 | 久久综合给久久狠狠97色 | 国产精品亚洲а∨无码播放麻豆 | 伊人久久婷婷五月综合97色 | 波多野42部无码喷潮在线 | 亚洲综合在线一区二区三区 | 国产午夜亚洲精品不卡 | 偷窥日本少妇撒尿chinese | 精品欧洲av无码一区二区三区 | 人妻少妇精品无码专区动漫 | 国产亚洲精品久久久久久久久动漫 | 骚片av蜜桃精品一区 | 永久免费精品精品永久-夜色 | 免费无码av一区二区 | 亚洲精品国偷拍自产在线观看蜜桃 | 久久国产精品_国产精品 | 精品无人区无码乱码毛片国产 | 少妇太爽了在线观看 | 麻豆国产人妻欲求不满谁演的 | 人妻夜夜爽天天爽三区 | 超碰97人人做人人爱少妇 | 久久伊人色av天堂九九小黄鸭 | 久精品国产欧美亚洲色aⅴ大片 | 兔费看少妇性l交大片免费 | 香蕉久久久久久av成人 | 精品人妻人人做人人爽夜夜爽 | 亚洲va中文字幕无码久久不卡 | 正在播放东北夫妻内射 | 国产精品a成v人在线播放 | 六月丁香婷婷色狠狠久久 | 欧美黑人性暴力猛交喷水 | 国产九九九九九九九a片 | 国产成人无码区免费内射一片色欲 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 欧美老熟妇乱xxxxx | 18精品久久久无码午夜福利 | 性生交大片免费看l | 一个人看的www免费视频在线观看 | 日日碰狠狠躁久久躁蜜桃 | 国精品人妻无码一区二区三区蜜柚 | 色妞www精品免费视频 | 久久久久av无码免费网 | 一本无码人妻在中文字幕免费 | 精品少妇爆乳无码av无码专区 | 天天综合网天天综合色 | 欧美第一黄网免费网站 | 日韩av激情在线观看 | 久久国产36精品色熟妇 | 久久99精品国产麻豆蜜芽 | 日欧一片内射va在线影院 | 一本久久伊人热热精品中文字幕 | 国产激情无码一区二区 | 天堂亚洲2017在线观看 | 青青青爽视频在线观看 | 欧美性生交活xxxxxdddd | 欧美熟妇另类久久久久久不卡 | 精品一区二区三区波多野结衣 | 男女猛烈xx00免费视频试看 | 国产成人一区二区三区别 | 国产在线aaa片一区二区99 | 国产精品鲁鲁鲁 | 国语自产偷拍精品视频偷 | 18黄暴禁片在线观看 | 午夜性刺激在线视频免费 | 免费人成在线观看网站 | 国语精品一区二区三区 | 丰满人妻翻云覆雨呻吟视频 | 亚洲熟妇色xxxxx欧美老妇y | 亚洲成av人片在线观看无码不卡 | 久久久久亚洲精品男人的天堂 | 中文字幕人成乱码熟女app | 老司机亚洲精品影院 | 熟女俱乐部五十路六十路av | 97夜夜澡人人爽人人喊中国片 | 日韩欧美成人免费观看 | 国产免费观看黄av片 | 免费无码一区二区三区蜜桃大 | 亚拍精品一区二区三区探花 | 久青草影院在线观看国产 | 国产绳艺sm调教室论坛 | 麻豆人妻少妇精品无码专区 | 欧美野外疯狂做受xxxx高潮 | 粉嫩少妇内射浓精videos | 国产手机在线αⅴ片无码观看 | 欧洲美熟女乱又伦 | 1000部啪啪未满十八勿入下载 | 亚洲精品一区二区三区婷婷月 | 无码人妻黑人中文字幕 | 亚洲人成网站在线播放942 | 亚洲 激情 小说 另类 欧美 | 狠狠色噜噜狠狠狠狠7777米奇 | 少妇人妻大乳在线视频 | 国产亚洲精品久久久久久大师 | 国产欧美熟妇另类久久久 | 高清不卡一区二区三区 | 日本欧美一区二区三区乱码 | 欧美日本精品一区二区三区 | 欧洲vodafone精品性 | 精品熟女少妇av免费观看 | 黑人粗大猛烈进出高潮视频 | 欧洲vodafone精品性 | 久久www免费人成人片 | 国产av一区二区精品久久凹凸 | 欧美老人巨大xxxx做受 | 精品成在人线av无码免费看 | 国产偷抇久久精品a片69 | 秋霞成人午夜鲁丝一区二区三区 | 亚洲成av人影院在线观看 | 亚洲日韩av一区二区三区四区 | 久久99精品国产麻豆蜜芽 | 中文字幕无线码 | 亚洲精品午夜无码电影网 | 中文字幕亚洲情99在线 | 久久国产精品_国产精品 | 麻豆国产丝袜白领秘书在线观看 | 国产成人无码专区 | 扒开双腿疯狂进出爽爽爽视频 | 妺妺窝人体色www在线小说 | 成人欧美一区二区三区黑人免费 | 日本成熟视频免费视频 | 国产口爆吞精在线视频 | 成人精品视频一区二区三区尤物 | 久久久www成人免费毛片 | 西西人体www44rt大胆高清 | 国产极品美女高潮无套在线观看 | 丰满少妇人妻久久久久久 | 久久aⅴ免费观看 | 国产熟妇高潮叫床视频播放 | 香港三级日本三级妇三级 | 中文字幕+乱码+中文字幕一区 | 亚洲精品午夜国产va久久成人 | 伊人久久婷婷五月综合97色 | 老司机亚洲精品影院 | 99re在线播放 | 亚洲精品无码人妻无码 | 国精品人妻无码一区二区三区蜜柚 | 国产精品18久久久久久麻辣 | 国产综合久久久久鬼色 | 欧美丰满熟妇xxxx性ppx人交 | 国产成人精品一区二区在线小狼 | 欧美 丝袜 自拍 制服 另类 | 帮老师解开蕾丝奶罩吸乳网站 | 亚洲无人区午夜福利码高清完整版 | 国产亚洲欧美在线专区 | 日韩少妇白浆无码系列 | 3d动漫精品啪啪一区二区中 | 欧美熟妇另类久久久久久多毛 | 又大又黄又粗又爽的免费视频 | 国内老熟妇对白xxxxhd | 亚洲成av人综合在线观看 | 强辱丰满人妻hd中文字幕 | 一区二区三区乱码在线 | 欧洲 | 99久久婷婷国产综合精品青草免费 | 男女猛烈xx00免费视频试看 | 亚洲欧美国产精品专区久久 | 丝袜人妻一区二区三区 | 4hu四虎永久在线观看 | 无码人妻丰满熟妇区五十路百度 | 免费网站看v片在线18禁无码 | 午夜福利试看120秒体验区 | 综合网日日天干夜夜久久 | 国产欧美精品一区二区三区 | 婷婷丁香六月激情综合啪 | 特大黑人娇小亚洲女 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 中文字幕无线码免费人妻 | 国产成人精品优优av | 欧美 丝袜 自拍 制服 另类 | 日产精品高潮呻吟av久久 | 精品亚洲成av人在线观看 | 98国产精品综合一区二区三区 | av在线亚洲欧洲日产一区二区 | 久久久国产精品无码免费专区 | 日本xxxx色视频在线观看免费 | 成人免费视频在线观看 | 亚洲色www成人永久网址 | 国产一区二区三区四区五区加勒比 | 国产精品丝袜黑色高跟鞋 | 久青草影院在线观看国产 | 亚洲精品综合五月久久小说 | 国产成人综合色在线观看网站 | 无码人妻丰满熟妇区毛片18 | 亚洲爆乳无码专区 | 亚洲自偷精品视频自拍 | 日日碰狠狠丁香久燥 | 天天摸天天碰天天添 | 日本xxxx色视频在线观看免费 | 国产免费观看黄av片 | 国产成人精品无码播放 | 日本精品少妇一区二区三区 | 久久久久99精品成人片 | 无码人妻少妇伦在线电影 | 熟女少妇在线视频播放 | 99久久无码一区人妻 | 亚洲色在线无码国产精品不卡 | 国产精品人妻一区二区三区四 | 亚洲熟女一区二区三区 | 亚洲欧洲日本综合aⅴ在线 | 中文字幕人妻无码一夲道 | 日韩av无码一区二区三区 | 欧美人与禽zoz0性伦交 | 亚洲 a v无 码免 费 成 人 a v | 国产成人人人97超碰超爽8 | 国产精品无码成人午夜电影 | 亚洲精品综合一区二区三区在线 | 成人免费视频在线观看 | 久久亚洲a片com人成 | 亚洲色无码一区二区三区 | 久久精品丝袜高跟鞋 | 久久人人97超碰a片精品 | 国产精品久久久久无码av色戒 | 男女爱爱好爽视频免费看 | 夜精品a片一区二区三区无码白浆 | 久激情内射婷内射蜜桃人妖 | 亚洲综合另类小说色区 | 欧洲精品码一区二区三区免费看 | 亚洲国产精品一区二区第一页 | 狠狠cao日日穞夜夜穞av | 永久免费观看美女裸体的网站 | 国产极品美女高潮无套在线观看 | 三上悠亚人妻中文字幕在线 | 免费无码肉片在线观看 | 色一情一乱一伦一视频免费看 | 亚洲色无码一区二区三区 | 亚洲综合色区中文字幕 | 四虎国产精品一区二区 | 成人试看120秒体验区 | 亚洲精品一区二区三区大桥未久 | 夜先锋av资源网站 | 国产亚洲精品久久久久久久 | 亚洲国产精品一区二区第一页 | 久久久久99精品国产片 | 久激情内射婷内射蜜桃人妖 | 欧美成人高清在线播放 | 国产精品久免费的黄网站 | 国产精品美女久久久 | 国产免费久久久久久无码 | 久久国产精品萌白酱免费 | 色诱久久久久综合网ywww | 欧美xxxxx精品 | 国产成人无码区免费内射一片色欲 | 图片小说视频一区二区 | 亚洲 激情 小说 另类 欧美 | 日日碰狠狠丁香久燥 | 在线天堂新版最新版在线8 | www国产亚洲精品久久网站 | 国产在线精品一区二区三区直播 | 成年美女黄网站色大免费全看 | 四十如虎的丰满熟妇啪啪 | 精品aⅴ一区二区三区 | 少妇愉情理伦片bd | 国产做国产爱免费视频 | 人人澡人人透人人爽 | 亚洲国产一区二区三区在线观看 | 亚洲国产高清在线观看视频 | 51国偷自产一区二区三区 | 999久久久国产精品消防器材 | 午夜精品一区二区三区的区别 | 男人的天堂av网站 | 亚洲经典千人经典日产 | 免费视频欧美无人区码 | 老司机亚洲精品影院 | 强伦人妻一区二区三区视频18 | 人妻夜夜爽天天爽三区 | 国产艳妇av在线观看果冻传媒 | 午夜精品一区二区三区在线观看 | 十八禁视频网站在线观看 | 亚洲午夜无码久久 | 国产av久久久久精东av | 国产亲子乱弄免费视频 | 丰满人妻翻云覆雨呻吟视频 | 精品偷拍一区二区三区在线看 | 免费看男女做好爽好硬视频 | 中文字幕无码日韩欧毛 | 久久99热只有频精品8 | 国产精品视频免费播放 | 国产亚洲欧美在线专区 | 日韩 欧美 动漫 国产 制服 | 老太婆性杂交欧美肥老太 | 亚洲精品国偷拍自产在线观看蜜桃 | 又色又爽又黄的美女裸体网站 | www国产精品内射老师 | 亚洲人亚洲人成电影网站色 | 久久久久久久人妻无码中文字幕爆 | 中国女人内谢69xxxxxa片 | 蜜桃av抽搐高潮一区二区 | 内射欧美老妇wbb | 中文字幕av日韩精品一区二区 | 清纯唯美经典一区二区 | 男女下面进入的视频免费午夜 | 日产精品高潮呻吟av久久 | 成年女人永久免费看片 | 图片区 小说区 区 亚洲五月 | 亚洲精品成人福利网站 | 青春草在线视频免费观看 | 国产精品久久久久久久9999 | 国产成人无码专区 | a在线观看免费网站大全 | 狠狠躁日日躁夜夜躁2020 | 狂野欧美激情性xxxx | 夜精品a片一区二区三区无码白浆 | 婷婷综合久久中文字幕蜜桃三电影 | 国内精品久久久久久中文字幕 | 美女毛片一区二区三区四区 | 欧美三级不卡在线观看 | 色婷婷久久一区二区三区麻豆 | 日韩av无码一区二区三区 | 狂野欧美激情性xxxx | 国内老熟妇对白xxxxhd | 国产综合久久久久鬼色 | 免费观看又污又黄的网站 | 偷窥村妇洗澡毛毛多 | 牲交欧美兽交欧美 | 欧美高清在线精品一区 | 俄罗斯老熟妇色xxxx | 特级做a爰片毛片免费69 | 无码福利日韩神码福利片 | 爆乳一区二区三区无码 | 西西人体www44rt大胆高清 | 亚洲 日韩 欧美 成人 在线观看 | 丰腴饱满的极品熟妇 | 国内揄拍国内精品少妇国语 | 亚洲人成网站在线播放942 | 色婷婷久久一区二区三区麻豆 | 人妻少妇精品久久 | 亚洲欧美国产精品久久 | 999久久久国产精品消防器材 | 国产精品无码一区二区桃花视频 | 国产色xx群视频射精 | 日本一卡2卡3卡四卡精品网站 | 波多野42部无码喷潮在线 | 久久久久亚洲精品男人的天堂 | 无码人妻精品一区二区三区不卡 | 欧美猛少妇色xxxxx | 无遮无挡爽爽免费视频 | 久精品国产欧美亚洲色aⅴ大片 | 国内综合精品午夜久久资源 | 东京无码熟妇人妻av在线网址 | 中文字幕日产无线码一区 | 亚洲精品一区二区三区四区五区 | 国产猛烈高潮尖叫视频免费 | 激情人妻另类人妻伦 | 无码人妻精品一区二区三区不卡 | 欧美色就是色 | 强伦人妻一区二区三区视频18 | 国精产品一品二品国精品69xx | 最新国产乱人伦偷精品免费网站 | 高清不卡一区二区三区 | 中文字幕无码av激情不卡 | 人人爽人人爽人人片av亚洲 | 国产后入清纯学生妹 | 男女下面进入的视频免费午夜 | 欧美丰满熟妇xxxx性ppx人交 | 人妻少妇精品无码专区动漫 | 97久久超碰中文字幕 | 国产精华av午夜在线观看 | 精品国产av色一区二区深夜久久 | 波多野结衣av一区二区全免费观看 | 国产亚洲日韩欧美另类第八页 | 欧美丰满熟妇xxxx性ppx人交 | 中文字幕无码av波多野吉衣 | 国内精品人妻无码久久久影院 | 俺去俺来也在线www色官网 | 日韩精品无码免费一区二区三区 | 久久99精品久久久久婷婷 | 超碰97人人射妻 | 久久zyz资源站无码中文动漫 | 小鲜肉自慰网站xnxx | 玩弄少妇高潮ⅹxxxyw | 牛和人交xxxx欧美 | 欧美人与禽猛交狂配 | 国产激情一区二区三区 | 精品乱子伦一区二区三区 | 思思久久99热只有频精品66 | 久久99精品久久久久婷婷 | 亚洲综合无码一区二区三区 | 少妇性l交大片欧洲热妇乱xxx | 国产麻豆精品一区二区三区v视界 | 国产三级久久久精品麻豆三级 | 国产日产欧产精品精品app | 久热国产vs视频在线观看 | 国内少妇偷人精品视频免费 | 无码精品国产va在线观看dvd | 天天摸天天碰天天添 | 久久99精品久久久久久 | 少妇无套内谢久久久久 | 国产深夜福利视频在线 | 国产va免费精品观看 | 性色欲情网站iwww九文堂 | 日本乱偷人妻中文字幕 | 奇米影视7777久久精品人人爽 | 正在播放老肥熟妇露脸 | 欧美日韩精品 | 国产精品视频免费播放 | а√资源新版在线天堂 | 久久久久久av无码免费看大片 | 日日摸夜夜摸狠狠摸婷婷 | 理论片87福利理论电影 | 色情久久久av熟女人妻网站 | 天堂无码人妻精品一区二区三区 | 精品久久综合1区2区3区激情 | 日日天日日夜日日摸 | 免费人成在线视频无码 | 亚洲 激情 小说 另类 欧美 | 东京热一精品无码av | 国产在线一区二区三区四区五区 | 精品无码一区二区三区的天堂 | 成人毛片一区二区 | www国产亚洲精品久久久日本 | 亚洲精品久久久久中文第一幕 | 国产成人精品无码播放 | 亚洲色www成人永久网址 | 中文字幕无码日韩欧毛 | 97资源共享在线视频 | 国内精品人妻无码久久久影院 | 麻豆md0077饥渴少妇 | 国产av人人夜夜澡人人爽麻豆 | 欧美 日韩 亚洲 在线 | 人妻天天爽夜夜爽一区二区 | 国产成人午夜福利在线播放 | 国产精品亚洲а∨无码播放麻豆 | 人妻少妇被猛烈进入中文字幕 | 免费无码肉片在线观看 | 国产一区二区三区精品视频 | 中文字幕 亚洲精品 第1页 | 久久99精品久久久久久动态图 | 天天躁日日躁狠狠躁免费麻豆 | 精品国产av色一区二区深夜久久 | 一本久道高清无码视频 | 又色又爽又黄的美女裸体网站 | 国产亚洲精品久久久久久 | 老熟女重囗味hdxx69 | 欧美黑人性暴力猛交喷水 | 99视频精品全部免费免费观看 | 日韩在线不卡免费视频一区 | 国产免费无码一区二区视频 | 色爱情人网站 | 亚洲毛片av日韩av无码 | 亚洲人成网站色7799 | 亚洲最大成人网站 | 午夜福利一区二区三区在线观看 | 精品国产一区二区三区四区 | 伊人久久大香线蕉av一区二区 | 亚洲日韩乱码中文无码蜜桃臀网站 | 无码吃奶揉捏奶头高潮视频 | 国产成人精品必看 | 奇米影视888欧美在线观看 | 欧美激情内射喷水高潮 | 国产成人无码一二三区视频 | 久久久久99精品成人片 | 图片小说视频一区二区 | 久久久久99精品国产片 | 任你躁国产自任一区二区三区 | 久久精品中文字幕一区 | 久激情内射婷内射蜜桃人妖 | 欧美zoozzooz性欧美 | 日韩 欧美 动漫 国产 制服 | 一本无码人妻在中文字幕免费 | 国产精品无套呻吟在线 | 狂野欧美性猛xxxx乱大交 | 亚洲色成人中文字幕网站 | 99er热精品视频 | 夜精品a片一区二区三区无码白浆 | 亚无码乱人伦一区二区 | 少妇久久久久久人妻无码 | 免费观看激色视频网站 | 18无码粉嫩小泬无套在线观看 | 久久aⅴ免费观看 | 十八禁视频网站在线观看 | 欧美日韩人成综合在线播放 | √天堂中文官网8在线 | 国产亚洲精品久久久久久大师 | 久久亚洲精品中文字幕无男同 | 欧美日韩综合一区二区三区 | 久久精品人人做人人综合 | 特级做a爰片毛片免费69 | 久久精品女人天堂av免费观看 | 扒开双腿疯狂进出爽爽爽视频 | 国产成人综合美国十次 | 久久人人爽人人爽人人片av高清 | 76少妇精品导航 | 久久久亚洲欧洲日产国码αv | 国产乱人伦av在线无码 | 国产美女极度色诱视频www | 国产成人精品视频ⅴa片软件竹菊 | 精品国产成人一区二区三区 | 久久人妻内射无码一区三区 | 久久99久久99精品中文字幕 | 无码av中文字幕免费放 | 欧美激情内射喷水高潮 | 日本欧美一区二区三区乱码 | 久久久久久国产精品无码下载 | 伦伦影院午夜理论片 | 亚洲中文字幕无码中文字在线 | 日日天干夜夜狠狠爱 | 中文字幕av伊人av无码av | 国产精品-区区久久久狼 | 久久精品丝袜高跟鞋 | 亚洲成a人片在线观看无码3d | 久久精品99久久香蕉国产色戒 | 亚洲成熟女人毛毛耸耸多 | 欧美丰满少妇xxxx性 | 亚洲区欧美区综合区自拍区 | 欧美成人免费全部网站 | 女人被男人躁得好爽免费视频 | 久久99精品国产.久久久久 | 久久99精品久久久久久动态图 | 成人亚洲精品久久久久软件 | 国产色精品久久人妻 | 亚洲欧美日韩国产精品一区二区 | 成人aaa片一区国产精品 | 国产深夜福利视频在线 | 亚洲成熟女人毛毛耸耸多 | 内射爽无广熟女亚洲 | 亚洲欧美综合区丁香五月小说 | 久久伊人色av天堂九九小黄鸭 | 国产成人无码a区在线观看视频app | 久久99精品国产麻豆 | 久久精品一区二区三区四区 | 精品久久综合1区2区3区激情 | 色一情一乱一伦一视频免费看 | 国产99久久精品一区二区 | 久久午夜无码鲁丝片午夜精品 | 成人综合网亚洲伊人 | 天天躁日日躁狠狠躁免费麻豆 | 精品偷自拍另类在线观看 | 日本一区二区三区免费高清 | 久久亚洲中文字幕无码 | 妺妺窝人体色www在线小说 | 亚洲国产成人av在线观看 | 日本精品少妇一区二区三区 | 国产美女极度色诱视频www | 熟女少妇人妻中文字幕 | 美女极度色诱视频国产 | 国产三级久久久精品麻豆三级 | 高清不卡一区二区三区 | 日韩精品无码一本二本三本色 | 西西人体www44rt大胆高清 | 又粗又大又硬毛片免费看 | 久久国内精品自在自线 | 3d动漫精品啪啪一区二区中 | 国产综合久久久久鬼色 | 无码帝国www无码专区色综合 | 久久精品人人做人人综合试看 | 国产色在线 | 国产 | 国产人成高清在线视频99最全资源 | 成人aaa片一区国产精品 | 欧美xxxxx精品 | 十八禁视频网站在线观看 | 一二三四社区在线中文视频 | 亚洲熟妇色xxxxx欧美老妇 | 精品国产一区av天美传媒 | 精品 日韩 国产 欧美 视频 | 亚洲国产成人a精品不卡在线 | 日本丰满护士爆乳xxxx | 国产一区二区三区精品视频 | 欧美日韩一区二区三区自拍 | 又湿又紧又大又爽a视频国产 | 久久精品99久久香蕉国产色戒 | 欧美自拍另类欧美综合图片区 | 欧美老熟妇乱xxxxx | 亚洲精品国偷拍自产在线麻豆 | 国产肉丝袜在线观看 | 国产成人无码av在线影院 | 久久精品国产亚洲精品 | 日本熟妇人妻xxxxx人hd | 奇米影视7777久久精品 | 国产精品久久久久影院嫩草 | 狠狠cao日日穞夜夜穞av | 国产精品第一国产精品 | 亚洲一区二区三区在线观看网站 | 亚洲国产精华液网站w | 日本一区二区三区免费高清 | 日日噜噜噜噜夜夜爽亚洲精品 | 无码人妻精品一区二区三区不卡 | 成年女人永久免费看片 | 国产婷婷色一区二区三区在线 | 亚洲无人区一区二区三区 | 激情国产av做激情国产爱 | 欧美放荡的少妇 | 欧美丰满熟妇xxxx | 国产亚洲精品久久久久久大师 | 精品欧美一区二区三区久久久 | 人妻少妇精品视频专区 | 丰满少妇熟乱xxxxx视频 | 熟妇人妻中文av无码 | 麻豆精品国产精华精华液好用吗 | 在线成人www免费观看视频 | 亚洲成在人网站无码天堂 | 日韩少妇白浆无码系列 | 国产成人无码一二三区视频 | 强伦人妻一区二区三区视频18 | 99精品无人区乱码1区2区3区 | 内射巨臀欧美在线视频 | 亚洲色大成网站www | 亚洲熟熟妇xxxx | 成人免费无码大片a毛片 | 精品国产成人一区二区三区 | 少妇人妻av毛片在线看 | 国产在线精品一区二区三区直播 | 性色欲情网站iwww九文堂 | 人妻少妇精品无码专区二区 | 无码一区二区三区在线观看 | 丰满肥臀大屁股熟妇激情视频 | 精品久久久久香蕉网 | 欧美三级不卡在线观看 | 久久久精品456亚洲影院 | 精品无码一区二区三区爱欲 | 99久久99久久免费精品蜜桃 | 国产午夜精品一区二区三区嫩草 | 无码乱肉视频免费大全合集 | 99久久精品午夜一区二区 | 亚洲精品美女久久久久久久 | 丝袜足控一区二区三区 | 欧美日韩一区二区免费视频 | 男女性色大片免费网站 | 亚洲日韩av一区二区三区四区 | 少妇无码av无码专区在线观看 | 色老头在线一区二区三区 | 亚洲欧美色中文字幕在线 | 久久人人97超碰a片精品 | 亚洲成在人网站无码天堂 | 自拍偷自拍亚洲精品被多人伦好爽 | 国产又粗又硬又大爽黄老大爷视 | 东京热无码av男人的天堂 | 国产成人精品久久亚洲高清不卡 | 精品国产av色一区二区深夜久久 | 蜜桃视频插满18在线观看 | 国产黑色丝袜在线播放 | 亚洲色欲久久久综合网东京热 | 欧美成人免费全部网站 | 亚洲人成无码网www | 亚洲成av人影院在线观看 | 成人无码精品1区2区3区免费看 | 国产亚洲美女精品久久久2020 | 欧美老妇交乱视频在线观看 | 国产乱码精品一品二品 | 久久久久免费精品国产 | 国产av一区二区三区最新精品 | 久久久精品456亚洲影院 | 国内精品一区二区三区不卡 | 婷婷丁香五月天综合东京热 | 亚洲综合伊人久久大杳蕉 | 国产午夜亚洲精品不卡下载 | 亚洲日本一区二区三区在线 | 熟妇激情内射com | а天堂中文在线官网 | 亚洲国产精品无码久久久久高潮 | 国产两女互慰高潮视频在线观看 | a在线观看免费网站大全 | 精品一区二区三区无码免费视频 | 蜜桃av抽搐高潮一区二区 | 亚洲精品成人福利网站 | 精品国产一区二区三区四区 | 国产精品成人av在线观看 | 搡女人真爽免费视频大全 | 老熟妇乱子伦牲交视频 | 国产激情一区二区三区 | 久久久久久久女国产乱让韩 | 国产精品久久精品三级 | 牲欲强的熟妇农村老妇女 | 欧美一区二区三区视频在线观看 | 好屌草这里只有精品 | 51国偷自产一区二区三区 | 日日麻批免费40分钟无码 | 国产97在线 | 亚洲 | 无码人妻久久一区二区三区不卡 | 久久精品国产日本波多野结衣 | 丰满岳乱妇在线观看中字无码 | 成熟女人特级毛片www免费 | 狂野欧美性猛xxxx乱大交 | 日本精品高清一区二区 | 久久精品人人做人人综合试看 | 国精品人妻无码一区二区三区蜜柚 | 国内精品久久毛片一区二区 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 国产精品鲁鲁鲁 | 扒开双腿疯狂进出爽爽爽视频 | 成年美女黄网站色大免费视频 | 狂野欧美激情性xxxx | 丝袜美腿亚洲一区二区 | 国内老熟妇对白xxxxhd | 午夜丰满少妇性开放视频 | 伊人久久婷婷五月综合97色 | 国产精品美女久久久久av爽李琼 | 性开放的女人aaa片 | 国产精品久久久久影院嫩草 | 国产做国产爱免费视频 | 欧美人与牲动交xxxx | 国产特级毛片aaaaaaa高清 | 欧洲熟妇精品视频 | 蜜桃臀无码内射一区二区三区 | 在线视频网站www色 | 国产97在线 | 亚洲 | 久久精品国产大片免费观看 | 又大又黄又粗又爽的免费视频 | 扒开双腿吃奶呻吟做受视频 | 中文精品久久久久人妻不卡 | 最新版天堂资源中文官网 | 人人澡人人透人人爽 | 高中生自慰www网站 | 日韩少妇白浆无码系列 | 国产精品久久久久久亚洲毛片 | 1000部啪啪未满十八勿入下载 | 中文字幕无码av波多野吉衣 | 国内精品久久毛片一区二区 | 久久熟妇人妻午夜寂寞影院 | 日本饥渴人妻欲求不满 | 精品久久久中文字幕人妻 | 国产午夜福利100集发布 | 精品欧美一区二区三区久久久 | 成人欧美一区二区三区黑人免费 | 国产精品美女久久久 | 久久国产自偷自偷免费一区调 | ass日本丰满熟妇pics | 99精品无人区乱码1区2区3区 | 国产精品资源一区二区 | 久久综合色之久久综合 | 国产农村妇女高潮大叫 | 中文无码成人免费视频在线观看 | 欧美刺激性大交 | 人妻有码中文字幕在线 | 97夜夜澡人人双人人人喊 | 成 人 网 站国产免费观看 | 无码国产乱人伦偷精品视频 | 亚洲码国产精品高潮在线 | 国精产品一区二区三区 | 午夜精品一区二区三区在线观看 | 美女黄网站人色视频免费国产 | 四虎4hu永久免费 | 欧美熟妇另类久久久久久多毛 | 国产又爽又黄又刺激的视频 | 无码国模国产在线观看 | 噜噜噜亚洲色成人网站 | 牲欲强的熟妇农村老妇女视频 | 99久久精品国产一区二区蜜芽 | 水蜜桃色314在线观看 | 免费无码一区二区三区蜜桃大 | 国产疯狂伦交大片 | 伊在人天堂亚洲香蕉精品区 | 装睡被陌生人摸出水好爽 | 成人精品视频一区二区三区尤物 | 精品国产国产综合精品 | 精品欧洲av无码一区二区三区 | 亚洲综合久久一区二区 | 激情国产av做激情国产爱 | 亚洲国精产品一二二线 | 亚洲性无码av中文字幕 | 色欲人妻aaaaaaa无码 | 免费无码午夜福利片69 | 99久久婷婷国产综合精品青草免费 | www国产亚洲精品久久网站 | 图片小说视频一区二区 | 国产真人无遮挡作爱免费视频 | 亚洲日本va中文字幕 | 亚洲a无码综合a国产av中文 | 国产综合色产在线精品 | 精品久久综合1区2区3区激情 | 正在播放老肥熟妇露脸 | 一区二区三区高清视频一 | 少妇一晚三次一区二区三区 | 少妇性l交大片欧洲热妇乱xxx | www国产亚洲精品久久网站 | 2020久久香蕉国产线看观看 | 人人妻人人澡人人爽欧美一区 | 亚洲欧美精品aaaaaa片 | 水蜜桃色314在线观看 | 亚洲 日韩 欧美 成人 在线观看 | 中文毛片无遮挡高清免费 | 久久亚洲精品中文字幕无男同 | 成年女人永久免费看片 | 国产高清av在线播放 | 夜先锋av资源网站 | 亚洲一区av无码专区在线观看 | 日本又色又爽又黄的a片18禁 | 乱人伦人妻中文字幕无码久久网 | 久久综合色之久久综合 | 无码人妻丰满熟妇区五十路百度 | 妺妺窝人体色www婷婷 | 97精品国产97久久久久久免费 | 亚洲色成人中文字幕网站 | 精品成人av一区二区三区 | 国产成人久久精品流白浆 | 亚洲精品综合一区二区三区在线 | 又大又紧又粉嫩18p少妇 | 又色又爽又黄的美女裸体网站 | 丰满人妻一区二区三区免费视频 | 自拍偷自拍亚洲精品被多人伦好爽 | 波多野结衣aⅴ在线 | 亚洲中文字幕无码一久久区 | 欧美喷潮久久久xxxxx | 久久精品国产99久久6动漫 | 中文字幕乱码中文乱码51精品 | 亚洲人亚洲人成电影网站色 | 人妻体内射精一区二区三四 | 伦伦影院午夜理论片 | 男女爱爱好爽视频免费看 | 在线播放免费人成毛片乱码 | 国产精品对白交换视频 | 丰满少妇熟乱xxxxx视频 | 亚洲国产综合无码一区 | 成人欧美一区二区三区 | 国产xxx69麻豆国语对白 | 欧美兽交xxxx×视频 | 欧美激情一区二区三区成人 | 国产精品福利视频导航 | 少妇一晚三次一区二区三区 | 久久成人a毛片免费观看网站 | 国产明星裸体无码xxxx视频 | 日本一区二区三区免费播放 | 强伦人妻一区二区三区视频18 | 国产精品久久久久久亚洲影视内衣 | а√天堂www在线天堂小说 | 激情内射亚州一区二区三区爱妻 | 四虎影视成人永久免费观看视频 | 午夜性刺激在线视频免费 | 国产猛烈高潮尖叫视频免费 | 久久亚洲国产成人精品性色 | 亚洲国产精品久久久天堂 | 日本大香伊一区二区三区 | 人妻无码αv中文字幕久久琪琪布 | 狠狠cao日日穞夜夜穞av | 女人被爽到呻吟gif动态图视看 | 亚洲中文无码av永久不收费 | 亚洲色无码一区二区三区 | 国产精品内射视频免费 | 色综合久久久无码网中文 | 性欧美疯狂xxxxbbbb | 久久精品国产99精品亚洲 | 伊在人天堂亚洲香蕉精品区 | 国产精品久久国产三级国 | 国产无遮挡又黄又爽免费视频 | 又紧又大又爽精品一区二区 | 国产精品理论片在线观看 | 鲁鲁鲁爽爽爽在线视频观看 | 亚洲国产精品成人久久蜜臀 | 国产后入清纯学生妹 | 7777奇米四色成人眼影 | 欧美熟妇另类久久久久久多毛 | 粉嫩少妇内射浓精videos | 亚洲色欲久久久综合网东京热 | 色欲综合久久中文字幕网 | 中文久久乱码一区二区 | 欧美怡红院免费全部视频 | 亚洲小说春色综合另类 | 乌克兰少妇xxxx做受 | 九九久久精品国产免费看小说 | 动漫av网站免费观看 | 久久精品一区二区三区四区 | 日本肉体xxxx裸交 | 正在播放东北夫妻内射 | 国产精品99爱免费视频 | 免费观看激色视频网站 | 四虎国产精品一区二区 | 国产精品美女久久久久av爽李琼 | 国产极品美女高潮无套在线观看 | 久久www免费人成人片 | 国产明星裸体无码xxxx视频 | 性欧美熟妇videofreesex | a国产一区二区免费入口 | 亚洲狠狠色丁香婷婷综合 | 亚洲成色在线综合网站 | 亚洲综合久久一区二区 | 99久久精品午夜一区二区 | 免费观看又污又黄的网站 | 狠狠综合久久久久综合网 | 夫妻免费无码v看片 | av无码久久久久不卡免费网站 | 国产在线aaa片一区二区99 | 超碰97人人射妻 | 国产亚洲精品久久久久久大师 | 岛国片人妻三上悠亚 | 国产成人无码午夜视频在线观看 | 无码av中文字幕免费放 | 欧美 丝袜 自拍 制服 另类 | 国产精品久久久久久久影院 | 无码人中文字幕 | 成人亚洲精品久久久久软件 | 麻豆国产丝袜白领秘书在线观看 | 天天爽夜夜爽夜夜爽 | 亚洲の无码国产の无码影院 | 久久午夜无码鲁丝片秋霞 | 丰满人妻一区二区三区免费视频 | 人妻熟女一区 | 国产激情艳情在线看视频 | 国产精品美女久久久久av爽李琼 | 国产亚洲日韩欧美另类第八页 | 在线观看免费人成视频 | 无码毛片视频一区二区本码 | 特黄特色大片免费播放器图片 | 久久午夜无码鲁丝片午夜精品 | 又紧又大又爽精品一区二区 | 高中生自慰www网站 | 成人免费无码大片a毛片 | 亚洲国产成人a精品不卡在线 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 日本爽爽爽爽爽爽在线观看免 | 国产午夜亚洲精品不卡下载 | 亚洲中文无码av永久不收费 | 成人性做爰aaa片免费看 | 久久久亚洲欧洲日产国码αv | 在线亚洲高清揄拍自拍一品区 | 真人与拘做受免费视频一 | 精品无码成人片一区二区98 | 性开放的女人aaa片 | 青青久在线视频免费观看 | 亚洲日韩精品欧美一区二区 | 清纯唯美经典一区二区 | 亚洲a无码综合a国产av中文 | 久久久av男人的天堂 | 亚洲欧洲中文日韩av乱码 | 亚洲国产精品无码久久久久高潮 | 国産精品久久久久久久 | 中文字幕av伊人av无码av | 色偷偷人人澡人人爽人人模 | 丰满岳乱妇在线观看中字无码 | 三级4级全黄60分钟 | 性欧美牲交xxxxx视频 | 国产精品久久久久久无码 | 欧美一区二区三区 | 天天做天天爱天天爽综合网 | 免费观看又污又黄的网站 | 亚洲区小说区激情区图片区 | 亚洲午夜久久久影院 | 中文字幕无码免费久久9一区9 | 久久人人爽人人爽人人片av高清 | 亚洲aⅴ无码成人网站国产app | 99麻豆久久久国产精品免费 | av香港经典三级级 在线 | 国产精品视频免费播放 | 欧美35页视频在线观看 | 国模大胆一区二区三区 | 99在线 | 亚洲 | 任你躁国产自任一区二区三区 | 中文字幕人成乱码熟女app | 牛和人交xxxx欧美 | 一二三四在线观看免费视频 | 男女下面进入的视频免费午夜 | 妺妺窝人体色www婷婷 | 中文字幕av日韩精品一区二区 | 伊在人天堂亚洲香蕉精品区 | 色情久久久av熟女人妻网站 | 大色综合色综合网站 | 国产成人精品优优av | 狠狠亚洲超碰狼人久久 | 国产精品永久免费视频 | 国产99久久精品一区二区 | 欧美日韩亚洲国产精品 | 国产 浪潮av性色四虎 | 亚洲欧美国产精品专区久久 | 成人动漫在线观看 | 欧美丰满少妇xxxx性 | 国产福利视频一区二区 | 国产美女精品一区二区三区 | 久久久精品欧美一区二区免费 | 人妻夜夜爽天天爽三区 | 正在播放东北夫妻内射 | 成人一在线视频日韩国产 | 成人三级无码视频在线观看 | 久久亚洲a片com人成 | 中文字幕无码av激情不卡 | 在线观看国产午夜福利片 | 18精品久久久无码午夜福利 | 天天综合网天天综合色 | 欧美日韩亚洲国产精品 | 乌克兰少妇性做爰 | 国产熟妇高潮叫床视频播放 | 国产办公室秘书无码精品99 | 精品日本一区二区三区在线观看 | 亚洲爆乳无码专区 | 99久久久无码国产aaa精品 | 欧美日本日韩 | 亚洲中文无码av永久不收费 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 在线亚洲高清揄拍自拍一品区 | 国产超碰人人爽人人做人人添 | 亚洲 a v无 码免 费 成 人 a v | 在线欧美精品一区二区三区 | 国产特级毛片aaaaaa高潮流水 | 亚洲第一无码av无码专区 | 巨爆乳无码视频在线观看 | 东京热一精品无码av | 亚洲gv猛男gv无码男同 | 无码av中文字幕免费放 | 欧洲极品少妇 | 亚洲中文字幕va福利 | 国产在线精品一区二区三区直播 | 欧洲熟妇色 欧美 | 成人片黄网站色大片免费观看 | 无遮无挡爽爽免费视频 | 蜜桃臀无码内射一区二区三区 | 国产麻豆精品精东影业av网站 | 国产黄在线观看免费观看不卡 | 撕开奶罩揉吮奶头视频 | 人人妻人人澡人人爽人人精品 | 在线观看欧美一区二区三区 | 国产精品18久久久久久麻辣 | 亚洲色在线无码国产精品不卡 | 乱中年女人伦av三区 | 国产人妻人伦精品 | 人人妻人人澡人人爽欧美一区九九 | 中文精品无码中文字幕无码专区 | 色五月丁香五月综合五月 | 久久久久se色偷偷亚洲精品av | 亚洲国产av精品一区二区蜜芽 | 亚洲成a人片在线观看日本 | 好爽又高潮了毛片免费下载 | 亚洲成av人影院在线观看 | 人妻与老人中文字幕 | 午夜精品久久久内射近拍高清 | 亚洲精品美女久久久久久久 | 久久久久av无码免费网 | 美女极度色诱视频国产 | 青青青爽视频在线观看 | 成人无码精品1区2区3区免费看 | 清纯唯美经典一区二区 | 黑人粗大猛烈进出高潮视频 | 亚洲精品中文字幕久久久久 | 特黄特色大片免费播放器图片 | 久久伊人色av天堂九九小黄鸭 | 国产精品美女久久久久av爽李琼 | 啦啦啦www在线观看免费视频 | 免费观看又污又黄的网站 | 露脸叫床粗话东北少妇 | 国产舌乚八伦偷品w中 | av在线亚洲欧洲日产一区二区 | 日本熟妇人妻xxxxx人hd | 亚洲区欧美区综合区自拍区 | 国产av无码专区亚洲a∨毛片 | 欧美熟妇另类久久久久久多毛 | 日日摸天天摸爽爽狠狠97 | 国产乱子伦视频在线播放 | 亚洲码国产精品高潮在线 | www国产精品内射老师 | 亚洲精品国产品国语在线观看 | 无码国模国产在线观看 | 午夜无码区在线观看 | 西西人体www44rt大胆高清 | 精品夜夜澡人妻无码av蜜桃 | 亚洲精品无码国产 | 久久亚洲中文字幕精品一区 | 97色伦图片97综合影院 | 亚洲性无码av中文字幕 | 精品国产一区av天美传媒 | 久在线观看福利视频 | 国产成人无码a区在线观看视频app | 无码乱肉视频免费大全合集 | 成人无码视频在线观看网站 | 精品亚洲成av人在线观看 | 丰满人妻一区二区三区免费视频 | 伊人久久大香线蕉午夜 | 久久亚洲日韩精品一区二区三区 | 亚洲欧美色中文字幕在线 | 国产亚洲精品久久久ai换 | 欧美变态另类xxxx | 国产成人综合美国十次 | 亲嘴扒胸摸屁股激烈网站 | 亚洲色大成网站www | 久久精品国产亚洲精品 | 欧美日韩久久久精品a片 | 在线播放无码字幕亚洲 | 麻豆果冻传媒2021精品传媒一区下载 | 老熟妇仑乱视频一区二区 | 中文字幕av日韩精品一区二区 | 国产后入清纯学生妹 | 中文无码成人免费视频在线观看 | 偷窥村妇洗澡毛毛多 | 99国产精品白浆在线观看免费 | 国产精品久久久久久亚洲毛片 | 日韩欧美中文字幕公布 | 国产精品无套呻吟在线 | 樱花草在线播放免费中文 | 中文字幕无码免费久久9一区9 | 我要看www免费看插插视频 | 久久久久国色av免费观看性色 | 亚洲精品成a人在线观看 | 巨爆乳无码视频在线观看 | 东北女人啪啪对白 | 日韩av无码一区二区三区不卡 | 无码播放一区二区三区 | 中文字幕无码热在线视频 | 久久久精品人妻久久影视 | 国产精品无码一区二区三区不卡 | 国产av一区二区三区最新精品 | 日本免费一区二区三区最新 | 国产精品久免费的黄网站 | 国产福利视频一区二区 | 亚洲色大成网站www | 国产sm调教视频在线观看 | 日产国产精品亚洲系列 | 国产成人精品久久亚洲高清不卡 | 久久久久久久人妻无码中文字幕爆 | 欧美日韩一区二区免费视频 | 国产精品99久久精品爆乳 | 人人澡人人透人人爽 | 亚洲色欲色欲天天天www | 精品乱子伦一区二区三区 | 东京热男人av天堂 | 永久免费观看国产裸体美女 | 国产成人综合美国十次 | 中文亚洲成a人片在线观看 | 日韩精品成人一区二区三区 | 男人扒开女人内裤强吻桶进去 | 久久精品人妻少妇一区二区三区 | 男人的天堂av网站 | 亚洲熟妇色xxxxx欧美老妇 | 无码人妻丰满熟妇区毛片18 | 黑人巨大精品欧美黑寡妇 | 成人无码影片精品久久久 | 久久久久99精品国产片 | 亚洲熟悉妇女xxx妇女av | 精品一区二区三区无码免费视频 | 99riav国产精品视频 | 精品无人区无码乱码毛片国产 | 高潮毛片无遮挡高清免费视频 | 日日碰狠狠躁久久躁蜜桃 | 久久久久成人片免费观看蜜芽 | 夜夜夜高潮夜夜爽夜夜爰爰 | 女人被男人躁得好爽免费视频 | 少妇人妻av毛片在线看 | 欧洲熟妇色 欧美 | 强伦人妻一区二区三区视频18 | 国产成人一区二区三区在线观看 | 好爽又高潮了毛片免费下载 | 亚洲无人区午夜福利码高清完整版 | 激情爆乳一区二区三区 | 亚洲国产精品无码久久久久高潮 | 少妇人妻偷人精品无码视频 | 久激情内射婷内射蜜桃人妖 | 欧美人与牲动交xxxx | 国产亚洲欧美在线专区 | 亚洲色www成人永久网址 | 成年女人永久免费看片 | 国内揄拍国内精品人妻 | 亚洲a无码综合a国产av中文 | 少妇无码av无码专区在线观看 | 天天摸天天碰天天添 | 波多野结衣高清一区二区三区 | 久久视频在线观看精品 | 亚洲国产综合无码一区 | 免费国产成人高清在线观看网站 | 精品无码国产自产拍在线观看蜜 | 樱花草在线播放免费中文 | 好屌草这里只有精品 | 樱花草在线社区www | 亚洲无人区一区二区三区 | 国产精品久久久一区二区三区 | 牲交欧美兽交欧美 | 国产亚洲日韩欧美另类第八页 | a在线观看免费网站大全 | 国产成人精品无码播放 | 亚洲精品鲁一鲁一区二区三区 | 亚洲а∨天堂久久精品2021 | 亚洲色大成网站www | 欧美熟妇另类久久久久久不卡 | 久久午夜夜伦鲁鲁片无码免费 | 国产免费无码一区二区视频 | 国产va免费精品观看 | 四虎永久在线精品免费网址 | 亚洲精品中文字幕 | 久久伊人色av天堂九九小黄鸭 | 撕开奶罩揉吮奶头视频 | 国产无遮挡吃胸膜奶免费看 | 无码人妻久久一区二区三区不卡 | 色偷偷人人澡人人爽人人模 | 亚洲精品欧美二区三区中文字幕 | 成人免费视频在线观看 | 亚洲精品国产第一综合99久久 | 国产欧美亚洲精品a | 成人无码视频在线观看网站 | 国产sm调教视频在线观看 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 久久伊人色av天堂九九小黄鸭 | 无码人妻少妇伦在线电影 | 久久久久久亚洲精品a片成人 | 国产手机在线αⅴ片无码观看 | 亚洲欧美日韩国产精品一区二区 | 欧美人与禽猛交狂配 | 国产人妻大战黑人第1集 | 精品夜夜澡人妻无码av蜜桃 | 久久这里只有精品视频9 | 欧美日韩色另类综合 | 午夜理论片yy44880影院 | 亚洲欧美综合区丁香五月小说 | 老司机亚洲精品影院无码 | 内射白嫩少妇超碰 | 麻豆精品国产精华精华液好用吗 | 国产婷婷色一区二区三区在线 | 日本护士毛茸茸高潮 | 99精品国产综合久久久久五月天 | 亚洲男女内射在线播放 | 未满成年国产在线观看 | 亚洲人成影院在线无码按摩店 | 一本久久a久久精品vr综合 | 国内精品人妻无码久久久影院 | 熟妇人妻无乱码中文字幕 | 国产网红无码精品视频 | 久久99精品久久久久久 | 国产凸凹视频一区二区 | 粗大的内捧猛烈进出视频 | 综合网日日天干夜夜久久 | 人人爽人人爽人人片av亚洲 | 国内精品久久久久久中文字幕 | 欧美xxxxx精品 | 国产精品无码一区二区三区不卡 | 亚洲精品久久久久avwww潮水 | 日韩av无码中文无码电影 | 欧美精品免费观看二区 | 色情久久久av熟女人妻网站 | 少妇被黑人到高潮喷出白浆 | 丰满少妇高潮惨叫视频 | 中文字幕无码热在线视频 | 久久久久av无码免费网 | 亚洲 高清 成人 动漫 | 宝宝好涨水快流出来免费视频 | 高潮喷水的毛片 | 男女作爱免费网站 | 在线а√天堂中文官网 | 国产欧美精品一区二区三区 | 夜夜躁日日躁狠狠久久av | 亚洲国产成人a精品不卡在线 | 久久久久国色av免费观看性色 | 乱中年女人伦av三区 | 伊人久久大香线蕉亚洲 | 青青久在线视频免费观看 | 狠狠躁日日躁夜夜躁2020 | 国内精品人妻无码久久久影院 | 狠狠综合久久久久综合网 | 成人一在线视频日韩国产 | 99久久人妻精品免费二区 | 激情国产av做激情国产爱 | 暴力强奷在线播放无码 | 国产在线aaa片一区二区99 | 久久综合网欧美色妞网 | 97夜夜澡人人双人人人喊 | 99久久久国产精品无码免费 | 免费国产成人高清在线观看网站 | 欧美肥老太牲交大战 | 精品久久8x国产免费观看 | 亚洲乱码中文字幕在线 | 奇米影视888欧美在线观看 | 久久99久久99精品中文字幕 | 国产福利视频一区二区 | 亚洲 日韩 欧美 成人 在线观看 | 亚洲精品欧美二区三区中文字幕 | 最新版天堂资源中文官网 | 欧美黑人性暴力猛交喷水 | 一本无码人妻在中文字幕免费 | 亚洲第一网站男人都懂 | 国产精品免费大片 | 亚洲人成影院在线无码按摩店 | 久久精品女人天堂av免费观看 | 99久久亚洲精品无码毛片 | 人人澡人人透人人爽 | 久久天天躁狠狠躁夜夜免费观看 | 亲嘴扒胸摸屁股激烈网站 | 国产精品自产拍在线观看 | 成人无码精品1区2区3区免费看 | 亚洲精品国产第一综合99久久 | 亚洲中文字幕无码中文字在线 | 国产成人精品一区二区在线小狼 | 成年美女黄网站色大免费全看 | 小泽玛莉亚一区二区视频在线 | 麻豆成人精品国产免费 | 久久精品99久久香蕉国产色戒 | 日韩人妻无码一区二区三区久久99 | 久久精品国产一区二区三区 | 麻豆国产人妻欲求不满谁演的 | 欧美熟妇另类久久久久久不卡 | 亚洲无人区午夜福利码高清完整版 | 色综合久久久久综合一本到桃花网 | 久9re热视频这里只有精品 | 水蜜桃av无码 | 双乳奶水饱满少妇呻吟 | 色欲人妻aaaaaaa无码 | 亚洲精品国偷拍自产在线观看蜜桃 | 无套内谢的新婚少妇国语播放 | 国色天香社区在线视频 | 久久久久免费看成人影片 | 牲欲强的熟妇农村老妇女 | 久久天天躁狠狠躁夜夜免费观看 | 久久午夜无码鲁丝片秋霞 | 国语精品一区二区三区 | 日韩成人一区二区三区在线观看 | 波多野结衣av一区二区全免费观看 | 精品久久综合1区2区3区激情 | 88国产精品欧美一区二区三区 | 无码一区二区三区在线观看 | 欧美日韩一区二区免费视频 | 国产成人综合色在线观看网站 | 熟女体下毛毛黑森林 | 成人三级无码视频在线观看 | 亚洲国产精品一区二区美利坚 | 国产小呦泬泬99精品 | 久久婷婷五月综合色国产香蕉 | 小sao货水好多真紧h无码视频 | 久久久精品国产sm最大网站 | 免费人成网站视频在线观看 | 成人精品天堂一区二区三区 | 国产熟妇高潮叫床视频播放 | 精品乱子伦一区二区三区 | 日本肉体xxxx裸交 | 天天摸天天透天天添 | 无码午夜成人1000部免费视频 | 亚洲色大成网站www | 色狠狠av一区二区三区 | 色五月五月丁香亚洲综合网 | 台湾无码一区二区 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 欧洲精品码一区二区三区免费看 | 99久久精品午夜一区二区 | 超碰97人人做人人爱少妇 | 免费观看又污又黄的网站 | 日本熟妇人妻xxxxx人hd | 女人高潮内射99精品 | 无码av免费一区二区三区试看 | 成在人线av无码免费 | 精品国产aⅴ无码一区二区 | 国产精品亚洲综合色区韩国 | 久久zyz资源站无码中文动漫 | 亚洲精品无码国产 | 亚洲中文字幕无码一久久区 | 在线播放免费人成毛片乱码 | 秋霞特色aa大片 | 无套内谢的新婚少妇国语播放 | 丰满少妇高潮惨叫视频 | 国产莉萝无码av在线播放 | 国产成人无码av一区二区 | 男人和女人高潮免费网站 | 99精品国产综合久久久久五月天 | 妺妺窝人体色www婷婷 | 久久国内精品自在自线 | 中文字幕无码免费久久99 | 免费观看又污又黄的网站 | 国产国语老龄妇女a片 | 人人澡人人透人人爽 | 牲欲强的熟妇农村老妇女 | 奇米影视888欧美在线观看 | 欧洲精品码一区二区三区免费看 | 玩弄少妇高潮ⅹxxxyw | 国产精品.xx视频.xxtv | 色一情一乱一伦一视频免费看 | 一二三四社区在线中文视频 | 精品国产乱码久久久久乱码 | 欧美日韩一区二区免费视频 | 伊人久久婷婷五月综合97色 | 日日鲁鲁鲁夜夜爽爽狠狠 | 伦伦影院午夜理论片 | 国产亚洲美女精品久久久2020 | 亚洲精品中文字幕乱码 | 亚洲欧美日韩综合久久久 | 国产精品.xx视频.xxtv | 亚洲自偷自拍另类第1页 | 久久久亚洲欧洲日产国码αv | 亚洲精品久久久久avwww潮水 | 亚洲娇小与黑人巨大交 | 秋霞成人午夜鲁丝一区二区三区 | 丝袜人妻一区二区三区 | 久久精品国产一区二区三区肥胖 | 奇米影视7777久久精品 | 亚洲精品国偷拍自产在线观看蜜桃 | 乱码av麻豆丝袜熟女系列 | 俺去俺来也在线www色官网 | 激情内射亚州一区二区三区爱妻 | 麻豆国产丝袜白领秘书在线观看 | 久久久久久国产精品无码下载 | 国产猛烈高潮尖叫视频免费 | 久在线观看福利视频 | 99riav国产精品视频 | 天天摸天天透天天添 | 国产亚洲精品久久久久久久 | 毛片内射-百度 | 国产精品福利视频导航 | 97久久国产亚洲精品超碰热 | 成人综合网亚洲伊人 | 精品国产精品久久一区免费式 | 精品欧洲av无码一区二区三区 | 中文字幕无码免费久久99 | 在线成人www免费观看视频 | 国产深夜福利视频在线 | 亚洲 另类 在线 欧美 制服 | 国产美女精品一区二区三区 | 久久99精品久久久久久动态图 | 日本一卡2卡3卡四卡精品网站 | 国产热a欧美热a在线视频 | www成人国产高清内射 | 国产偷抇久久精品a片69 | 国产色在线 | 国产 | 久久99精品国产.久久久久 | 少妇人妻偷人精品无码视频 | 天堂无码人妻精品一区二区三区 | 天天做天天爱天天爽综合网 | 欧美老熟妇乱xxxxx | 欧洲vodafone精品性 | 爆乳一区二区三区无码 | 思思久久99热只有频精品66 | 亚洲精品国产第一综合99久久 | 帮老师解开蕾丝奶罩吸乳网站 | 久久熟妇人妻午夜寂寞影院 | 国内精品一区二区三区不卡 | 欧美刺激性大交 | 国产婷婷色一区二区三区在线 | 国产一区二区三区日韩精品 | 久久精品国产一区二区三区肥胖 | а√天堂www在线天堂小说 | 在线观看欧美一区二区三区 | 美女毛片一区二区三区四区 | 国产人妖乱国产精品人妖 | 国产69精品久久久久app下载 | 熟妇人妻无乱码中文字幕 | 色综合久久久久综合一本到桃花网 | 久久久国产一区二区三区 | 国产情侣作爱视频免费观看 | 日本成熟视频免费视频 | 99国产欧美久久久精品 | 久久午夜夜伦鲁鲁片无码免费 | 亚洲成色在线综合网站 | 丰满人妻被黑人猛烈进入 | 国产偷自视频区视频 | 日韩av无码一区二区三区不卡 | 国产成人无码av在线影院 | 中文无码伦av中文字幕 | 在线精品国产一区二区三区 | 成熟女人特级毛片www免费 | 久久 国产 尿 小便 嘘嘘 | 一区二区传媒有限公司 | 亚洲国产精品成人久久蜜臀 | 久久久精品成人免费观看 | 国产精品久久久久无码av色戒 | 少妇性荡欲午夜性开放视频剧场 | 中文字幕无码日韩专区 | 亚洲成a人片在线观看无码 | 国产人妻人伦精品 | 无码播放一区二区三区 | 国产av一区二区三区最新精品 | 日韩欧美中文字幕在线三区 | 国产激情一区二区三区 | 我要看www免费看插插视频 | 在线亚洲高清揄拍自拍一品区 | 日本一本二本三区免费 | 天堂无码人妻精品一区二区三区 | 伊在人天堂亚洲香蕉精品区 | 大地资源网第二页免费观看 | √天堂资源地址中文在线 | 亚洲国产成人a精品不卡在线 | 樱花草在线播放免费中文 | 18无码粉嫩小泬无套在线观看 | 天天躁日日躁狠狠躁免费麻豆 | 秋霞特色aa大片 | 中文字幕人妻无码一区二区三区 | 日韩av无码中文无码电影 | 成人影院yy111111在线观看 | 性色欲情网站iwww九文堂 | 亚洲日本va中文字幕 | 中文字幕无码乱人伦 | 天天av天天av天天透 | 1000部夫妻午夜免费 | 国产精品视频免费播放 | 又紧又大又爽精品一区二区 | 波多野结衣乳巨码无在线观看 | 国产猛烈高潮尖叫视频免费 | 漂亮人妻洗澡被公强 日日躁 | 永久黄网站色视频免费直播 | 天海翼激烈高潮到腰振不止 | 亚洲の无码国产の无码步美 | 好男人社区资源 | av小次郎收藏 | 国内丰满熟女出轨videos | 欧美猛少妇色xxxxx | 无遮挡啪啪摇乳动态图 | 99久久精品无码一区二区毛片 | 牛和人交xxxx欧美 | 亚洲中文字幕在线无码一区二区 | 欧美猛少妇色xxxxx | 婷婷综合久久中文字幕蜜桃三电影 | 在线 国产 欧美 亚洲 天堂 | 亚洲最大成人网站 | 97精品人妻一区二区三区香蕉 | 欧美人与禽zoz0性伦交 | 国产精品无码一区二区桃花视频 | 欧美激情内射喷水高潮 | 福利一区二区三区视频在线观看 | a片免费视频在线观看 | 日本丰满熟妇videos | 丰满人妻精品国产99aⅴ | 国内精品人妻无码久久久影院 | 欧美性生交活xxxxxdddd | 亚洲精品一区二区三区大桥未久 | 欧美自拍另类欧美综合图片区 | 免费观看的无遮挡av | 欧美亚洲日韩国产人成在线播放 | 宝宝好涨水快流出来免费视频 | 午夜成人1000部免费视频 | 老熟妇仑乱视频一区二区 | 亚洲自偷自拍另类第1页 | 国产热a欧美热a在线视频 | 久久综合狠狠综合久久综合88 | 精品日本一区二区三区在线观看 | 成人性做爰aaa片免费看 | 国产精品久久久久9999小说 | 亚洲色欲色欲天天天www | 免费无码的av片在线观看 | 激情综合激情五月俺也去 | 无遮挡啪啪摇乳动态图 | 精品国产成人一区二区三区 | 成人欧美一区二区三区黑人 | 国产深夜福利视频在线 | 国产精华av午夜在线观看 | 波多野结衣av在线观看 | 国产亚洲精品久久久闺蜜 | 97久久国产亚洲精品超碰热 | 国产色在线 | 国产 | 日韩av无码一区二区三区 | 国产真人无遮挡作爱免费视频 |