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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > HTML >内容正文

HTML

大前端开发者需要了解的基础编译原理和语言知识

發布時間:2025/7/25 HTML 73 豆豆
生活随笔 收集整理的這篇文章主要介紹了 大前端开发者需要了解的基础编译原理和语言知识 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

轉自:https://yq.aliyun.com/articles/180879

?

在我剛剛進入大學,從零開始學習 C 語言的時候,我就不斷的從學長的口中聽到一個又一個語言,比如 C++、Java、Python、JavaScript 這些大眾的,也有 Lisp、Perl、Ruby 這些相對小眾的。一般來說,當程序員討論一門語言的時候,默認的上下文經常是:“用 xxx 語言來完成 xxx 任務”。所以一直困擾著的我的一個問題就是,為什么完成某個任務,一定要選擇特定的語言,比如安卓開發是 Java,前端要用 JavaScript,iOS 開發使用 Objective-C 或者 Swift。這些問題的答案非常復雜,有的是技術原因,有的是歷史原因,有的會考慮成本,很難得出統一的結論,只能 case-by-case 的分析。這篇文章并非專門解答上述問題,而是希望通過介紹一些通用的概念,幫助讀者掌握分析問題的能力,如果這個概念在實際編程中用得到,我也會舉一些具體的例子。

在閱讀本文前,不妨思考一下這幾個問題,如果沒有頭緒,建議看完文章以后再思考一遍。如果覺得答案顯而易見,恭喜你,這篇文章并非為你準備的:

  • 什么是編譯器,它以什么為分界線,分為前端和后端?
  • Java 是編譯型語言還是解釋型語言,Python 呢?
  • C 語言的編譯器也是 C 語言,那它怎么被編譯的?
  • 目標文件的格式是什么樣的,段表、符號表、重定位表有什么作用?
  • Swift 是靜態語言,為什么還有運行時庫?
  • 什么是 ABI,ABI 不穩定有什么問題?
  • 什么是 WebAssembly,為什么要推出這門技術,用 C++ 代替 JavaScript 可行么?
  • JavaScript 和 DOM API 是什么關系,JavaScript 可以讀寫文件么?
  • C++ 代碼可以自動轉換成 Java 代碼么,任意兩種語言是否可以互轉?
  • 為什么說 Python 是膠水語言,它可以用來開發 iOS/Android 么?
  • 編譯原理

    就像數學是一個公理體系,從簡單的公理就能推導出各種高階公式一樣,我們從最基本的 C 語言和編譯說起。

  • int?main(void)?{?
  • ????int?a?=?strlen("Hello?world");??//?字符串的長度是?11?
  • ????return?0;?
  • }?
  • 相關的介紹編譯過程的文章很多,讀者應該都非常熟悉了,整個流程包括預處理、詞法分析、語法分析、生成中間代碼,生成目標代碼,匯編,鏈接 等。已有的文章大多分析了每一步的邏輯,但很少談實現思路,我會盡量用簡單的語言來描述每一步的實現思路,相信這樣有助于加深記憶。由于主要談的概念和思路,難免會有一些不夠準確的抽象,讀者學會抓重點就行。

    預處理是一個獨立的模塊,它放在最后介紹,我們先看詞法分析。

    詞法分析

    最先登場的是編譯器,它負責前五個步驟,也就是說編譯器的輸入是源代碼,輸出是中間代碼。

    編譯器不能像人一樣,一眼就看明白源代碼的內容,它只能比較傻的逐個單詞分析。詞法分析要做的就是把源代碼分割開,形成若干個單詞。這個過程并不像想象的那么簡單。比如舉幾個例子:

  • int t 表示一個整數,而 intt 只是一個變量名。
  • int a() 表示一個函數而非整數 a,int a () 也是一個函數。
  • a = 沒有具體價值,它可以是一個賦值語句,還可以是 a == 1 的前綴,表示一個判斷。
  • 詞法分析的主要難點在于,前綴無法決定一個完整字符串的含義,通常需要看完整句以后才知道每個單詞的具體含義。同時,C 語言的語法也不簡單,各種關鍵字,括號,逗號,語法等等都會給詞法分析的實現增加難度。

    詞法分析的主要實現原理是狀態機,它逐個讀取字符,然后根據讀到的字符的特點轉換狀態。比如這是 GCC 的詞法分析狀態機(引用自《編譯系統透視》):??

    如果自己實現的話,思路也不難。外面包一個循環,然后各種 switch...case 就完事了。詞法分析應該算是最簡單的一節。

    語法分析

    經過詞法分析以后,編譯器已經知道了每個單詞,但這些單詞組合起來表示的語法還不清楚。一個簡單的思路是模板匹配,比如有這樣的語句:

  • int?a?=?10;?
  • 它其實表示了這么一種通用的語法格式:

    類型 變量名 = 常量;

    所以 int a = 10; 當然可以匹配上這種模式。同理,它不可能匹配 類型 函數名(參數); 這種函數定義模式,因為兩者結構不一致,等號無法被匹配。

    語法分析比詞法分析更復雜,因為所有 C 語言支持的語法特性都必須被語法分析器正確的匹配,這個難度比純新手學習 C 語言語法難上很多倍。不過這個屬于業務復雜性,無論采用哪種解決方案都不可避免,因為語法規則的數量就是這么多。

    在匹配模式的時候,另一個問題在于上述的名詞,比如 類型、參數,很難界定。比如int 是類型,long long 也是類型,unsigned long long 也是類型。(int a) 可以是參數,(int a, int b) 也是參數,(unsigned long long a, long long double b, int *p) 看起來能把人逼瘋。

    下面舉一個簡單的例子來解釋 int a = 10 是如何被解析的,總的思路是歸納與分解。我們把一個復雜的式子分割成若干部分,然后分析各個部分,這樣可以簡化復雜度。對于 int a = 10 來說,他是一個聲明,聲明由兩部分組成,分別是聲明說明符和初始聲明符列表。

    聲明聲明說明符初始聲明符列表
    int a = 10inta = 10
    int fun(int a)intfun(int a)
    int array[5]intarray[5]

    聲明說明符比較簡單,它其實是若干個類型的串聯:

    聲明說明符 = 類型 + 類型的數組(長度可以為 0)

    而且我們知道若干個類型連在一起又變成了聲明說明符,所以上述等式等價于:

    聲明說明符 = 類型 + 聲明說明符(可選)

    再嚴謹一些,聲明說明符還可以包括 const 這樣的限定說明符,inline 這樣的函數說明符,和 _Alignas 這樣的對齊說明符。借用書中的公式,它的完整表達如下:

    這才僅僅是聲明語句中最簡單的聲明說明符,僅僅是幾個類型和關鍵字的組合而已。后面的初始聲明符列表的解析更復雜。如果有能力做完這些解析,恭喜你,成功的解析了聲明語句。你會發現什么定義語句啦,調用語句啦,正嫵媚的向你招手╮(╯▽╰)╭。

    成功解析語法以后,我們會得到抽象語法樹(AST: Abstract Syntax Tree)。以這段代碼為例:

  • int?fun(int?a,?int?b)?{?
  • ????int?c?=?0;?
  • ????c?=?a?+?b;?
  • ????return?c;?
  • }?
  • 它的語法樹如下:

    語法樹將字符串格式的源代碼轉化為樹狀的數據結構,更容易被計算機理解和處理。但它距離中間代碼還有一定的距離。

    生成中間代碼

    以 GCC 為例,生成中間代碼可以分為三個步驟:

  • 語法樹轉高端 gimple
  • 高端 gimple 轉低端 gimple
  • 低端 gimple 經過 cfa 轉 ssa 再轉中間代碼
  • 簡單的介紹一下每一步都做了什么。

    語法樹轉高端 gimple

    這一步主要是處理寄存器和棧,比如 c = a + b 并沒有直接的匯編代碼和它對應,一般來說需要把 a + b 的結果保存到寄存器中,然后再把寄存器賦值給 c。所以這一步如果用 C 語言來表示其實是:

  • int?temp?=?a?+?b;?//?temp?其實是寄存器?
  • c?=??temp;?
  • 另外,調用一個新的函數時會進入到函數自己的棧,建棧的操作也需要在 gimple 中聲明。

    高端 gimple 轉低端 gimple

    這一步主要是把變量定義,語句執行和返回語句區分存儲。比如:

  • int?a?=?1;?
  • a++;?
  • int?b?=?1;?
  • 會被處理成:

  • int?a?=?1;?
  • int?b?=?1;?
  • a++;?
  • 這樣做的好處是很容易計算一個函數到底需要多少棧空間。

    此外,return 語句會被統一處理,放在函數的末尾,比如:

  • if?(1?>?0)?{?
  • ????return?1;?
  • }?
  • else?{?
  • ????return?0;?
  • }?
  • 會被處理成:

  • if?(1?>?0)?{?
  • ????goto?a;?
  • }?
  • else?{?
  • ????goto?b;?
  • }?
  • a:?
  • ????return?1;?
  • b:?
  • ????return?0;?
  • 低端 gimple 經過 cfa 轉 ssa 再轉中間代碼

    這一步主要是進行各種優化,添加版本號等,我不太了解,對于普通開發者來說也沒有學習的必要。

    中間代碼的意義

    其實中間代碼可以被省略,抽象語法樹可以直接轉化為目標代碼(匯編代碼)。然而,不同的 CPU 的匯編語法并不一致,比如 AT&T與Intel匯編風格比較 這篇文章所提到的,Intel 架構和 AT&T 架構的匯編碼中,源操作數和目標操作數位置恰好相反。Intel 架構下操作數和立即數沒有前綴但 AT&T 有。因此一種比較高效的做法是先生成語言無關,CPU 也無關的中間代碼,然后再生成對應各個 CPU 的匯編代碼。

    生成中間代碼是非常重要的一步,一方面它和語言無關,也和 CPU 與具體實現無關。可以理解為中間代碼是一種非常抽象,又非常普適的代碼。它客觀中立的描述了代碼要做的事情,如果用中文、英文來分別表示 C 和 Java 的話,中間碼某種意義上可以被理解為世界語。

    另一方面,中間代碼是編譯器前端和后端的分界線。編譯器前端負責把源碼轉換成中間代碼,編譯器后端負責把中間代碼轉換成匯編代碼。

    LLVM IR 是一種中間代碼,它長成這樣:

  • define?i32?@square_unsigned(i32?%a)?{?
  • ??%1?=?mul?i32?%a,?%a?
  • ??ret?i32?%1?
  • }?
  • 生成目標代碼

    目標代碼也可以叫做匯編代碼。由于中間代碼已經非常接近于實際的匯編代碼,它幾乎可以直接被轉化。主要的工作量在于兼容各種 CPU 以及填寫模板。在最終生成的匯編代碼中,不僅有匯編命令,也有一些對文件的說明。比如:

  • ??.file???????"test.c"??????#?文件名稱?
  • ????.global?????m?????????????#?全局變量?m?
  • ????.data?????????????????????#?數據段聲明?
  • ????.align??????4?????????????#?4?字節對齊?
  • ????.type???????m,?@objc?
  • ????.size???????m,?4?
  • m:?
  • ????.long???????10????????????#?m?的值是?10?
  • ????.text?
  • ????.global?????main?
  • ????.type???????main,?@function?
  • main:?
  • ????pushl???%ebp?
  • ????movl????%esp,???%ebp?
  • ????...?
  • 匯編

    匯編器會接收匯編代碼,將它轉換成二進制的機器碼,生成目標文件(后綴是 .o),機器碼可以直接被 CPU 識別并執行。從目標代碼可以猜出來,最終的目標文件(機器碼)也是分段的,這主要有以下三個原因:

  • 分段可以將數據和代碼區分開。其中代碼只讀,數據可寫,方便權限管理,避免指令被改寫,提高安全性。
  • 現代 CPU 一般有自己的數據緩存和指令緩存,區分存儲有助于提高緩存命中率。
  • 當多個進程同時運行時,他們的指令可以被共享,這樣能節省內存。
  • 段分離我們并不遙遠,比如命令行中的 objcopy 可以自行添加自定義的段名,C 語言的 __attribute((section(段名)))__ 可以把變量定義在某個特定名稱的段中。

    對于一個目標文件來說,文件的最開頭(也叫作 ELF 頭)記錄了目標文件的基本信息,程序入口地址,以及段表的位置,相當于是對文件的整體描述。接下來的重點是段表,它記錄了每個段的段名,長度,偏移量。比較常用的段有:

    • .strtab 段: 字符串長度不定,分開存放浪費空間(因為需要內存對齊),因此可以統一放到字符串表(也就是 .strtab 段)中進行管理。字符串之間用\0 分割,所以凡是引用字符串的地方用一個數字就可以代表。
    • .symtab: 表示符號表。符號表統一管理所有符號,比如變量名,函數名。符號表可以理解為一個表格,每行都有符號名(數字)、符號類型和符號值(存儲地址)
    • .rel 段: 它表示一系列重定位表。這個表主要在鏈接時用到,下面會詳細解釋。

    鏈接

    在一個目標文件中,不可能所有變量和函數都定義在文件內部。比如 strlen 函數就是一個被調用的外部函數,此時就需要把 main.o 這個目標文件和包含了 strlen函數實現的目標文件鏈接起來。我們知道函數調用對應到匯編其實是 jump 指令,后面寫上被調用函數的地址,但在生成 main.o 的過程中,strlen() 函數的地址并不知道,所以只能先用 0 來代替,直到最后鏈接時,才會修改成真實的地址。

    鏈接器就是靠著重定位表來知道哪些地方需要被重定位的。每個可能存在重定位的段都會有對應的重定位表。在鏈接階段,鏈接器會根據重定位表中,需要重定位的內容,去別的目標文件中找到地址并進行重定位。

    有時候我們還會聽到動態鏈接這個名詞,它表示重定位發生在運行時而非編譯后。動態鏈接可以節省內存,但也會帶來加載的性能問題,這里不詳細解釋,感興趣的讀者可以閱讀《程序員的自我修養》這本書。

    預處理

    最后簡單描述一下預處理。預處理主要是處理一些宏定義,比如#define、#include、#if 等。預處理的實現有很多種,有的編譯器會在詞法分析前先進行預處理,替換掉所有 # 開頭的宏,而有的編譯器則是在詞法分析的過程中進行預處理。當分析到 # 開頭的單詞時才進行替換。雖然先預處理再詞法分析比較符合直覺,但在實際使用中,GCC 使用的卻是一邊詞法分析,一邊預處理的方案。

    編譯 VS 解釋

    總結一下,對于 C 語言來說,從源碼到運行結果大致上需要經歷編譯、匯編和鏈接三個步驟。編譯器接收源代碼,輸出目標代碼(也就是匯編代碼),匯編器接收匯編代碼,輸出由機器碼組成的目標文件(二進制格式,.o 后綴),最后鏈接器將各個目標文件鏈接起來,執行重定位,最終生成可執行文件。

    編譯器以中間代碼為界限,又可以分前端和后端。比如 clang 就是一個前端工具,而 LLVM 則負責后端處理。另一個知名工具 GCC(GNU Compile Collection)則是一個套裝,包攬了前后端的所有任務。前端主要負責預處理、詞法分析、語法分析,最終生成語言無關的中間代碼。后端主要負責目標代碼的生成和優化。

    關于編譯原理的基礎知識雖然枯燥,但掌握這些知識有助于我們理解一些有用的,但不太容易理解的概念。接下來,我們簡單看一下別的語言是如何運行的。

    Java

    在 Java 代碼的執行過程中,可以簡單分為編譯和執行兩步。Java 的編譯器首先會把 .java 格式的源碼編譯成 .class 格式的字節碼。字節碼對應到 C 語言的編譯體系中就是中間碼,Java 虛擬機執行這些中間碼得到最終結果。

    回憶一下上文對中間碼的解釋,一方面它與語言無關,僅僅描述客觀事實。另一方面它和目標代碼的差距并不大,已經包括了對寄存器和棧的處理,僅僅是抽象了 CPU 架構而已,只要把它具體化成各個平臺下的目標代碼,就可以交給匯編器了。

    解釋型語言

    一般來說我們也把解釋型語言叫做腳本語言,比如 Python、Ruby、JavaScript 等等。這類語言的特點是,不需要編譯,直接由解釋器執行。換言之,運行流程變成了:

    源代碼 -> 解釋器 -> 運行結果

    需要注意的是,這里的解釋器只是一個黑盒,它的實現方式可以是多種多樣的。舉個例子,它的實現可以非常類似于 Java 的執行過程。解釋器里面可以包含一個編譯器和虛擬機,編譯器把源碼轉化成 AST 或者字節碼(中間代碼)然后交給虛擬機執行,比如 Ruby 1.9 以后版本的官方實現就是這個思路。

    至于虛擬機,它并不是什么黑科技,它的內部可以編譯執行,也可以解釋執行。如果是編譯執行,那么它會把字節碼編譯成當前 CPU 下的機器碼然后統一執行。如果是解釋執行,它會逐條翻譯字節碼。

    有意思的是,如果虛擬機是編譯執行的,那么這套流程和 C 語言幾乎一樣,都滿足下面這個流程:

    源代碼 -> 中間代碼 -> 目標代碼 -> 運行結果

    下面是重點!!!

    下面是重點!!!

    下面是重點!!!

    因此,解釋型語言和編譯型語言的根本區別在于,對于用戶來說,到底是直接從源碼開始執行,還是從中間代碼開始執行。以 C 語言為例,所有的可執行程序都是二進制文件。而對于傳統意義的 Python 或者 JavaScript,用戶并沒有拿到中間代碼,他們直接從源碼開始執行。從這個角度來看, Java 不可能是解釋型語言,雖然 Java 虛擬機會解釋字節碼,但是對于用戶來說,他們是從編譯好的 .class 文件開始執行,而非源代碼。

    實際上,在 x86 這種復雜架構下,二進制的機器碼也不能被硬件直接執行,CPU 會把它翻譯成更底層的指令。從這個角度來說,我們眼中的硬件其實也是一個虛擬機,執行了一些“抽象”指令,但我相信不會有人認為 C 語言是解釋型語言。因此,有沒有虛擬機,虛擬機是不是解釋執行,會不會生成中間代碼,這些都不重要,重要的是如果從中間代碼開始執行,而且 AST 已經事先生成好,那就是編譯型的語言。

    如果更本質一點看問題,根本就不存在解釋型語言或者編譯型語言這種說法。已經有人證明,如果一門語言是可以解釋的,必然可以開發出這門語言的編譯器。反過來說,如果一門語言是可編譯的,我只要把它的編譯器放到解釋器里,把編譯推遲到運行時,這么語言就可以是解釋型的。事實上,早有人開發出了 C 語言的解釋器:

    C 源代碼 -> C 語言解釋器(運行時編譯、匯編、鏈接) -> 運行結果

    我相信這一點很容易理解,規范和實現是兩套分離的體系。我們平常說的 C 語言的語法,實際上是一套規范。理論上來說每個人都可以寫出自己的編譯器來實現 C 語言,只要你的編譯器能夠正確運行,最終的輸出結果正確即可。而編譯型和解釋型說的其實是語言的實現方案,是提前編譯以獲得最大的性能提高,還是運行時去解析以獲得靈活性,往往取決于語言的應用場景。所以說一門語言是編譯型還是解釋型的,這會非常可笑。一個標準怎么可能會有固定的實現呢?之所以給大家留下了 C 語言是編譯型語言,Python 是解釋型語言的印象,往往是因為這門語言的應用場景決定了它是主流實現是編譯型還是解釋型。

    自舉

    不知道有沒有人思考過,C 語言的編譯器是如何實現的?實際上它還是用 C 語言實現的。這種自己能編譯自己的神奇能力被稱為自舉(Bootstrap)。

    乍一看,自舉是不可能的。因為 C 語言編譯器,比如 GCC,要想運行起來,必定需要 GCC 的編譯器將它編譯成二進制的機器碼。然而 GCC 的編譯器又如何編譯呢……

    解決問題的關鍵在于打破這個循環,我們可以先用一個比 C 語言低級的語言來實現一個 C 語言編譯器。這件事是可能做到的,因為這個低級語言必然會比 C 語言簡單,比如我們可以直接用匯編代碼來寫 C 語言的編譯器。由于越低級的語言越簡單,但表達能力越弱,所以用匯編來寫可能太復雜。這種情況下我們可以先用一個比 C 語言低級但比匯編高級的語言來實現 C 語言的編譯器,同時用匯編來實現這門語言的編譯器。總之就是不斷用低級語言來寫高級語言的編譯器,雖然語言越低級,它的表達能力越弱,但是它要解析的語言也在不斷變簡單,所以這件事是可以做到的。

    有了低級語言寫好的 C 語言編譯器以后,這個編譯器是二進制格式的。此時就可以刪掉所有的低級語言,只留一個二進制格式的 C 語言編譯器,接下來我們就可以用 C 語言寫編譯器,再用這個二進制格式的編譯器去編譯 C 語言實現的 C 語言編譯器了,于是完成了自舉。

    以上邏輯描述起來比較繞,但我想多讀幾遍應該可以理解。如果實在不理解也沒關系,我們只要明白 C 語言可以自舉是因為它可以編譯成二進制機器碼,只要用低級語言生成這個機器碼,就不再需要低級語言了,因為機器碼可以直接被 CPU 執行。

    從這個角度來看,解釋型語言是不可能自舉的。以 Python 為例,自舉要求它能用 Python 語言寫出來 Python 的解釋器,然而這個解釋器如何運行呢,最終還是需要一個解釋器。而解釋器體系下, Python 都是從源碼經過解釋器執行,又不能留下什么可以直接被硬件執行的二進制形式的解釋器文件,自然是沒辦法自舉的。然而,就像前面說的,Python 完全可以實現一個編譯器,這種情況下它就是可以自舉的。

    所以一門語言能不能自舉,主要取決于它的實現形式能否被編譯并留下二進制格式的可執行文件。

    運行時

    本文的讀者如果是使用 Objective-C 的 iOS 開發者,想必都有過在面試時被 runtime 支配的恐懼。然而,runtime 并非是 Objective-C 的專利,絕大多數語言都有這個概念。所以有人說 Objective-C 具有動態性是因為它有 runtime,這種說法并不準確,我覺得要把 Objective-C 的 runtime 和一般意義的運行時庫區分開,認識到它僅僅是運行時庫的一個組成部分,同時還是要深入到方法調用的層面來談。

    運行時庫的基本概念

    以 C 語言為例,有非常多的操作最終都依賴于 glibc 這個動態鏈接庫。包括但不限于字符串處理(strlen、strcpy)、信號處理、socket、線程、IO、動態內存分屏(malloc)等等。這一點很好理解,如果回憶一下之前編譯器的工作原理,我們會發現它僅僅是處理了語言的語法,比如變量定義,函數聲明和調用等等。至于語言的功能, 比如內存管理,內建的類型,一些必要功能的實現等等。如果要對運行時庫進行分類,大概有兩類。一種是語言自身功能的實現,比如一些內建類型,內置的函數;另一種則是語言無關的基礎功能,比如文件 IO,socket 等等。

    由于每個程序都依賴于運行時庫,這些庫一般都是動態鏈接的,比如 C 語言的 (g)libc。這樣一來,運行時庫可以存儲在操作系統中,節省內存占用空間和應用程序大小。

    對于 Java 語言來說,它的垃圾回收功能,文件 IO 等都是在虛擬機中實現,并提供給 Java 層調用。從這個角度來看,虛擬機/解釋器也可以被看做語言的運行時環境(庫)。

    swift 運行時庫

    經過這樣的解釋,相信 swift 的運行時庫就很容易理解了。一方面,swift 是絕對的靜態語言,另一方面,swift 毫無疑問的帶有自己的運行時庫。舉個最簡單的例子,如果閱讀 swift 源碼就會發現某些類型,比如字符串(String),或者數組,再或者某些函數(print)都是用 swift 實現的,這些都是 swift 運行時庫的一部分。按理說,運行時庫應該內置于操作系統中并且和應用程序動態鏈接,然而坑爹的 Swift 在本文寫作之時依然沒有穩定 ABI,導致每個程序都必須自帶運行時庫,這也就是為什么目前 swift 開發的 app 普遍會增加幾 Mb 包大小的原因。

    說到 ABI,它其實就是一個編譯后的 API。簡單來說,API 是描述了在應用程序級別,模塊之間的調用約定。比如某個模塊想要調用另一個模塊的功能,就必須根據被調用模塊提供的 API 來調用,因為 API 中規定了方法名、參數和返回結果的類型。而當源碼被編譯成二進制文件后,它們之間的調用也存在一些規則和約定。

    比如模塊 A 有兩個整數 a 和 b,它們的內存布局如下:

    模塊 A
    初始地址
    a
    b

    這時候別的模塊調用 A 模塊的 b 變量,可以通過初始地址加偏移量的方式進行。

    如果后來模塊 A 新增了一個整數 c,它的內存布局可能會變成:

    模塊 A
    初始地址
    c
    a
    b

    如果調用方還是使用相同的偏移量,可以想見,這次拿到的就是變量 a 了。因此,每當模塊 A 有更新,所有依賴于模塊 A 的模塊都必須重新編譯才能正確工作。如果這里的模塊 A 是 swift 的運行時庫,它內置于操作系統并與其他模塊(應用程序)動態鏈接會怎么樣呢?結果就是每次更新系統后,所有的 app 都無法打開。顯然這是無法接受的。

    當然,ABI 穩定還包括其他的一些要求,比如調用和被調用者遵守相同的調用約定(參數和返回值如何傳遞)等。

    JavaScript 那些事

    我們繼續剛才有關運行時的話題,先從 JavaScript 的運行時聊起,再介紹 JavaScript 的相關知識。

    JavaScript 是如何運行的

    JavaScript 和其他語言,無論是 C 語言,還是 Python 這樣的腳本語言,最大的區別在于 JavaScript 的宿主環境比較奇怪,一般來說是瀏覽器。

    無論是 C 還是 Python,他們都有一個編譯器/解釋器運行在操作系統上,直接把源碼轉換成機器碼。而 JavaScript 的解釋器一般內置在瀏覽器中,比如 Chrome 就有一個 V8 引擎可以解析并執行 JavaScript 代碼。因此 JavaScript 的能力實際上會受到宿主環境的影響,有一些限制和加強。

    首先來看看 DOM 操作,相關的 API 并沒有定義在 ECMAScript 標準中,因此我們常用的 window.xxx 還有 window.document.xxx 并非是 JavaScript 自帶的功能,這通常是由宿主平臺通過 C/C++ 等語言實現,然后提供給 JavaScript 的接口。同樣的,由于瀏覽器中的 JavaScript 只是一個輕量的語言,沒有必要讀寫操作系統的文件,因此瀏覽器引擎一般不會向 JavaScript 提供文件讀寫的運行時組件,它也就不具備 IO 的能力。從這個角度來看,整個瀏覽器都可以看做 JavaScript 的虛擬機或者運行時環境。

    因此,當我們換一個宿主環境,比如 Node.js,JavaScript 的能力就會發生變化。它不再具有 DOM API,但多了讀寫文件等能力。這時候,Node.js 就更像是一個標準的 JavaScript 解析器了。這也是為什么 Node.js 讓 JavaScript 可以編寫后端應用的原因。

    JIT 優化

    解釋執行效率低的主要原因之一在于,相同的語句被反復解釋,因此優化的思路是動態的觀察哪些代碼是經常被調用的。對于那些被高頻率調用的代碼,可以用編譯器把它編譯成機器碼并且緩存下來,下次執行的時候就不用重新解釋,從而提升速度。這就是 JIT(Just-In-Time) 的技術原理。

    但凡基于緩存的優化,一定會涉及到緩存命中率的問題。在 JavaScript 中,即使是同一段代碼,在不同上下文中生成的機器碼也不一定相同。比如這個函數:

  • function?add(a,?b)?{?
  • ????return?a?+?b;?
  • }?
  • 如果這里的 a 和 b 都是整數,可以想見最終的代碼一定是匯編中的 add 命令。如果類似的加法運算調用了很多次,解釋器可能會認為它值得被優化,于是編譯了這段代碼。但如果下一次調用的是 add("hello", "world"),之前的優化就無效了,因為字符串加法的實現和整數加法的實現完全不同。

    于是優化后的代碼(二進制格式)還得被還原成原先的形式(字符串格式),這樣的過程被稱為去優化。反復的優化 -> 去優化 -> 優化 …… 非常耗時,大大降低了引入 JIT 帶來的性能提升。

    JIT 理論上給傳統的 JavaScript 帶了了 20-40 倍的性能提升,但由于上述去優化的存在,在實際運行的過程中遠遠達不到這個理論上的性能天花板。

    WebAssembly

    前文說過,JavaScript 實際上是由瀏覽器引擎負責解析并提供一些功能的。瀏覽器引擎可能是由 C++ 這樣高效的語言實現的,那么為什么不用 C++ 來寫網頁呢?實際上我認為從技術角度來說并不存在問題,直接下發 C++ 代碼,然后交給 C++ 解釋器去執行,再調用瀏覽器的 C++ 組件,似乎更加符合直覺一些。

    之所以選擇 JavaScript 而不是 C++,除了主流瀏覽器目前都只支持 JavaScript 而不支持 C++ 這個歷史原因以外,更重要的一點是一門語言的高性能和簡單性不可兼得。JavaScript 在運行速度方面做出了犧牲,但也具備了簡單易開發的優點。作為通用編程語言,JavaScript 和 C++ 主要的性能差距就在于缺少類型標注,導致無法進行有效的提前編譯。之前說過 JIT 這種基于緩存去猜測類型的方式存在瓶頸,那么最精確的方式肯定還是直接加上類型標注,這樣就可以直接編譯了,代表性的作品有 Mozilla 的Asm.js。

    Asm.js 是 JavaScript 的一個子集,任何 JavaScript 解釋器都可以解釋它:

  • function?add(a,?b)?{?
  • ????a?=?a?|?0??//?任何整數和自己做按位或運算的結果都是自己?
  • ????b?=?b?|?0??//?所以這個標記不改變運算結果,但是可以提示編譯器?a、b?都是整數?
  • ????return?a?+?b?|?0?
  • }?
  • 如果有 Asm.js 特定的解釋器,完全可以把它提前編譯出來。即使沒有也沒關系,因為它完全是 JavaScript 語法的子集,普通的解釋器也可以解釋。

    然而,回顧一下我們最初對解釋器的定義: 解釋器是一個黑盒,輸入源碼,輸出運行結果。Asm.js 其實是黑盒內部的一個優化,不同的黑盒(瀏覽器)無法共享這一優化。換句話說 Asm.js 寫成的代碼放到 Chrome 上面和普通的 JavaScript 毫無區別。

    于是,包括微軟、谷歌和蘋果在內的各大公司覺得,是時候搞個標準了,這個標準就是 WebAssembly 格式。它是介于中間代碼和目標代碼之間的一種二進制格式,借用WebAssembly 系列(四)WebAssembly 工作原理 一文的插圖來表示:

    通常從中間代碼到機器碼,需要經過平臺具體化(轉目標代碼)和二進制化(匯編器把匯編代碼變為二進制機器碼)這兩個步驟。而 WebAssembly 首先完成了第二個步驟,即已經是二進制格式的,但只是一系列虛擬的通用指令,還需要轉換到各個 CPU 架構上。這樣一來,從 WebAssembly 到機器碼其實是透明且統一的,各個瀏覽器廠商只需要考慮如何從中間代碼轉換 WebAssembly 就行了。

    由于編譯器的前端工具 Clang 可以把 C/C++ 轉換成中間代碼,因此理論上它們都可以用來開發網頁。然而誰會這么這么做呢,放著簡單快捷,現在又高效的 JavaScript 不寫,非要去啃 C++?

    跨語言那些事兒

    C++ 寫網頁這個腦洞雖然比較大,但它啟發我思考一個問題:“對于一個常見的可以由某個語言完成的任務(比如 JavaScript 寫網頁),能不能換一個語言來實現(比如 C++),如果不能,制約因素在哪里”。

    由于絕大多數主流語言都是圖靈完備的,也就是說一切可計算的問題,在這些語言層面都是等價的,都可以計算。那么制約語言能力的因素也就只剩下了運行時的環境是否提供了相應的功能。比如前文解釋過的,雖然瀏覽器中的 JavaScript 不能讀寫文件,不能實現一個服務器,但這是瀏覽器(即運行時環境)不行,不是 JavaScript 不行,只要把運行環境換成 Node.js 就行了。

    直接語法轉換

    大部分讀者應該接觸過簡單的逆向工程。比如編譯后的 .o 目標文件和 .class 字節碼都可以反編譯成源代碼,這種從中間代碼倒推回源代碼的技術也被叫做反編譯(decompile),反編譯器的工作流程基本上是編譯器的倒序,只不過完美的反編譯一般來說比較困難,這取決于中間代碼的實現。像 Java 字節碼這樣的中間代碼,由于信息比較全,所以反編譯就相對容易、準確一些。C 代碼在生成中間代碼時丟失了很多信息,因此就幾乎不可能 100% 準確的倒推回去,感興趣的讀者可以參考一下知名的反編譯工具Hex-Rays 的一篇博客。

    前文說過,編譯器前端可以對多種語言進行詞法分析和語法分析,并且生成一套語言無關的中間代碼,因此理論上來說,如果某個編譯器前端工具支持兩個語言 A 和 B 的解析,那么 A 和 B 是可以互相轉換的,流程如下:

    A 源碼 <--> 語言無關的中間代碼 <--> B 源碼

    其中從源碼轉換到中間代碼需要使用編譯器,從中間代碼轉換到源碼則使用反編譯器。

    但在實際情況中,事情會略復雜一些,這是因為中間代碼雖然是一套語言無關、CPU 也無關的指令集,但不代表不同語言生成的中間代碼就可以通用。比如中間代碼共有 1、2、3、……、6 這六個指令。A 語言生成的中間代碼僅僅是所有指令的一個子集,比如是 1-5 這 5 個指令;B 語言生成的中間代碼可能是所有指令的另一個子集,比如 2-6。這時候我們說的 B 語言的反編譯器,實際上是從 2-6 的指令子集推導出 B 語言源碼,它對指令 1 可能無能為力。

    以 GCC 的中間代碼 RTL: Register Transfer Language 為例,官方文檔 在對 RTL 的解釋中,就明確的把 RTL 樹分為了通用的、C/C++ 特有的、Java 特有的等幾個部分。

    具體來說,我們知道 Java 并不能直接訪問內存地址,這一點和瀏覽器上的 JavaScript 不能讀寫文件很類似,都是因為它們的運行環境(虛擬機)具備這種能力,但沒有在語言層面提供。因此,含有指針四則運算的 C 代碼無法直接被轉換成 Java 代碼,因為 Java 字節碼層面并沒有定義這樣的抽象,一種簡單的方案是申請一個超大的數組,然后自己模擬內存地址。

    所以,即使編譯器前端同時支持兩種語言的解析,要想進行轉換,還必須處理兩種語言在中間代碼層面的一些小差異,實際流程應該是:

    A 源碼 <--> 中間代碼子集(A) <--適配器--> 中間代碼子集(B) <--> B 源碼

    這個思路已經不僅僅停留在理論上了,比如 Github 上有一個庫: emscripten 就實現了將任何 Clang 支持的語言(比如 C/C++ 等)轉換成 JavaScript,再比如 lljvm實現了 C 到 Java 字節碼的轉換。

    然而前文已經解釋過,實現單純語法的轉換意義并不大。一方面,對于圖靈完備的語言來說,換一種表示方法(語言)去解決相同的問題并沒有意義。另一方面,語言的真正功能絕不僅僅是語法本身,而在于它的運行時環境提供了什么樣的功能。比如 Objective-C 的 Foundation 庫提供了字典類型 NSDictionary,它如果直接轉換成 C 語言,將是一個找不到的符號。因為 C 語言的運行時環境根本就不提供對這種數據結構的支持。因此凡是在語言層面進行強制轉換的,要么利用反編譯器拿到一堆格式正確但無法運行的代碼,要么就自行解析語法樹并為轉換后的語言添加對應的能力,來實現轉換前語言的功能。

    比如圖中就是一個 C 語言轉換 Java 的工具,為了實現 C 語言中的字符串申請和釋放內存,這個工具不得不自己實現了 com.mtsystems.coot.String8 類。這樣巨大的成本,顯然不夠普適,應用場景相對有限。

    總之,直接的語法轉換是一個美好的想法,但實現起來難度大,收益有限,通常是為了移植已經用某個語言寫好的框架,或者開個腦洞用于學習,但實際應用場景并不多。

    膠水語言 Python

    Python 一個很強大的特點是膠水語言,可以把 Python 理解為各種語言的粘合劑。對于 Python 可以處理的邏輯,用 Python 代碼即可完成。如果追求極致的性能或者調用已經實現的功能,也可以讓 Python 調用已經由別的語言實現的模塊,以 Python 和 C 語言的交互解釋一下。

    首先,如果是 C 語言要執行 Python 代碼,顯然需要一個 Python 的解釋器。由于在 Mac OS X 系統上,Python 解釋器是一個動態鏈接庫,所以只要導入一下頭文件即可,下面這段代碼可以成功輸出 “Hello Python!!!”:

  • #include?<stdio.h>?
  • #import?<Python/Python.h>?
  • ?
  • int?main(int?argc,?const?char?*?argv[])?{?
  • ????Py_SetProgramName(argv[0]);?
  • ????Py_Initialize();?
  • ????PyRun_SimpleString("print?'Hello?Python!!!'\n");?
  • ????Py_Finalize();?
  • ????return?0;?
  • }?
  • 如果是在 iOS 應用里,由于 iOS 系統沒有對應的動態庫,所以需要把 Python 的解釋器打包成一個靜態庫并且鏈接到應用中,網上已經有人做好了: python-for-iphone,這就是為什么我們看到一些教育類的應用模擬了 Python 解釋器,允許用戶編寫 Python 代碼并得到輸出。

    Python 調用 Objective-C/C 也不復雜,只需要在 C 代碼中指定要暴露的模塊 A 和要暴露的方法 a,然后 Python 就可以直接調用了:

  • import?A?
  • A.a()?
  • 詳細的教程可以看這里: 如何實現 C/C++ 與 Python 的通信?

    有時候,如果能把自己熟悉的語言應用到一個陌生的領域,無疑會大大降低上手的難度。以 iOS 開發為例,開發者的日常其實是利用 Objective-C 語法來描述一些邏輯,最終利用 UIKit 等框架完成和應用的交互。 一種很自然而然的想法是,能不能用 Python 來實現邏輯,并且調用 Objective-C 的接口,比如 UIKit、Foundation 等。實際上前者是完全可以實現的,但是 Python 調用 Objective-C 遠比調用 C 語言要復雜得多。

    一方面從之前的分析中也能看出,并不是所有的源碼編譯成目標文件都可以被 Python 引用;另一方面,最重要的是 Objective-C 方法調用的特性。我們知道方法調用實際上會被編譯成 msg_Send 并交給 runtime 處理,最終找到函數指針并調用。這里 Objective-C 的 runtime 其實是一個用 C 語言實現動態鏈接庫,它可以理解為 Objective-C 運行時環境的一部分。換句話說,沒有 runtime 這個庫,包含方法調用的 Objective-C 代碼是不可能運行起來的,因為 msg_Send 這個符號無法被重定向,運行時將找不到 msg_Send 函數的地址。就連原生的 Objective-C 代碼都需要依賴運行時,想讓 Python 直接調用某個 Objective-C 編譯出來的庫就更不可能了。

    想用 Python 寫開發 iOS 應用是有可能的,比如: PyObjc,但最終還是要依賴 Runtime。大概的思路是首先用 Python 拿到 runtime 這個庫,然后通過這個庫去和 runtime 交互,進而具備了調用 Objective-C 和各種框架的能力。比如我要實現 Python 中的 UIView 這個類,代碼會變成這樣:

  • import?objc?
  • ?
  • #?這個?objc?是動態加載?libobjc.dylib?得到的?
  • #?Python?會對?objc?做一些封裝,提供調用?runtime?的能力?
  • #?實際的工作還是交給?libobjc.dylib?完成?
  • ?
  • class?UIView:?
  • ????def?__init__(self,?param):?
  • ????????objc.msgSend("UIView",?"init",?param)?
  • 這么做的性價比并不高,如果和 JSPatch 相比,JSPatch 使用了內置的 JavaScriptCore 作為 JavaScript 的解析器,而 PyObjc 就得自己帶一個 libPython.a 解釋器。此外,由于 iOS 系統的沙盒限制,非越獄機器并不能拿到 libobjc 庫,所以這個工具只能在越獄手機上使用。

    OCS

    既然說到了 JSPatch 這一類動態化的 iOS 開發工具,我就斗膽猜測一下騰訊 OCS 的實現原理,目前介紹 OCS 的文章寥寥無幾,由于蘋果公司的要求,原文已經被刪除,從新浪博客上摘錄了一份: OCS ——史上最瘋狂的 iOS 動態化方案。如果用一句話來概述,那么就是 OCS 是一個 Objective-C 解釋器。

    首先,OCS 基于 clang 對下發的 Objective-C 代碼做詞法、語法分析,生成 AST 然后轉化成自定義的一套中間碼(OSScript)。當然,原生的 Objective-C 可以運行,絕不僅僅是編譯器的功勞。就像之前反復強調的那樣,運行時環境也必不可少,比如負責 GCD 的 libdispatch 庫,還有內存管理,多線程等等功能。這些功能原來都由系統的動態庫實現,但現在必須由解釋器實現,所以 OCS 的做法是開發了一套自己的虛擬機去解釋執行中間碼。這個運行原理就和 JVM 非常類似了。

    當然,最終還是要和 Objective-C 的 Runtime 打交道,這樣才能調用 UIKit 等框架。由于對虛擬機的實現原理并不清楚,這里就不敢多講了,希望在學習完 JVM 以后再做分享。

    參考資料

  • AT&T與Intel匯編風格比較
  • glibc
  • WebAssembly 系列(一)生動形象地介紹 WebAssembly
  • Decompilers and beyond
  • python-for-iphone
  • 如何實現 C/C++ 與 Python 的通信?
  • WebAssembly 系列(四)WebAssembly 工作原理
  • 扯淡:大白話聊聊編譯那點事兒
  • rubicon-objc
  • OCS ——史上最瘋狂的 iOS 動態化方案
  • 虛擬機隨談(一):解釋器,樹遍歷解釋器,基于棧與基于寄存器,大雜燴
  • JavaScript的功能是不是都是靠C或者C++這種編譯語言提供的?
  • 計算機編程語言必須能夠自舉嗎?
  • 如何評論瀏覽器最新的 WebAssembly 字節碼技術?
  • Objective-C Runtime —— From Build To Did Launch
  • 10 GENERIC
  • 寫個編譯器,把C++代碼編譯到JVM的字節碼可不可行??
  • 作者:bestswifter

    轉載于:https://www.cnblogs.com/jacksplwxy/p/10807114.html

    總結

    以上是生活随笔為你收集整理的大前端开发者需要了解的基础编译原理和语言知识的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    高中生自慰www网站 | 欧美性黑人极品hd | 国产精品沙发午睡系列 | 国产特级毛片aaaaaa高潮流水 | yw尤物av无码国产在线观看 | 国产精品久久久久无码av色戒 | 国产一区二区不卡老阿姨 | 精品无码一区二区三区的天堂 | 久激情内射婷内射蜜桃人妖 | 人妻aⅴ无码一区二区三区 | 中国大陆精品视频xxxx | 色窝窝无码一区二区三区色欲 | 一个人看的www免费视频在线观看 | 丰满人妻一区二区三区免费视频 | 国内精品人妻无码久久久影院 | 无码毛片视频一区二区本码 | 久久久久久亚洲精品a片成人 | 欧美自拍另类欧美综合图片区 | 99麻豆久久久国产精品免费 | 亚洲一区二区三区国产精华液 | 大乳丰满人妻中文字幕日本 | 国产午夜精品一区二区三区嫩草 | 丰满护士巨好爽好大乳 | 天堂在线观看www | 亚洲国产综合无码一区 | 国产av人人夜夜澡人人爽麻豆 | 成人动漫在线观看 | 日韩精品无码一区二区中文字幕 | 国产亚洲精品久久久久久大师 | 中文字幕中文有码在线 | 亚洲成色www久久网站 | 97精品国产97久久久久久免费 | 免费国产黄网站在线观看 | 久久午夜无码鲁丝片秋霞 | 国产黑色丝袜在线播放 | 国产极品美女高潮无套在线观看 | 黑人巨大精品欧美一区二区 | 伊人久久大香线焦av综合影院 | 5858s亚洲色大成网站www | 国产福利视频一区二区 | 国产精品亚洲五月天高清 | 人人妻人人澡人人爽精品欧美 | 特级做a爰片毛片免费69 | 亚洲一区二区三区含羞草 | 樱花草在线播放免费中文 | 久久综合给合久久狠狠狠97色 | 国产亚洲tv在线观看 | 国产猛烈高潮尖叫视频免费 | 美女扒开屁股让男人桶 | 国内精品久久久久久中文字幕 | 精品偷拍一区二区三区在线看 | 国产精品高潮呻吟av久久 | 风流少妇按摩来高潮 | 欧美成人免费全部网站 | 中文字幕人妻无码一夲道 | 狂野欧美性猛交免费视频 | 在线看片无码永久免费视频 | 综合人妻久久一区二区精品 | 久久成人a毛片免费观看网站 | 国产熟女一区二区三区四区五区 | 国产亚洲视频中文字幕97精品 | 久久综合给合久久狠狠狠97色 | 国产麻豆精品精东影业av网站 | 色一情一乱一伦一视频免费看 | 一区二区三区乱码在线 | 欧洲 | 无码一区二区三区在线 | 成人av无码一区二区三区 | 国产熟妇另类久久久久 | 国产va免费精品观看 | 美女黄网站人色视频免费国产 | 亚洲欧洲日本无在线码 | av无码久久久久不卡免费网站 | 一二三四社区在线中文视频 | 成人欧美一区二区三区黑人 | 亚洲 欧美 激情 小说 另类 | 日日摸日日碰夜夜爽av | 精品无码一区二区三区的天堂 | 丰满少妇女裸体bbw | 麻豆蜜桃av蜜臀av色欲av | 无码人妻av免费一区二区三区 | 亚洲国产日韩a在线播放 | 爱做久久久久久 | 色欲av亚洲一区无码少妇 | 人妻少妇精品无码专区二区 | 无码人妻黑人中文字幕 | 无码毛片视频一区二区本码 | 亚洲人成网站免费播放 | 免费人成网站视频在线观看 | 无码av最新清无码专区吞精 | 久久久久99精品成人片 | 久久亚洲日韩精品一区二区三区 | 天天综合网天天综合色 | 国产精品久久久久9999小说 | 99久久亚洲精品无码毛片 | 欧美三级不卡在线观看 | 蜜桃臀无码内射一区二区三区 | 天天爽夜夜爽夜夜爽 | 国产精品a成v人在线播放 | 无码人妻精品一区二区三区下载 | 欧美zoozzooz性欧美 | 67194成是人免费无码 | 精品偷拍一区二区三区在线看 | 国产色精品久久人妻 | 国产一区二区不卡老阿姨 | 精品国偷自产在线视频 | 精品国产一区av天美传媒 | 撕开奶罩揉吮奶头视频 | 久久综合给合久久狠狠狠97色 | 久久久久成人片免费观看蜜芽 | av无码电影一区二区三区 | 久久午夜无码鲁丝片午夜精品 | 夫妻免费无码v看片 | 色情久久久av熟女人妻网站 | 免费观看激色视频网站 | 中文字幕人成乱码熟女app | 无码乱肉视频免费大全合集 | 国产精品办公室沙发 | 亚洲精品无码人妻无码 | 99精品久久毛片a片 | 国产无av码在线观看 | 日韩 欧美 动漫 国产 制服 | 午夜无码人妻av大片色欲 | 日本一卡2卡3卡四卡精品网站 | 国产午夜亚洲精品不卡下载 | 内射老妇bbwx0c0ck | av无码不卡在线观看免费 | 人人妻人人澡人人爽人人精品浪潮 | 内射爽无广熟女亚洲 | 熟女少妇在线视频播放 | 日本乱偷人妻中文字幕 | 精品人妻人人做人人爽 | 麻豆国产人妻欲求不满 | 美女黄网站人色视频免费国产 | 免费无码av一区二区 | 东京热一精品无码av | 午夜精品一区二区三区的区别 | 精品无码一区二区三区的天堂 | 女人色极品影院 | 欧美丰满老熟妇xxxxx性 | 人妻天天爽夜夜爽一区二区 | 少妇一晚三次一区二区三区 | 国产尤物精品视频 | 亚洲日韩一区二区三区 | 久久国产精品偷任你爽任你 | 理论片87福利理论电影 | 日本护士xxxxhd少妇 | 少妇一晚三次一区二区三区 | 国产精品igao视频网 | 麻豆蜜桃av蜜臀av色欲av | 欧美freesex黑人又粗又大 | 精品久久久久久人妻无码中文字幕 | 天干天干啦夜天干天2017 | 亚洲中文无码av永久不收费 | 福利一区二区三区视频在线观看 | 高中生自慰www网站 | 久久久久久a亚洲欧洲av冫 | 国内精品人妻无码久久久影院 | 国产亚洲人成在线播放 | 欧美国产日产一区二区 | 中文字幕色婷婷在线视频 | 日欧一片内射va在线影院 | 日本大香伊一区二区三区 | 色婷婷欧美在线播放内射 | 对白脏话肉麻粗话av | 老熟女重囗味hdxx69 | 成人欧美一区二区三区黑人免费 | 国产办公室秘书无码精品99 | 成人亚洲精品久久久久 | 国产婷婷色一区二区三区在线 | 国产av剧情md精品麻豆 | 3d动漫精品啪啪一区二区中 | 内射欧美老妇wbb | 欧美人与物videos另类 | 少妇久久久久久人妻无码 | 精品少妇爆乳无码av无码专区 | 青青久在线视频免费观看 | 一二三四社区在线中文视频 | 国产精品美女久久久久av爽李琼 | √天堂中文官网8在线 | 熟女俱乐部五十路六十路av | 99久久无码一区人妻 | 性欧美疯狂xxxxbbbb | 亚洲欧美日韩综合久久久 | 一个人免费观看的www视频 | 日本熟妇人妻xxxxx人hd | 午夜成人1000部免费视频 | 牲交欧美兽交欧美 | 成人欧美一区二区三区 | 日本一本二本三区免费 | 久久久久久九九精品久 | 国产人妻人伦精品1国产丝袜 | 国产精品久久久久9999小说 | 亚洲精品www久久久 | 亚洲欧美日韩成人高清在线一区 | 中文字幕人妻丝袜二区 | 精品欧美一区二区三区久久久 | 老头边吃奶边弄进去呻吟 | 麻豆精产国品 | 国产精品久久久久无码av色戒 | 亚洲一区二区三区含羞草 | 亚洲色欲久久久综合网东京热 | 久久午夜无码鲁丝片秋霞 | 国产亚洲欧美日韩亚洲中文色 | 麻豆人妻少妇精品无码专区 | 国产成人无码专区 | 亚洲色欲色欲欲www在线 | 久久精品国产精品国产精品污 | 日本丰满护士爆乳xxxx | 精品无码av一区二区三区 | 人人妻人人澡人人爽欧美一区 | 亚洲欧洲日本无在线码 | 精品午夜福利在线观看 | 少妇高潮一区二区三区99 | 俄罗斯老熟妇色xxxx | 久久www免费人成人片 | 无码中文字幕色专区 | 精品无码一区二区三区的天堂 | 中文字幕乱码中文乱码51精品 | a片在线免费观看 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 精品日本一区二区三区在线观看 | 日本饥渴人妻欲求不满 | 国产97在线 | 亚洲 | 国产精品18久久久久久麻辣 | 久久亚洲国产成人精品性色 | 国产三级久久久精品麻豆三级 | 欧美一区二区三区视频在线观看 | 国产无套内射久久久国产 | 亚洲欧洲日本综合aⅴ在线 | 国産精品久久久久久久 | 亚洲色欲久久久综合网东京热 | 久久精品中文字幕一区 | 搡女人真爽免费视频大全 | 人人澡人摸人人添 | а√天堂www在线天堂小说 | 中文字幕乱妇无码av在线 | 一本大道伊人av久久综合 | 精品无码成人片一区二区98 | 国产在线一区二区三区四区五区 | 国产极品视觉盛宴 | 无码吃奶揉捏奶头高潮视频 | 无码人妻丰满熟妇区五十路百度 | 国产偷国产偷精品高清尤物 | 一二三四社区在线中文视频 | 四虎永久在线精品免费网址 | 99riav国产精品视频 | 成人av无码一区二区三区 | 波多野结衣乳巨码无在线观看 | 俺去俺来也在线www色官网 | 欧美人与禽zoz0性伦交 | 中文字幕 亚洲精品 第1页 | 女人色极品影院 | 国产精品久久久一区二区三区 | 久久久久人妻一区精品色欧美 | 日本爽爽爽爽爽爽在线观看免 | 欧美亚洲国产一区二区三区 | 蜜臀aⅴ国产精品久久久国产老师 | 中国女人内谢69xxxx | 精品成人av一区二区三区 | 国产成人人人97超碰超爽8 | 国内精品人妻无码久久久影院蜜桃 | 无码乱肉视频免费大全合集 | 老熟妇仑乱视频一区二区 | 国内精品一区二区三区不卡 | 天堂无码人妻精品一区二区三区 | 国产乱人偷精品人妻a片 | 妺妺窝人体色www在线小说 | 国产精品欧美成人 | 久久国产精品偷任你爽任你 | 欧美丰满熟妇xxxx性ppx人交 | 免费观看的无遮挡av | 色婷婷久久一区二区三区麻豆 | 国产97在线 | 亚洲 | 成人欧美一区二区三区黑人免费 | 最近免费中文字幕中文高清百度 | 日韩av激情在线观看 | 国产亚洲视频中文字幕97精品 | 亚洲一区二区三区无码久久 | 国产亚洲日韩欧美另类第八页 | 国产明星裸体无码xxxx视频 | 欧美日韩一区二区综合 | 国产黄在线观看免费观看不卡 | 免费看男女做好爽好硬视频 | 久久久无码中文字幕久... | 偷窥村妇洗澡毛毛多 | 亚洲国精产品一二二线 | 国产电影无码午夜在线播放 | 午夜精品久久久久久久久 | 帮老师解开蕾丝奶罩吸乳网站 | 亚洲一区二区三区国产精华液 | 亚洲s色大片在线观看 | 亚洲欧美综合区丁香五月小说 | 亚洲乱码中文字幕在线 | 人人妻人人澡人人爽人人精品浪潮 | 黑人大群体交免费视频 | 成人欧美一区二区三区黑人免费 | 九九久久精品国产免费看小说 | 中文字幕精品av一区二区五区 | 欧美国产亚洲日韩在线二区 | 久久精品国产99久久6动漫 | 午夜不卡av免费 一本久久a久久精品vr综合 | 国产一区二区三区四区五区加勒比 | 国产激情综合五月久久 | 欧美精品在线观看 | 撕开奶罩揉吮奶头视频 | 久久这里只有精品视频9 | 鲁大师影院在线观看 | 在线观看国产午夜福利片 | 麻豆av传媒蜜桃天美传媒 | 精品无码国产一区二区三区av | 99久久亚洲精品无码毛片 | 亚洲小说春色综合另类 | 亚洲aⅴ无码成人网站国产app | 少妇愉情理伦片bd | 夜夜高潮次次欢爽av女 | 国产美女精品一区二区三区 | 成人无码影片精品久久久 | 中文字幕+乱码+中文字幕一区 | 国产人妖乱国产精品人妖 | 精品熟女少妇av免费观看 | 好屌草这里只有精品 | 学生妹亚洲一区二区 | 无码国产色欲xxxxx视频 | 国产精品美女久久久久av爽李琼 | 激情内射亚州一区二区三区爱妻 | 无码人妻久久一区二区三区不卡 | 国产av一区二区三区最新精品 | 两性色午夜免费视频 | 精品偷拍一区二区三区在线看 | 东京热无码av男人的天堂 | 精品国产精品久久一区免费式 | 一个人免费观看的www视频 | 亚洲成av人影院在线观看 | 伊人久久大香线焦av综合影院 | 国产特级毛片aaaaaa高潮流水 | 成人精品视频一区二区三区尤物 | 天下第一社区视频www日本 | 亚洲阿v天堂在线 | 亚洲熟悉妇女xxx妇女av | 毛片内射-百度 | 精品厕所偷拍各类美女tp嘘嘘 | 国产成人人人97超碰超爽8 | 免费观看的无遮挡av | 欧美人妻一区二区三区 | 夜夜影院未满十八勿进 | 亚洲狠狠婷婷综合久久 | 丰满人妻精品国产99aⅴ | 在线观看欧美一区二区三区 | 日韩少妇内射免费播放 | 亚洲码国产精品高潮在线 | 好爽又高潮了毛片免费下载 | 亚洲爆乳精品无码一区二区三区 | 亚洲 另类 在线 欧美 制服 | 国产亚洲精品久久久久久久久动漫 | 亚洲毛片av日韩av无码 | 国产精品久久福利网站 | 中文字幕日韩精品一区二区三区 | 正在播放东北夫妻内射 | 牲欲强的熟妇农村老妇女 | 中文字幕乱码中文乱码51精品 | 国产又爽又猛又粗的视频a片 | 亚洲日韩精品欧美一区二区 | 欧美精品一区二区精品久久 | 日本高清一区免费中文视频 | 97色伦图片97综合影院 | 99久久亚洲精品无码毛片 | 欧洲熟妇精品视频 | 欧美激情一区二区三区成人 | 野狼第一精品社区 | 国产成人无码区免费内射一片色欲 | 国产三级精品三级男人的天堂 | 少妇人妻大乳在线视频 | 日日摸天天摸爽爽狠狠97 | 久久国产精品精品国产色婷婷 | 国产成人精品久久亚洲高清不卡 | 亚洲国产午夜精品理论片 | 久久 国产 尿 小便 嘘嘘 | 精品亚洲韩国一区二区三区 | 无套内谢的新婚少妇国语播放 | 亚洲熟悉妇女xxx妇女av | 国产精品鲁鲁鲁 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 久久久成人毛片无码 | 99麻豆久久久国产精品免费 | 久久aⅴ免费观看 | 天堂久久天堂av色综合 | 国产亚洲精品久久久久久大师 | 一二三四社区在线中文视频 | 亚洲精品中文字幕久久久久 | 波多野结衣av在线观看 | 东京一本一道一二三区 | 性欧美熟妇videofreesex | 亚洲综合无码久久精品综合 | 成人女人看片免费视频放人 | 强伦人妻一区二区三区视频18 | 青青久在线视频免费观看 | 国产在线精品一区二区三区直播 | 日本成熟视频免费视频 | 乱人伦中文视频在线观看 | 国产舌乚八伦偷品w中 | 精品无码国产自产拍在线观看蜜 | 好爽又高潮了毛片免费下载 | 国内少妇偷人精品视频 | 久久久www成人免费毛片 | 久久精品国产一区二区三区 | 欧美 亚洲 国产 另类 | 夜精品a片一区二区三区无码白浆 | 欧美人与动性行为视频 | 亚洲综合久久一区二区 | 中文字幕av伊人av无码av | 国产suv精品一区二区五 | 人妻尝试又大又粗久久 | 色欲人妻aaaaaaa无码 | 亚洲中文字幕成人无码 | 国产精品无码一区二区桃花视频 | 精品成在人线av无码免费看 | 7777奇米四色成人眼影 | 国产亲子乱弄免费视频 | 久久综合久久自在自线精品自 | 漂亮人妻洗澡被公强 日日躁 | 国产综合色产在线精品 | 激情五月综合色婷婷一区二区 | 7777奇米四色成人眼影 | 美女极度色诱视频国产 | 日本高清一区免费中文视频 | 成人性做爰aaa片免费看 | 国产成人无码av一区二区 | 国产精品丝袜黑色高跟鞋 | 久久久久99精品国产片 | 最近的中文字幕在线看视频 | 日韩精品成人一区二区三区 | 无遮挡啪啪摇乳动态图 | 欧美黑人巨大xxxxx | 欧洲极品少妇 | 少女韩国电视剧在线观看完整 | 免费无码的av片在线观看 | 日韩少妇内射免费播放 | 夜精品a片一区二区三区无码白浆 | 人妻体内射精一区二区三四 | 久久人人爽人人爽人人片ⅴ | 少妇愉情理伦片bd | 一本久道久久综合狠狠爱 | 亚洲精品久久久久中文第一幕 | 又大又硬又黄的免费视频 | 亚洲综合伊人久久大杳蕉 | 久久成人a毛片免费观看网站 | 精品久久久无码人妻字幂 | 人人妻人人澡人人爽欧美一区 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 国产激情无码一区二区app | 亚洲欧洲日本无在线码 | 国产精品亚洲а∨无码播放麻豆 | 四虎国产精品免费久久 | √8天堂资源地址中文在线 | 夜夜高潮次次欢爽av女 | 久激情内射婷内射蜜桃人妖 | 婷婷丁香六月激情综合啪 | 亚洲欧美精品aaaaaa片 | 扒开双腿疯狂进出爽爽爽视频 | 国产亚av手机在线观看 | 亚洲中文字幕成人无码 | 熟妇人妻中文av无码 | 在线 国产 欧美 亚洲 天堂 | 亚洲成熟女人毛毛耸耸多 | 欧美性色19p | 亚洲国产精品美女久久久久 | 国产激情精品一区二区三区 | 无码人妻丰满熟妇区五十路百度 | 高清不卡一区二区三区 | 久久精品国产一区二区三区肥胖 | 天堂一区人妻无码 | 国产小呦泬泬99精品 | 欧美zoozzooz性欧美 | 国产精品久久久av久久久 | 青青久在线视频免费观看 | 欧美国产日产一区二区 | 伊人久久婷婷五月综合97色 | 永久免费精品精品永久-夜色 | 国产深夜福利视频在线 | 国内综合精品午夜久久资源 | 天天拍夜夜添久久精品大 | 欧美丰满熟妇xxxx | 亚洲成熟女人毛毛耸耸多 | 亚洲国产欧美国产综合一区 | 亚洲国产精品无码久久久久高潮 | 国产性生交xxxxx无码 | 久久精品国产99久久6动漫 | 日本丰满护士爆乳xxxx | 人人澡人人妻人人爽人人蜜桃 | 中文字幕 人妻熟女 | 妺妺窝人体色www在线小说 | 给我免费的视频在线观看 | av无码电影一区二区三区 | 亚洲国产精品一区二区美利坚 | 亚洲va欧美va天堂v国产综合 | 九九久久精品国产免费看小说 | 老太婆性杂交欧美肥老太 | 中文字幕乱妇无码av在线 | 欧美猛少妇色xxxxx | 中文字幕 亚洲精品 第1页 | 九九在线中文字幕无码 | 国产精品美女久久久久av爽李琼 | 亚洲国产成人a精品不卡在线 | 大屁股大乳丰满人妻 | 国产另类ts人妖一区二区 | 初尝人妻少妇中文字幕 | 性欧美大战久久久久久久 | 国产免费无码一区二区视频 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 国产精品欧美成人 | 中文字幕无码av波多野吉衣 | 国产亚洲精品久久久久久大师 | 日本爽爽爽爽爽爽在线观看免 | 福利一区二区三区视频在线观看 | 国产免费无码一区二区视频 | 中文字幕乱妇无码av在线 | 精品一区二区不卡无码av | 粉嫩少妇内射浓精videos | 久久精品无码一区二区三区 | 无码精品国产va在线观看dvd | 日本饥渴人妻欲求不满 | 亚洲欧美国产精品久久 | 一个人看的视频www在线 | 中文字幕乱码中文乱码51精品 | 免费人成网站视频在线观看 | 亚洲 另类 在线 欧美 制服 | 国产一区二区三区精品视频 | 久久综合久久自在自线精品自 | 荫蒂被男人添的好舒服爽免费视频 | 日韩av无码一区二区三区 | 国产手机在线αⅴ片无码观看 | 2020最新国产自产精品 | 国产成人综合色在线观看网站 | 老太婆性杂交欧美肥老太 | 亚洲s色大片在线观看 | 久久久久se色偷偷亚洲精品av | 熟女少妇人妻中文字幕 | 国产综合色产在线精品 | 999久久久国产精品消防器材 | 国产 浪潮av性色四虎 | 国产麻豆精品一区二区三区v视界 | 强奷人妻日本中文字幕 | 亚洲国产av精品一区二区蜜芽 | 国产亚洲精品久久久ai换 | 国产精品怡红院永久免费 | 99久久久无码国产aaa精品 | 亚洲中文字幕成人无码 | 乱人伦人妻中文字幕无码 | 性色欲情网站iwww九文堂 | 一本色道久久综合狠狠躁 | 久久久婷婷五月亚洲97号色 | 国产办公室秘书无码精品99 | 欧美35页视频在线观看 | 午夜精品一区二区三区在线观看 | 欧洲精品码一区二区三区免费看 | 在线播放亚洲第一字幕 | 国产内射老熟女aaaa | 久久久精品人妻久久影视 | 爆乳一区二区三区无码 | 亚洲色在线无码国产精品不卡 | 色综合视频一区二区三区 | 无码国产乱人伦偷精品视频 | 精品无码国产自产拍在线观看蜜 | 麻豆国产人妻欲求不满 | 中国女人内谢69xxxx | 亚洲欧美国产精品久久 | 麻豆md0077饥渴少妇 | 中文字幕无码日韩欧毛 | 内射后入在线观看一区 | 中文字幕亚洲情99在线 | 老熟妇仑乱视频一区二区 | 性色欲情网站iwww九文堂 | 精品一区二区三区波多野结衣 | 图片区 小说区 区 亚洲五月 | 国精产品一区二区三区 | 人妻天天爽夜夜爽一区二区 | 无码人妻久久一区二区三区不卡 | 免费男性肉肉影院 | 一本色道婷婷久久欧美 | 又大又黄又粗又爽的免费视频 | 国产精品久久久一区二区三区 | 麻豆果冻传媒2021精品传媒一区下载 | av人摸人人人澡人人超碰下载 | 奇米影视7777久久精品人人爽 | yw尤物av无码国产在线观看 | 无码人妻出轨黑人中文字幕 | 欧美zoozzooz性欧美 | 伊在人天堂亚洲香蕉精品区 | 无码人妻丰满熟妇区毛片18 | 少妇人妻av毛片在线看 | 国产黄在线观看免费观看不卡 | 久久亚洲中文字幕无码 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 精品久久综合1区2区3区激情 | 亚洲成av人片天堂网无码】 | 国产免费久久久久久无码 | 性生交大片免费看l | 亚欧洲精品在线视频免费观看 | 色婷婷久久一区二区三区麻豆 | 97久久精品无码一区二区 | 国产 精品 自在自线 | 色综合久久久无码网中文 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 午夜理论片yy44880影院 | 久久天天躁狠狠躁夜夜免费观看 | 丝袜足控一区二区三区 | 亚洲中文字幕成人无码 | 亚洲乱码日产精品bd | 国产极品美女高潮无套在线观看 | 精品无码国产一区二区三区av | 少妇被黑人到高潮喷出白浆 | 精品 日韩 国产 欧美 视频 | 国产精品手机免费 | 日本熟妇浓毛 | 国产精品人妻一区二区三区四 | 久久午夜无码鲁丝片午夜精品 | 国产卡一卡二卡三 | 综合激情五月综合激情五月激情1 | 久久久久免费精品国产 | 六十路熟妇乱子伦 | 色偷偷人人澡人人爽人人模 | 久久亚洲a片com人成 | 伊人久久大香线蕉亚洲 | 无码毛片视频一区二区本码 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 日日麻批免费40分钟无码 | 国产一区二区三区精品视频 | 久久久久se色偷偷亚洲精品av | 红桃av一区二区三区在线无码av | 亚洲中文字幕av在天堂 | 亚洲欧洲日本无在线码 | 中文字幕无码热在线视频 | 对白脏话肉麻粗话av | 国产人妻精品一区二区三区 | 久久久久99精品国产片 | 成年女人永久免费看片 | 香港三级日本三级妇三级 | 特黄特色大片免费播放器图片 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 日本大乳高潮视频在线观看 | 日本熟妇人妻xxxxx人hd | 久久97精品久久久久久久不卡 | 在线а√天堂中文官网 | 蜜桃视频韩日免费播放 | 亚洲理论电影在线观看 | 国产人妖乱国产精品人妖 | 欧美性生交xxxxx久久久 | 丰满少妇人妻久久久久久 | 日本一区二区更新不卡 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 日韩欧美中文字幕公布 | 国产无av码在线观看 | 爆乳一区二区三区无码 | 亚洲日韩av一区二区三区中文 | 麻豆精品国产精华精华液好用吗 | 精品无人区无码乱码毛片国产 | 久久午夜无码鲁丝片 | 无套内谢的新婚少妇国语播放 | 又紧又大又爽精品一区二区 | 97夜夜澡人人双人人人喊 | 精品久久久无码人妻字幂 | 久精品国产欧美亚洲色aⅴ大片 | 无码午夜成人1000部免费视频 | 久久精品成人欧美大片 | 性欧美大战久久久久久久 | 亚洲狠狠婷婷综合久久 | 国产精品igao视频网 | 久久精品国产一区二区三区 | 在线天堂新版最新版在线8 | 澳门永久av免费网站 | 久久精品99久久香蕉国产色戒 | 夜夜夜高潮夜夜爽夜夜爰爰 | 国产精品久久久久无码av色戒 | 毛片内射-百度 | 久久亚洲中文字幕无码 | 一本加勒比波多野结衣 | v一区无码内射国产 | 国内精品一区二区三区不卡 | 精品无人区无码乱码毛片国产 | 亚洲成色在线综合网站 | 国产综合久久久久鬼色 | 中文字幕中文有码在线 | 免费看男女做好爽好硬视频 | 亚洲天堂2017无码 | 人人澡人人透人人爽 | 久久久无码中文字幕久... | 日本在线高清不卡免费播放 | 精品久久8x国产免费观看 | 国产精品无码成人午夜电影 | 国内精品人妻无码久久久影院蜜桃 | 国产97色在线 | 免 | 特大黑人娇小亚洲女 | 丰满岳乱妇在线观看中字无码 | 色综合久久久无码网中文 | 啦啦啦www在线观看免费视频 | 亚洲s码欧洲m码国产av | 久久久久久av无码免费看大片 | 国产精品资源一区二区 | 国产成人精品优优av | 少妇激情av一区二区 | 国产成人无码专区 | 久久99久久99精品中文字幕 | 精品无人区无码乱码毛片国产 | 国产偷抇久久精品a片69 | 亚洲欧美日韩成人高清在线一区 | 欧美放荡的少妇 | 2019午夜福利不卡片在线 | 97精品国产97久久久久久免费 | 亚洲色成人中文字幕网站 | 国产精品无码一区二区桃花视频 | 黑人巨大精品欧美黑寡妇 | 欧美35页视频在线观看 | 国产两女互慰高潮视频在线观看 | 亚洲午夜久久久影院 | 丰满护士巨好爽好大乳 | 亚洲精品国产精品乱码视色 | 成人综合网亚洲伊人 | 俄罗斯老熟妇色xxxx | 国产精品怡红院永久免费 | 久久97精品久久久久久久不卡 | 久激情内射婷内射蜜桃人妖 | 久久久久国色av免费观看性色 | 狠狠噜狠狠狠狠丁香五月 | 国内揄拍国内精品少妇国语 | 亚洲熟女一区二区三区 | 色综合天天综合狠狠爱 | 欧美日韩色另类综合 | 亚洲国产精品一区二区美利坚 | 午夜精品久久久久久久 | 永久免费精品精品永久-夜色 | 亚洲综合另类小说色区 | 国产精品久久久久久亚洲影视内衣 | 亚洲一区二区三区播放 | 丰满岳乱妇在线观看中字无码 | 人妻中文无码久热丝袜 | 亚洲综合精品香蕉久久网 | 亚洲精品一区三区三区在线观看 | 色婷婷综合中文久久一本 | 国产人成高清在线视频99最全资源 | 天堂а√在线地址中文在线 | 亚洲精品一区二区三区在线 | 国产成人无码av片在线观看不卡 | 免费无码午夜福利片69 | 精品水蜜桃久久久久久久 | 噜噜噜亚洲色成人网站 | 日韩人妻系列无码专区 | 九九热爱视频精品 | 国产凸凹视频一区二区 | 亚洲精品国产a久久久久久 | 国产精品第一国产精品 | 亚洲人亚洲人成电影网站色 | 久久久婷婷五月亚洲97号色 | 丰满诱人的人妻3 | 国产精品久久福利网站 | 久久这里只有精品视频9 | 给我免费的视频在线观看 | 亚洲色欲久久久综合网东京热 | 少妇愉情理伦片bd | 色老头在线一区二区三区 | 亚洲色欲久久久综合网东京热 | 欧美乱妇无乱码大黄a片 | 97精品国产97久久久久久免费 | a片免费视频在线观看 | 国产成人无码一二三区视频 | 荡女精品导航 | 欧美一区二区三区 | 日韩av激情在线观看 | 高清不卡一区二区三区 | 熟女少妇在线视频播放 | 久久综合激激的五月天 | 亚洲经典千人经典日产 | 国产精品久久久午夜夜伦鲁鲁 | 亚洲国产精品一区二区第一页 | 欧美亚洲国产一区二区三区 | 四虎永久在线精品免费网址 | 2019午夜福利不卡片在线 | 一本无码人妻在中文字幕免费 | 俺去俺来也在线www色官网 | 少妇人妻偷人精品无码视频 | 中文字幕无码免费久久99 | 色欲av亚洲一区无码少妇 | 久久无码人妻影院 | 东京无码熟妇人妻av在线网址 | 亚洲国产av精品一区二区蜜芽 | 精品久久8x国产免费观看 | 中文字幕无码乱人伦 | 国产一区二区不卡老阿姨 | 亚洲 欧美 激情 小说 另类 | 亚洲 激情 小说 另类 欧美 | 亚洲国产精品久久久久久 | 亚洲中文字幕在线无码一区二区 | 色情久久久av熟女人妻网站 | 小泽玛莉亚一区二区视频在线 | 国产精品久久久久久无码 | 久久婷婷五月综合色国产香蕉 | 99久久精品无码一区二区毛片 | 国产精品无码一区二区三区不卡 | 波多野42部无码喷潮在线 | 久久久久亚洲精品男人的天堂 | 精品国产一区二区三区四区 | 激情爆乳一区二区三区 | 中文字幕乱码亚洲无线三区 | 东京热无码av男人的天堂 | 国产黑色丝袜在线播放 | 亚洲人成网站色7799 | 搡女人真爽免费视频大全 | 亚洲一区二区三区偷拍女厕 | 精品乱子伦一区二区三区 | 亚洲欧美日韩国产精品一区二区 | 国产成人一区二区三区在线观看 | 国产又爽又黄又刺激的视频 | 在线成人www免费观看视频 | 无遮挡国产高潮视频免费观看 | 好屌草这里只有精品 | 成人亚洲精品久久久久 | 欧美日韩视频无码一区二区三 | 熟妇激情内射com | 色偷偷人人澡人人爽人人模 | 性欧美牲交xxxxx视频 | 99麻豆久久久国产精品免费 | 图片小说视频一区二区 | 国产人妻大战黑人第1集 | 欧美精品无码一区二区三区 | 欧美 日韩 人妻 高清 中文 | 啦啦啦www在线观看免费视频 | 中国女人内谢69xxxx | 强辱丰满人妻hd中文字幕 | 久久综合激激的五月天 | 中文字幕乱码中文乱码51精品 | 任你躁国产自任一区二区三区 | 又黄又爽又色的视频 | 成人免费视频视频在线观看 免费 | 久9re热视频这里只有精品 | 男女猛烈xx00免费视频试看 | 东京无码熟妇人妻av在线网址 | 亚洲综合精品香蕉久久网 | 精品国产av色一区二区深夜久久 | 亲嘴扒胸摸屁股激烈网站 | 免费观看激色视频网站 | 精品国偷自产在线视频 | 亚洲精品综合五月久久小说 | 精品一二三区久久aaa片 | 亚洲第一无码av无码专区 | 亚洲日本一区二区三区在线 | 夜夜夜高潮夜夜爽夜夜爰爰 | 久久精品中文闷骚内射 | 麻豆蜜桃av蜜臀av色欲av | 老熟妇乱子伦牲交视频 | 97夜夜澡人人双人人人喊 | 99久久99久久免费精品蜜桃 | 免费播放一区二区三区 | 中文字幕av日韩精品一区二区 | 在线视频网站www色 | 国产乱人无码伦av在线a | 欧美人与禽zoz0性伦交 | 免费视频欧美无人区码 | 亚洲国产精品成人久久蜜臀 | 久久无码专区国产精品s | 色婷婷综合中文久久一本 | 日韩精品无码一区二区中文字幕 | 亚洲人亚洲人成电影网站色 | 国产热a欧美热a在线视频 | 夜夜夜高潮夜夜爽夜夜爰爰 | 狠狠噜狠狠狠狠丁香五月 | 欧美精品一区二区精品久久 | 黑人巨大精品欧美黑寡妇 | 日本又色又爽又黄的a片18禁 | 一本久道久久综合狠狠爱 | 日韩精品乱码av一区二区 | www国产亚洲精品久久久日本 | 无码人妻久久一区二区三区不卡 | 久久亚洲中文字幕无码 | 人人妻人人澡人人爽精品欧美 | 又粗又大又硬毛片免费看 | 国产精品亚洲综合色区韩国 | 成年美女黄网站色大免费视频 | 久久精品人人做人人综合 | 国产一区二区三区日韩精品 | а天堂中文在线官网 | 给我免费的视频在线观看 | 亚洲欧美日韩国产精品一区二区 | 久久精品无码一区二区三区 | 国产精品自产拍在线观看 | 亚洲精品中文字幕 | 免费无码一区二区三区蜜桃大 | 亚洲人成影院在线观看 | 亚洲日本一区二区三区在线 | 97精品人妻一区二区三区香蕉 | 亚洲一区二区三区含羞草 | 无套内谢老熟女 | 国产三级精品三级男人的天堂 | 中国女人内谢69xxxxxa片 | 亚洲自偷自拍另类第1页 | 中文字幕 亚洲精品 第1页 | 亚洲中文字幕无码中字 | 狠狠躁日日躁夜夜躁2020 | 美女毛片一区二区三区四区 | 亚洲精品综合五月久久小说 | 国内精品人妻无码久久久影院 | 亚洲国产精品美女久久久久 | 成 人 免费观看网站 | 亚洲 另类 在线 欧美 制服 | 国产精品久久久久久亚洲影视内衣 | 日本一区二区更新不卡 | 久久精品国产一区二区三区 | 狠狠色欧美亚洲狠狠色www | 精品厕所偷拍各类美女tp嘘嘘 | 欧洲熟妇精品视频 | 日产精品高潮呻吟av久久 | 免费人成在线视频无码 | 高清不卡一区二区三区 | 日韩精品无码免费一区二区三区 | 日韩av无码中文无码电影 | 日韩 欧美 动漫 国产 制服 | 狠狠噜狠狠狠狠丁香五月 | 国产性生大片免费观看性 | 欧美阿v高清资源不卡在线播放 | 国产成人一区二区三区在线观看 | 人人澡人摸人人添 | 国产成人精品必看 | 精品无码成人片一区二区98 | 日韩av无码一区二区三区 | 亚洲欧美日韩综合久久久 | 精品无码成人片一区二区98 | 少妇无码av无码专区在线观看 | 性史性农村dvd毛片 | 国产精品亚洲五月天高清 | 在线亚洲高清揄拍自拍一品区 | 一本久久a久久精品亚洲 | 国产精品鲁鲁鲁 | 欧美精品免费观看二区 | aⅴ亚洲 日韩 色 图网站 播放 | 欧美成人家庭影院 | 国产性生大片免费观看性 | 日日干夜夜干 | 又大又硬又爽免费视频 | 捆绑白丝粉色jk震动捧喷白浆 | 精品国产乱码久久久久乱码 | 综合激情五月综合激情五月激情1 | 国产成人无码av一区二区 | 无码成人精品区在线观看 | 亚洲人成无码网www | 久久99热只有频精品8 | 久久99精品久久久久婷婷 | 国产区女主播在线观看 | 日本乱偷人妻中文字幕 | 国产区女主播在线观看 | 久久久久人妻一区精品色欧美 | 精品国产一区二区三区四区 | 丰满护士巨好爽好大乳 | 久久久www成人免费毛片 | 国产免费久久久久久无码 | 国产午夜亚洲精品不卡 | 97精品国产97久久久久久免费 | 国产69精品久久久久app下载 | 亚洲精品无码人妻无码 | 亚洲自偷自偷在线制服 | 无码国模国产在线观看 | 久久综合香蕉国产蜜臀av | 日韩精品无码一本二本三本色 | 亚洲 a v无 码免 费 成 人 a v | 成人毛片一区二区 | 成人片黄网站色大片免费观看 | 国产av一区二区精品久久凹凸 | 啦啦啦www在线观看免费视频 | 欧美老妇交乱视频在线观看 | 丁香啪啪综合成人亚洲 | 少妇激情av一区二区 | 国产成人无码av片在线观看不卡 | 午夜福利一区二区三区在线观看 | 97无码免费人妻超级碰碰夜夜 | 九月婷婷人人澡人人添人人爽 | 久久精品人妻少妇一区二区三区 | 亚欧洲精品在线视频免费观看 | 久久精品人人做人人综合试看 | 国内精品一区二区三区不卡 | 婷婷丁香六月激情综合啪 | 澳门永久av免费网站 | 欧美日本精品一区二区三区 | 国产精品无套呻吟在线 | 国产成人精品视频ⅴa片软件竹菊 | 国产亚洲人成在线播放 | 国产亚洲美女精品久久久2020 | 日本xxxx色视频在线观看免费 | 国产肉丝袜在线观看 | 扒开双腿疯狂进出爽爽爽视频 | 97久久超碰中文字幕 | 久久精品国产大片免费观看 | 亚洲 高清 成人 动漫 | 亚洲最大成人网站 | 亚洲人成网站色7799 | 国产婷婷色一区二区三区在线 | 国产无遮挡吃胸膜奶免费看 | 国产亚洲日韩欧美另类第八页 | 狂野欧美性猛交免费视频 | 亚洲欧美日韩成人高清在线一区 | a片在线免费观看 | 欧美人与物videos另类 | 老熟女乱子伦 | 好屌草这里只有精品 | 亚洲色大成网站www | 亚洲成熟女人毛毛耸耸多 | 亚洲乱码中文字幕在线 | 亚洲国产综合无码一区 | 人妻与老人中文字幕 | 日日鲁鲁鲁夜夜爽爽狠狠 | 狠狠色噜噜狠狠狠7777奇米 | 人妻aⅴ无码一区二区三区 | 婷婷五月综合激情中文字幕 | 18精品久久久无码午夜福利 | 亚洲精品一区二区三区婷婷月 | 中文久久乱码一区二区 | 国产精品99久久精品爆乳 | 久久国产精品萌白酱免费 | 国产97在线 | 亚洲 | 最新版天堂资源中文官网 | av无码久久久久不卡免费网站 | 丰满人妻精品国产99aⅴ | 欧美丰满熟妇xxxx性ppx人交 | 亚洲日韩av一区二区三区四区 | 妺妺窝人体色www婷婷 | 天天摸天天透天天添 | 亚洲日韩中文字幕在线播放 | 国产国语老龄妇女a片 | 自拍偷自拍亚洲精品被多人伦好爽 | 牛和人交xxxx欧美 | 无套内谢老熟女 | 国产婷婷色一区二区三区在线 | 国产精品无套呻吟在线 | 成人无码视频在线观看网站 | 在线成人www免费观看视频 | 成人亚洲精品久久久久软件 | 无码人妻出轨黑人中文字幕 | 久久天天躁狠狠躁夜夜免费观看 | 少妇被黑人到高潮喷出白浆 | 55夜色66夜色国产精品视频 | 国产女主播喷水视频在线观看 | 天天摸天天碰天天添 | 色窝窝无码一区二区三区色欲 | 99在线 | 亚洲 | 无码午夜成人1000部免费视频 | 久久久精品成人免费观看 | 国产人妻久久精品二区三区老狼 | 天堂久久天堂av色综合 | 男人和女人高潮免费网站 | 国产两女互慰高潮视频在线观看 | 精品国产麻豆免费人成网站 | 久久精品中文字幕大胸 | 亚洲综合另类小说色区 | 日韩精品久久久肉伦网站 | 精品国产aⅴ无码一区二区 | 日日天日日夜日日摸 | 人人爽人人澡人人人妻 | 欧美黑人巨大xxxxx | 国内精品一区二区三区不卡 | 亚洲精品午夜国产va久久成人 | 最新版天堂资源中文官网 | 2020久久超碰国产精品最新 | 国产在线aaa片一区二区99 | 精品无码成人片一区二区98 | 美女黄网站人色视频免费国产 | 人妻少妇精品无码专区二区 | 国产亚洲美女精品久久久2020 | 久久国内精品自在自线 | 玩弄少妇高潮ⅹxxxyw | 无遮无挡爽爽免费视频 | 无码吃奶揉捏奶头高潮视频 | 一本色道婷婷久久欧美 | 国产又爽又黄又刺激的视频 | 免费网站看v片在线18禁无码 | 久久精品人人做人人综合 | 久久无码专区国产精品s | 国产无套粉嫩白浆在线 | 青草视频在线播放 | 日本一卡二卡不卡视频查询 | 国产成人精品久久亚洲高清不卡 | 牲欲强的熟妇农村老妇女 | 成人精品视频一区二区 | 麻豆国产人妻欲求不满谁演的 | 丝袜人妻一区二区三区 | 午夜免费福利小电影 | 无码国产色欲xxxxx视频 | 国产精品无码成人午夜电影 | 99在线 | 亚洲 | 欧美激情内射喷水高潮 | 色五月五月丁香亚洲综合网 | 波多野结衣乳巨码无在线观看 | 久久国产精品_国产精品 | 亚洲日韩av一区二区三区中文 | 无码人妻少妇伦在线电影 | 国产乱人伦偷精品视频 | 国产午夜亚洲精品不卡下载 | 99国产欧美久久久精品 | 少妇性俱乐部纵欲狂欢电影 | 国产成人无码av片在线观看不卡 | 成人免费视频视频在线观看 免费 | 久久综合久久自在自线精品自 | 色偷偷人人澡人人爽人人模 | 老熟妇乱子伦牲交视频 | 午夜精品久久久久久久 | 少妇愉情理伦片bd | 久久久久久九九精品久 | 亚洲精品久久久久中文第一幕 | 香港三级日本三级妇三级 | 一本久久伊人热热精品中文字幕 | 老太婆性杂交欧美肥老太 | 精品无码av一区二区三区 | 亚洲成av人综合在线观看 | 色窝窝无码一区二区三区色欲 | 欧美 丝袜 自拍 制服 另类 | 亚洲小说图区综合在线 | 亚洲熟妇色xxxxx欧美老妇y | 久久97精品久久久久久久不卡 | 中文字幕无线码 | 色欲久久久天天天综合网精品 | 中国大陆精品视频xxxx | 国产成人亚洲综合无码 | 亚洲欧美精品aaaaaa片 | 国产亚洲视频中文字幕97精品 | 久久国内精品自在自线 | 性开放的女人aaa片 | 中文字幕乱码人妻无码久久 | 双乳奶水饱满少妇呻吟 | 国产综合久久久久鬼色 | 亚洲中文字幕乱码av波多ji | 99久久人妻精品免费二区 | 午夜无码区在线观看 | 乱人伦人妻中文字幕无码久久网 | 久久综合香蕉国产蜜臀av | 亚洲一区二区三区含羞草 | 无码福利日韩神码福利片 | 久久久久av无码免费网 | 日韩精品一区二区av在线 | 一本色道久久综合亚洲精品不卡 | 国产激情综合五月久久 | 日本熟妇大屁股人妻 | 精品国产麻豆免费人成网站 | 中文字幕人妻丝袜二区 | 国产熟女一区二区三区四区五区 | 日日噜噜噜噜夜夜爽亚洲精品 | 亚洲综合久久一区二区 | 国产成人无码区免费内射一片色欲 | 1000部啪啪未满十八勿入下载 | 99精品无人区乱码1区2区3区 | 欧美变态另类xxxx | 九九在线中文字幕无码 | 人妻无码αv中文字幕久久琪琪布 | 99久久久国产精品无码免费 | 国产精品怡红院永久免费 | 两性色午夜免费视频 | 久久伊人色av天堂九九小黄鸭 | 天干天干啦夜天干天2017 | 兔费看少妇性l交大片免费 | 亚洲春色在线视频 | 久久99国产综合精品 | 粉嫩少妇内射浓精videos | 熟女少妇人妻中文字幕 | 国产亚av手机在线观看 | 精品乱码久久久久久久 | 蜜臀aⅴ国产精品久久久国产老师 | 国产真实乱对白精彩久久 | 中文字幕av无码一区二区三区电影 | 亚洲精品久久久久avwww潮水 | 精品久久久中文字幕人妻 | 高清无码午夜福利视频 | 少妇人妻av毛片在线看 | 搡女人真爽免费视频大全 | 最新国产乱人伦偷精品免费网站 | 久久伊人色av天堂九九小黄鸭 | 欧美三级a做爰在线观看 | 强奷人妻日本中文字幕 | 少妇高潮一区二区三区99 | 色欲综合久久中文字幕网 | 中国大陆精品视频xxxx | 2020久久香蕉国产线看观看 | 亚洲 激情 小说 另类 欧美 | 大胆欧美熟妇xx | 国产女主播喷水视频在线观看 | 在线观看国产午夜福利片 | 无码国产乱人伦偷精品视频 | 欧洲欧美人成视频在线 | 久久无码人妻影院 | 婷婷色婷婷开心五月四房播播 | 国产一区二区三区日韩精品 | 欧美丰满老熟妇xxxxx性 | 99re在线播放 | 小sao货水好多真紧h无码视频 | 久久午夜夜伦鲁鲁片无码免费 | 任你躁国产自任一区二区三区 | 天海翼激烈高潮到腰振不止 | 日本一卡2卡3卡四卡精品网站 | 日日摸天天摸爽爽狠狠97 | 国产精品久久久久久亚洲毛片 | 狠狠色噜噜狠狠狠狠7777米奇 | 永久黄网站色视频免费直播 | 久久精品国产一区二区三区肥胖 | 伊人色综合久久天天小片 | 久久人妻内射无码一区三区 | 清纯唯美经典一区二区 | 欧美色就是色 | 鲁大师影院在线观看 | 日本乱偷人妻中文字幕 | 成人一区二区免费视频 | 俺去俺来也在线www色官网 | 国产av一区二区三区最新精品 | 国产午夜福利100集发布 | 亚洲精品美女久久久久久久 | 欧美日韩视频无码一区二区三 | 奇米影视7777久久精品 | 少妇性l交大片欧洲热妇乱xxx | 青草青草久热国产精品 | 久久午夜无码鲁丝片秋霞 | www一区二区www免费 | 亚洲色成人中文字幕网站 | 久久久久久久女国产乱让韩 | 国产又爽又猛又粗的视频a片 | 久久久久久久久888 | 我要看www免费看插插视频 | 99久久久国产精品无码免费 | 日本高清一区免费中文视频 | 一本久道久久综合婷婷五月 | 国产精品国产三级国产专播 | 无码乱肉视频免费大全合集 | 免费无码午夜福利片69 | 亚洲中文字幕va福利 | 中文字幕乱码中文乱码51精品 | 久久www免费人成人片 | 熟妇人妻无乱码中文字幕 | 亚洲自偷精品视频自拍 | 久久久久免费精品国产 | 人人爽人人爽人人片av亚洲 | 99久久99久久免费精品蜜桃 | 国产成人av免费观看 | 成人影院yy111111在线观看 | 久久熟妇人妻午夜寂寞影院 | 999久久久国产精品消防器材 | 丰满护士巨好爽好大乳 | 久久亚洲a片com人成 | 日产精品99久久久久久 | 国产av无码专区亚洲awww | 无码人中文字幕 | 精品人妻中文字幕有码在线 | 国产午夜手机精彩视频 | 乱码午夜-极国产极内射 | 亚洲 另类 在线 欧美 制服 | 久久国产精品精品国产色婷婷 | 亚洲欧美色中文字幕在线 | 亚洲区欧美区综合区自拍区 | 中文字幕+乱码+中文字幕一区 | 精品久久久久香蕉网 | 亚洲一区二区三区国产精华液 | 综合激情五月综合激情五月激情1 | 狂野欧美性猛xxxx乱大交 | 日韩av无码一区二区三区 | 免费国产黄网站在线观看 | 国产精品久久久久久久影院 | 国语精品一区二区三区 | 久久久久久国产精品无码下载 | 国产av剧情md精品麻豆 | 国产激情精品一区二区三区 | 少妇性俱乐部纵欲狂欢电影 | 女人被男人躁得好爽免费视频 | 亚洲人成人无码网www国产 | 精品久久久无码人妻字幂 | 自拍偷自拍亚洲精品被多人伦好爽 | 免费无码av一区二区 | 九一九色国产 | 国产美女极度色诱视频www | 一本久久伊人热热精品中文字幕 | 国产美女精品一区二区三区 | 亚洲va欧美va天堂v国产综合 | 波多野42部无码喷潮在线 | v一区无码内射国产 | 99久久久无码国产aaa精品 | 久久精品99久久香蕉国产色戒 | 欧美精品免费观看二区 | 午夜性刺激在线视频免费 | 亚洲成av人片天堂网无码】 | 国产精品a成v人在线播放 | 午夜精品久久久内射近拍高清 | 亚洲男人av香蕉爽爽爽爽 | 亚洲日本va中文字幕 | 欧美黑人乱大交 | 国产精品无码久久av | 亚洲精品久久久久久一区二区 | 国产精品国产三级国产专播 | 久久精品人人做人人综合试看 | 色偷偷人人澡人人爽人人模 | 一本久道久久综合婷婷五月 | 人妻无码久久精品人妻 | 亚洲精品综合五月久久小说 | 强伦人妻一区二区三区视频18 | 无码福利日韩神码福利片 | 国产精品手机免费 | 伊人久久大香线蕉午夜 | 76少妇精品导航 | 伊人久久大香线蕉午夜 | 内射后入在线观看一区 | 无码人妻丰满熟妇区毛片18 | 18精品久久久无码午夜福利 | 青青草原综合久久大伊人精品 | 国产亚洲精品久久久久久大师 | 无码播放一区二区三区 | а√资源新版在线天堂 | 国产超级va在线观看视频 | 国产午夜精品一区二区三区嫩草 | 未满成年国产在线观看 | 中文字幕av无码一区二区三区电影 | 久久人人爽人人爽人人片av高清 | 精品久久久久久人妻无码中文字幕 | 成人av无码一区二区三区 | 粉嫩少妇内射浓精videos | 亚洲中文字幕成人无码 | 又粗又大又硬毛片免费看 | 极品尤物被啪到呻吟喷水 | 国产午夜福利100集发布 | 亚洲精品美女久久久久久久 | 久久久婷婷五月亚洲97号色 | 中文字幕av日韩精品一区二区 | 精品人妻中文字幕有码在线 | 久久精品女人天堂av免费观看 | 自拍偷自拍亚洲精品10p | 亚洲一区二区三区四区 | 亚洲国产欧美国产综合一区 | 熟妇人妻无乱码中文字幕 | 成人欧美一区二区三区黑人 | 乌克兰少妇xxxx做受 | 青春草在线视频免费观看 | 国产麻豆精品精东影业av网站 | 国产成人午夜福利在线播放 | 免费国产黄网站在线观看 | 亚洲精品无码人妻无码 | 日本大乳高潮视频在线观看 | 老子影院午夜伦不卡 | 国产精品多人p群无码 | 国产精品99爱免费视频 | 国产精品久久国产三级国 | 在线播放免费人成毛片乱码 | 色老头在线一区二区三区 | 亚洲成a人片在线观看无码 | 亚洲国产一区二区三区在线观看 | √8天堂资源地址中文在线 | 又紧又大又爽精品一区二区 | 丝袜人妻一区二区三区 | 精品偷拍一区二区三区在线看 | 中文字幕 亚洲精品 第1页 | 一本无码人妻在中文字幕免费 | 久久综合激激的五月天 | 国产精品久久久一区二区三区 | 中文字幕无码av激情不卡 | 亚洲一区二区三区偷拍女厕 | 成年美女黄网站色大免费视频 | 国产精品无码一区二区桃花视频 | 亚洲а∨天堂久久精品2021 | 天天拍夜夜添久久精品 | www国产亚洲精品久久久日本 | 国产午夜手机精彩视频 | 国产真实夫妇视频 | 亚洲熟女一区二区三区 | 日日麻批免费40分钟无码 | 国产小呦泬泬99精品 | 丁香花在线影院观看在线播放 | 又粗又大又硬毛片免费看 | а天堂中文在线官网 | 白嫩日本少妇做爰 | 欧洲美熟女乱又伦 | 乱码午夜-极国产极内射 | 亚洲综合在线一区二区三区 | 国产精品久久久久久久影院 | 色一情一乱一伦一视频免费看 | 欧美国产亚洲日韩在线二区 | 在线 国产 欧美 亚洲 天堂 | 亚洲日韩av一区二区三区四区 | 在教室伦流澡到高潮hnp视频 | 国产精品久久久久久亚洲毛片 | 色欲人妻aaaaaaa无码 | 久久精品国产99久久6动漫 | 欧美一区二区三区视频在线观看 | 亚洲第一无码av无码专区 | 在线播放无码字幕亚洲 | v一区无码内射国产 | 亚洲无人区午夜福利码高清完整版 | 女人和拘做爰正片视频 | 国产成人综合美国十次 | 精品国产乱码久久久久乱码 | 亚洲热妇无码av在线播放 | 日本熟妇大屁股人妻 | 51国偷自产一区二区三区 | 精品乱子伦一区二区三区 | 成人欧美一区二区三区黑人免费 | 天堂亚洲2017在线观看 | 国产精品丝袜黑色高跟鞋 | 扒开双腿疯狂进出爽爽爽视频 | 成人欧美一区二区三区黑人 | 亚洲成av人片在线观看无码不卡 | 亚洲中文字幕在线观看 | 久久综合狠狠综合久久综合88 | 国产熟女一区二区三区四区五区 | 国产美女精品一区二区三区 | 国产精品久久久久无码av色戒 | 欧美精品在线观看 | 捆绑白丝粉色jk震动捧喷白浆 | 好爽又高潮了毛片免费下载 | 国产人妻人伦精品1国产丝袜 | 亚洲熟女一区二区三区 | 欧美性色19p | 亚洲成熟女人毛毛耸耸多 | 好爽又高潮了毛片免费下载 | 男女爱爱好爽视频免费看 | 无码吃奶揉捏奶头高潮视频 | 日日鲁鲁鲁夜夜爽爽狠狠 | 亚洲伊人久久精品影院 | 亚洲乱码日产精品bd | 成人一在线视频日韩国产 | 性欧美牲交在线视频 | 国产熟妇另类久久久久 | 欧美激情一区二区三区成人 | 强奷人妻日本中文字幕 | 乱码午夜-极国产极内射 | 亚洲色欲色欲天天天www | 亚洲国产欧美日韩精品一区二区三区 | 欧洲精品码一区二区三区免费看 | 欧美精品在线观看 | 无码吃奶揉捏奶头高潮视频 | 国产精品va在线播放 | 国产精品人人妻人人爽 | 中文字幕人成乱码熟女app | 亚洲成在人网站无码天堂 | 性欧美大战久久久久久久 | 精品亚洲成av人在线观看 | 性生交大片免费看女人按摩摩 | 中文字幕 亚洲精品 第1页 | 窝窝午夜理论片影院 | 免费人成在线视频无码 | а√天堂www在线天堂小说 | 蜜桃av抽搐高潮一区二区 | 色婷婷香蕉在线一区二区 | 丝袜人妻一区二区三区 | 天天摸天天透天天添 | 国内少妇偷人精品视频 | 国产精品内射视频免费 | 撕开奶罩揉吮奶头视频 | 熟妇人妻无码xxx视频 | 在线亚洲高清揄拍自拍一品区 | 精品无码av一区二区三区 | aⅴ亚洲 日韩 色 图网站 播放 | 国产97人人超碰caoprom | 精品国产一区二区三区四区在线看 | 国产午夜精品一区二区三区嫩草 | 欧洲熟妇精品视频 | 亚洲成av人影院在线观看 | 成年美女黄网站色大免费全看 | 天堂久久天堂av色综合 | 丰满人妻被黑人猛烈进入 | 国产真实夫妇视频 | 性欧美熟妇videofreesex | 成人欧美一区二区三区黑人 | 丰满人妻翻云覆雨呻吟视频 | 精品一区二区三区无码免费视频 | 国产亚洲精品久久久ai换 | 亚洲精品一区二区三区四区五区 | 亚拍精品一区二区三区探花 | 国产成人无码午夜视频在线观看 | 麻豆国产人妻欲求不满谁演的 | 中文精品久久久久人妻不卡 | 男女猛烈xx00免费视频试看 | 久久国产精品二国产精品 | 国产性生大片免费观看性 | 波多野42部无码喷潮在线 | 自拍偷自拍亚洲精品10p | 国产疯狂伦交大片 | a在线亚洲男人的天堂 | 中文字幕av日韩精品一区二区 | 亚洲精品一区二区三区在线 | 性欧美牲交在线视频 | 女人被爽到呻吟gif动态图视看 | 青春草在线视频免费观看 | 香港三级日本三级妇三级 | 俺去俺来也在线www色官网 | 欧美自拍另类欧美综合图片区 | 丰满岳乱妇在线观看中字无码 | 好屌草这里只有精品 | 亚洲精品一区三区三区在线观看 | 樱花草在线播放免费中文 | 欧美阿v高清资源不卡在线播放 | 久激情内射婷内射蜜桃人妖 | 久久精品一区二区三区四区 | 欧美精品无码一区二区三区 | 亚洲国产精品无码一区二区三区 | 中文字幕无线码 | 日本xxxx色视频在线观看免费 | 欧美猛少妇色xxxxx | 精品无码国产自产拍在线观看蜜 | 国产口爆吞精在线视频 | 狠狠色色综合网站 | 欧美xxxx黑人又粗又长 | av无码不卡在线观看免费 | 国产又爽又黄又刺激的视频 | 国产人妻精品一区二区三区不卡 | 97色伦图片97综合影院 | 女人色极品影院 | 国产做国产爱免费视频 | 亚洲人成影院在线无码按摩店 | 中文字幕 亚洲精品 第1页 | 国产一区二区三区日韩精品 | 亚洲精品国产第一综合99久久 | 国产成人人人97超碰超爽8 | 国产另类ts人妖一区二区 | 丰满肥臀大屁股熟妇激情视频 | 亚洲精品国偷拍自产在线观看蜜桃 | 无遮挡国产高潮视频免费观看 | 纯爱无遮挡h肉动漫在线播放 | 一本大道久久东京热无码av | 欧美一区二区三区视频在线观看 | 人人妻人人澡人人爽欧美一区 | 粗大的内捧猛烈进出视频 | 亚洲毛片av日韩av无码 | 88国产精品欧美一区二区三区 | 日日鲁鲁鲁夜夜爽爽狠狠 | 免费国产成人高清在线观看网站 | 98国产精品综合一区二区三区 | 成 人 网 站国产免费观看 | 久久99久久99精品中文字幕 | 无套内谢的新婚少妇国语播放 | 无码一区二区三区在线观看 | 亚洲人亚洲人成电影网站色 | 欧美性生交xxxxx久久久 | √8天堂资源地址中文在线 | 日韩 欧美 动漫 国产 制服 | 久久无码专区国产精品s | 精品人妻av区 | 少妇性l交大片欧洲热妇乱xxx | 亚洲欧洲日本无在线码 | 76少妇精品导航 | 熟妇人妻中文av无码 | 老太婆性杂交欧美肥老太 | 久久亚洲日韩精品一区二区三区 | 男女下面进入的视频免费午夜 | 日本精品人妻无码77777 天堂一区人妻无码 | 亚洲中文字幕在线无码一区二区 | 国产成人无码av片在线观看不卡 | 国产成人无码午夜视频在线观看 | 激情内射亚州一区二区三区爱妻 | 少妇厨房愉情理9仑片视频 | 波多野结衣一区二区三区av免费 | 国产精品久久国产三级国 | 国内精品人妻无码久久久影院 | 成人亚洲精品久久久久 | 又大又紧又粉嫩18p少妇 | 久久精品视频在线看15 | 人人爽人人澡人人人妻 | 亚洲 日韩 欧美 成人 在线观看 | 强伦人妻一区二区三区视频18 | 亚洲国产综合无码一区 | 亚洲日韩av片在线观看 | 久久久久成人片免费观看蜜芽 | 国产高清av在线播放 | www成人国产高清内射 | 青青草原综合久久大伊人精品 | 国产人妻精品午夜福利免费 | 国产两女互慰高潮视频在线观看 | 亚洲无人区午夜福利码高清完整版 | 国产成人一区二区三区在线观看 | 亚洲乱码国产乱码精品精 | 亚洲一区二区观看播放 | 四虎永久在线精品免费网址 | 国产亲子乱弄免费视频 | 18禁黄网站男男禁片免费观看 | 国产免费久久久久久无码 | 波多野结衣av在线观看 | 伦伦影院午夜理论片 | 中文字幕 亚洲精品 第1页 | 久久精品人人做人人综合 | 久久视频在线观看精品 | 人人妻人人藻人人爽欧美一区 | 欧美老人巨大xxxx做受 | 亚洲成a人片在线观看无码 | 亚洲精品www久久久 | 精品午夜福利在线观看 | 麻豆蜜桃av蜜臀av色欲av | 国产精品亚洲综合色区韩国 | 双乳奶水饱满少妇呻吟 | 国产97在线 | 亚洲 | 国产精品va在线播放 | 国产精品99久久精品爆乳 | 性色欲情网站iwww九文堂 | 亚洲爆乳精品无码一区二区三区 | 国精品人妻无码一区二区三区蜜柚 | 丰满少妇弄高潮了www | 国产一区二区三区影院 | 欧美 日韩 亚洲 在线 | 国产成人综合在线女婷五月99播放 | 一本一道久久综合久久 | 亚洲国产av美女网站 | 熟女少妇人妻中文字幕 | 午夜理论片yy44880影院 | 成人欧美一区二区三区黑人免费 | 久久国语露脸国产精品电影 | 九月婷婷人人澡人人添人人爽 | 久久综合给久久狠狠97色 | 18无码粉嫩小泬无套在线观看 | 熟女少妇在线视频播放 | 丰腴饱满的极品熟妇 | 精品国精品国产自在久国产87 | 日韩亚洲欧美精品综合 | 日韩亚洲欧美中文高清在线 | 亚洲日韩av片在线观看 | 久久久久久av无码免费看大片 | 三上悠亚人妻中文字幕在线 | 久久99精品国产麻豆蜜芽 | 最近免费中文字幕中文高清百度 | 久久精品女人天堂av免费观看 | 无码一区二区三区在线 | 东北女人啪啪对白 | 国产精品99久久精品爆乳 | 成人无码精品1区2区3区免费看 | 特大黑人娇小亚洲女 | 99久久精品日本一区二区免费 | 国产人妻人伦精品1国产丝袜 | 精品偷拍一区二区三区在线看 | 午夜精品久久久久久久久 | 亚洲a无码综合a国产av中文 | 四虎国产精品一区二区 | 中文字幕人成乱码熟女app | 97资源共享在线视频 | 奇米影视7777久久精品 | 99久久精品国产一区二区蜜芽 | 亚洲人成人无码网www国产 | 无码人妻精品一区二区三区下载 | 亚洲国产一区二区三区在线观看 | 桃花色综合影院 | 精品无码国产自产拍在线观看蜜 | 网友自拍区视频精品 | 亚洲色大成网站www | 久久精品国产大片免费观看 | 国产精品99久久精品爆乳 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 日日天干夜夜狠狠爱 | 精品 日韩 国产 欧美 视频 | 波多野结衣高清一区二区三区 | 亚洲精品国偷拍自产在线观看蜜桃 | 扒开双腿吃奶呻吟做受视频 | 亚洲精品久久久久久一区二区 | 亚洲精品久久久久久久久久久 | 亚洲精品一区二区三区婷婷月 | 亚洲欧美国产精品专区久久 | 男人扒开女人内裤强吻桶进去 | 高潮毛片无遮挡高清免费视频 | 99久久99久久免费精品蜜桃 | 国产精品无码一区二区桃花视频 | 人妻无码αv中文字幕久久琪琪布 | 亚洲色欲久久久综合网东京热 | 久久精品国产一区二区三区肥胖 | 国产精品嫩草久久久久 | 精品成人av一区二区三区 | 国产三级久久久精品麻豆三级 | 精品人妻人人做人人爽 | 丁香啪啪综合成人亚洲 | 人妻尝试又大又粗久久 | 18精品久久久无码午夜福利 | 欧美三级a做爰在线观看 | 精品国产国产综合精品 | 天堂亚洲免费视频 | a国产一区二区免费入口 | 国产精华av午夜在线观看 | 亚洲热妇无码av在线播放 | 国产成人无码午夜视频在线观看 | 欧美肥老太牲交大战 | 久久99久久99精品中文字幕 | 国产精品美女久久久久av爽李琼 | 激情内射日本一区二区三区 | 亚洲一区av无码专区在线观看 | 对白脏话肉麻粗话av | 国产在线aaa片一区二区99 | √天堂资源地址中文在线 | 麻豆精品国产精华精华液好用吗 |