久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

麻省理工18年春软件构造课程阅读11“抽象函数与表示不变量”

發布時間:2023/12/10 编程问答 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 麻省理工18年春软件构造课程阅读11“抽象函数与表示不变量” 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本文內容來自MIT_6.031_sp18: Software Construction課程的Readings部分,采用CC BY-SA 4.0協議。

由于我們學校(哈工大)大二軟件構造課程的大部分素材取自此,也是推薦的閱讀材料之一,于是打算做一些翻譯工作,自己學習的同時也能幫到一些懶得看英文的朋友。另外,該課程的閱讀資料中有的練習題沒有標準答案,所給出的“正確答案”為譯者所寫,有錯誤的地方還請指出。

(更新:從第10章開始只翻譯正確答案)




譯者:李秋豪

審校:

V1.0 Sun Apr 1 22:23:37 CST 2018


本次課程的目標

今天我們會介紹以下幾個思想:

  • 不變量(invariants)
  • 表示暴露(representation exposure)
  • 抽象函數(abstraction functions)
  • 表示不變量(representation invariants)

在這篇閱讀中,我們會學習用一種正規的數學思想(抽象函數和表示不變量)去理解抽象數據類型ADT的實現。這些思想在軟件設計的實踐中非常重要。其中,抽象函數會讓我們清晰的定義對兩個ADT判斷相等的操作(我們會在后面的課程中深入介紹),而表示不變量會讓我們更易發現破壞數據結構導致的bug。


不變量

回想我們之前討論過的關于ADT的內容,什么設計會產生好的ADT?其中最重要的一點就是它會保護/保留自己的不變量。 不變量是一種屬性,它在程序運行的時候總是一種狀態,而不變性就是其中的一種:一旦一個不變類型的對象被創建,它總是代表一個不變的值。當一個ADT能夠確保它內部的不變量恒定不變(不受使用者/外部影響),我們就說這個ADT保護/保留自己的不變量.

當一個ADT保護/保留自己的不變量時,對代碼的分析會變得更簡單。例如,你能夠依賴字符串不變性的特點,在分析的時候跳過那些關于字符串的代碼;或者當你嘗試基于字符串建立其他的不變量的時候,也會變得更簡單。與此相對,對于可變的對象,你將不得不對每一處使用它的代碼處進行審查。

不變性

在這篇閱讀的后面,我們會看到許多關于不變量的例子,現在我們先看一看不變性:

/*** This immutable data type represents a tweet from Twitter.*/ public class Tweet {public String author;public String text;public Date timestamp;/*** Make a Tweet.* @param author Twitter user who wrote the tweet* @param text text of the tweet* @param timestamp date/time when the tweet was sent*/public Tweet(String author, String text, Date timestamp) {this.author = author;this.text = text;this.timestamp = timestamp;} }

我們應該怎么樣做才能確保Tweet對象是不可變的(一旦被創建,author, message, 和 date都不能被改變)?

第一個威脅就是使用者可以直接訪問Tweet內部的數據,例如:

Tweet t = new Tweet("justinbieber", "Thanks to all those beliebers out there inspiring me every day", new Date()); t.author = "rbmllr";

這就是一個表示暴露(Rep exposure)的例子,就是說類外部的代碼可以直接修改類內部存儲的數據。上面的表示暴露不僅影響到了不變量,也影響到了表示獨立性(譯者注:“抽象數據類型”),如果我們改變類內部數據的表示方法,使用者也會受到影響。

幸運地是,Java給我們提供了處理這樣的表示暴露的方法:

public class Tweet {private final String author;private final String text;private final Date timestamp;public Tweet(String author, String text, Date timestamp) {this.author = author;this.text = text;this.timestamp = timestamp;}/** @return Twitter user who wrote the tweet */public String getAuthor() {return author;}/** @return text of the tweet */public String getText() {return text;}/** @return date/time when the tweet was sent */public Date getTimestamp() {return timestamp;}}

其中, private 表示這個區域只能由同類進行訪問;而final確保了該變量的索引不會被更改,對于不可變的類型來說,就是確保了變量的值不可變。

但是這并沒有解決全部問題,表示還是會暴露!思考下面這個代碼:

/** @return a tweet that retweets t, one hour later*/ public static Tweet retweetLater(Tweet t) {Date d = t.getTimestamp();d.setHours(d.getHours()+1);return new Tweet("rbmllr", t.getText(), d); }

retweetLater 希望接受一個Tweet對象然后修改Date后返回一個新的Tweet對象。

問題出在哪里呢?其中的 getTimestamp 調用返回一個一樣的Date對象,它會被 t.t.timestamp 和 d 同時索引。所以當我們調用 d.setHours()后,t也會受到影響,如下圖所示:

這樣,Tweet的不變性就被破壞了。這里的問題就在于Tweet將自己內部對于可變對象的索引“泄露”了出來,因此整個對象都變成可變的了,使用者在使用時也容易造成隱秘的bug。

我們可以通過防御性復制來彌補這個問題:在返回的時候復制一個新的對象而不會返回原對象的索引。

public Date getTimestamp() {return new Date(timestamp.getTime()); }

可變類型通常都有一個專門用來復制的構造者,你可以通過它產生一個一模一樣的復制對象。在上面的例子中,Date的復制構造者就接受了一個timestamp值,然后產生了一個新的對象。另一個復制可變對象的方法是使用clone() ,但是它沒有被很多類支持(譯者注:標準庫里面只有5%支持),在Java中,使用clone()可能會帶來一些麻煩。你可以在 Josh Bloch, Effective Java, item 11, 或者 Copy Constructor vs. Cloning獲得更多有關這方面的信息。

現在我們已經通過防御性復制解決了 getTimestamp返回值的問題,但是我們還沒有完成任務!思考這個使用者的代碼:

/** @return a list of 24 inspiring tweets, one per hour today */ public static List<Tweet> tweetEveryHourToday () {List<Tweet> list = new ArrayList<Tweet>(); Date date = new Date();for (int i = 0; i < 24; i++) {date.setHours(i);list.add(new Tweet("rbmllr", "keep it up! you can do it", date));} return list; }

這個代碼嘗試創建24個Tweet對象,每一個對象代表一個小時,如下圖所示:

但是,Tweet的不變性再次被打破了,因為每一個Tweet創建時對Date對象的索引都是一樣的。所以我們應該對創建者也進行防御性編程:

public Tweet(String author, String text, Date timestamp) {this.author = author;this.text = text;this.timestamp = new Date(timestamp.getTime()); }

通常來說,你要特別注意ADT操作中的參數和返回值。如果它們之中有可變類型的對象,確保你的代碼沒有直接使用索引或者直接返回索引。

你可能會提出異議。這樣不會很浪費嗎?畢竟你要復制創建這么多新的對象。為什么不直接在規格說明中解決這個問題:

/*** Make a Tweet.* @param author Twitter user who wrote the tweet* @param text text of the tweet* @param timestamp date/time when the tweet was sent. Caller must never * mutate this Date object again!*/ public Tweet(String author, String text, Date timestamp) {

這種方法一般只在迫不得已的時候使用——例如,這個可變對象的數據量非常大,如果進行防御性復制的話會花費很多資源(當然,這取決于你對程序的判斷)。如果不是極端情況,確保ADT會保留/保護自己的不變量總比通過規格說明來限定使用者要好。

而更好的解決方案是使用不可變類型。例如上面的例子中,如果我們使用的是 java.time.ZonedDateTime而非 java.util.Date, 那么我們只需要添加 private和final即可,不用再擔心表示保留。

可變類型的不可變包裝

Java的collections類提供了一種有趣的“折中”:不可變包裝。

Collections.unmodifiableList() 會接收一個(可變)List然后將其包裝為一個不可變對象——它的 set(), add(), remove(),等操作都會拋出異常。所以你可以將一個List包裝為不可變對象(記得將以前對于List的索引丟掉),然后將它傳入其他地方使用。

這種方法的缺點就是你只能在運行時獲得不可變性,而不是編譯時。Java不會在編譯的時候對你對“不可變”列表的修改提出警告。但是這總比什么都不做好,所以使用不可變的列表、映射、和集合也是減少bug的好方法。

閱讀小練習

Rep exposure

思考下面這個有問題的數據類型:

/** Represents an immutable right triangle. */class RightTriangle { /*A*/ private double[] sides;/*B*/ public final int hypotenuse = 2;/** Make a right triangle.* @param legA, legB the two legs of the triangle* @param hypotenuse the hypotenuse of the triangle.*C* * Requires hypotenuse^2 = legA^2 + legB^2 * (within the error tolerance of double arithmetic)*/public RightTriangle(double legA, double legB, double hypotenuse) { /*D*/ this.sides = new double[] { legA, legB }; /*D*/ this.hypotenuse = hypotenuse;}/** Get the two sides of the right triangle.* @return two-element array with the triangle's side lengths*/public double[] getAllSides() { /*E*/ return sides;}/** @param factor to multiply the sides by* @return a triangle made from this triangle by * multiplying all side lengths by factor.*/public RightTriangle scale(double factor) {return new RightTriangle(sides[0]*factor, sides[1]*factor, hypotenuse*factor);}/** @return a regular triangle made from this triangle.* A regular right triangle is one in which* both legs have the same length.*/public RightTriangle regularize() {double bigLeg = Math.max(side[0], side[1]);return new RightTriangle (bigLeg, bigLeg, hypotenuse);}}

以下哪些說法是正確的?

  • [ ] The line marked /*A*/ is a problem for rep exposure because arrays are mutable.
  • [x] /*B*/ 處有問題,因為這種表示方法會讓使用者依賴于類型內部的表示。
  • [ ] The line marked *C* is a problem because creator operations should not have preconditions.
  • [ ] The two lines marked /*D*/ are a problem because they put legA, legB, and hypotenuse into the rep without doing a defensive copy first.
  • [x] /*E*/ 處有問題,因為這影響到了類的不可變性。


表示不變量和抽象函數

我們現在深入理解一下抽象數據類型背后的理論,這些理論不僅本身很有趣,它們在ADT的設計與實現中也很有意義。如果你能夠很好的理解它們,你將會設計出更好的抽象類型,并且遠離那些隱晦的陷阱。

在研究抽象類型的時候,先思考一下兩個值域之間的關系:

表示域(space of representation values)里面包含的是值具體的實現實體。在簡單的情況下,一個抽象類型只需要實現為單個的對象,但是更常見的情況是使用一個很多對象的網絡。

抽象域里面包含的則是類型設計時支持使用的值。這些值是由表示域“抽象/想象”出來的,也是使用者關注的。例如,一個無限整數對象的抽象域是整個整數域,但是它的實現域可能是一個由原始整數類型(有限)組成的數組實現的,而使用者只關注抽象域。

但是,實現者是非?!霸谝狻北硎居?#xff08;和抽象域)的,因為實現者的責任就是實現表示域到抽象域的轉換(映射)。

例如,我們選擇用字符串來表示一個字符集合:

public class CharSet {private String s;... }

如上圖所示,表示域R包含的是我們的實現實體(字符串),而抽象域里面是抽象類型表示的字符集合,我們用箭頭表示這兩個域之間的映射關系。這里要注意幾點:

  • 每一個抽象值都是由表示值映射而來 。我們之前說過實現抽象類型的意義在于支持對于抽象值的操作,即我們需要能夠創建和管理所有的抽象值,因此它們也必須是可表示的。
  • 一些抽象值是被多個表示值映射而來的。這是因為表示方法并不是固定的,我們可以靈活的表示一個抽象值。
  • 不是所有的表示值都能映射到抽象域中。在上面這個例子中,“abbc”就沒有被映射。因為我們已經確定了表示值的字符串中不能含有重復的字符——這樣我們的 remove 方法就能在遇到第一個對應字符的時候停止,因為我們知道沒有重復的字符。

由于我們不可能對每一個映射一一解釋,為了描述這種對應關系和這兩個域,我們再定義兩個概念:

抽象函數abstraction function是表示值到其對應的抽象值的映射:

AF : R → A

快照圖中的箭頭表示的就是抽象函數,可以看出,這種映射是滿射,但不一定是單射(不一定是雙射)。

表示不變量rep invariant是表示值到布爾值的映射:

RI : R → boolean

對于表示值r,當且僅當r被AF映射到了A,RI(r)為真。換句話說,RI告訴了我們哪些表示值是“良好組織”的(能夠去表示A中的抽象值),在下圖中,綠色表示的就是RI(r)為真的部分,AF只在這個子集上有定義。

例如上圖中,CharSet這種類型的實現禁止有重復字符,所以 RI(“a”) = true, RI(“ac”) = true, RI(“acb”) = true, 但是 RI(“aa”) = false, RI(“abbc”) = false.其中為假的集合用紅色區域表示,合法的(為真)的字符串集合用綠色表示。

表示不變量和抽象函數都應該在表示聲明后注釋出來:

public class CharSet {private String s;// Rep invariant:// s contains no repeated characters// Abstraction function:// AF(s) = {s[i] | 0 <= i < s.length()}... }

一個常見的疑惑就是,抽象函數和表示不變量似乎是被表示域和抽象域決定的,甚至似乎抽象域就可以決定它。如果是這樣的話,那么它們的定義似乎沒什么用。

首先證明抽象域并不能獨立決定AF和RI:對于同樣的抽象類型可以有多種表示方法。例如對于一個字符集合,我們既可以用字符串來表示,也可以用比特向量來表示,每一個比特位對應一個可能的字符。顯然我們需要兩個不同的抽象函數來表示這兩種不同的映射。

現在我們再來證明表示域和抽象域也不能決定AF和RI。這里的關鍵點在于,當我們確定表示域(表示值的空間)后,我們并不能決定哪一些表示值是合法的,以及如果它是合法的,它會被怎么解釋/映射。例如在上面的例子中,我們也可以允許表示值有重復的字符,但是我們要求表示值中的字符必須是排好序的,因為這樣我們就可以對其進行二分查找而非線性的遍歷了。對于同一個表示域,我們得到了不同的表示不變量:

public class CharSet {private String s;// Rep invariant:// s[0] <= s[1] <= ... <= s[s.length()-1]// Abstraction function:// AF(s) = {s[i] | 0 <= i < s.length()}... }

最后,即使是同樣的抽象域和表示域以及同樣的表示不變量,我們也可能有不同的解釋方法/抽象函數。還是上面的例子,我們可以對表示值中相鄰的字符做不同的解釋: "acgg" 被解釋為[a-c] 和 [g-g]中的字符,即{a,b,c,g}?,F在的映射如下圖所示:

public class CharSet {private String s;// Rep invariant:// s.length() is even// s[0] <= s[1] <= ... <= s[s.length()-1]// Abstraction function:// AF(s) = union of { c | s[2i] <= c <= s[2i+1] } // for all 0 <= i < s.length()/2... }

總之,一個ADT的實現不僅是選擇表示域(規格說明)和抽象域(具體實現),同時也要決定哪一些表示值是合法的(表示不變量),合法表示會被怎么解釋/映射(抽象函數)。

所以,你必須像我們一樣在代碼中寫出這些設計,以便別的程序員(或者未來的你)明白這些表示到底意味著什么。為什么呢?當程序員不明白表示的含義時會發生什么問題呢?請完成下面的閱讀小練習。

你可以在Github上找到上面例子中CharSet的三種實現的代碼。

閱讀小練習

Exploring a rep

請思考上面 CharSet 的最后一種實現方式:

public class CharSet {private String s;// Rep invariant:// s.length() is even// s[0] <= s[1] <= ... <= s[s.length()-1]// Abstraction function:// AF(s) = union of { c | s[2i] <= c <= s[2i+1] } // for all 0 <= i < s.length()/2... }

下面哪個選項的 s 滿足了表示不變量?

  • [ ] "abc"

  • [x] "abcd"

  • [x] "eeee"

  • [x] "ad"

  • [ ] "adad"

  • [ ] "" (譯者注:s.length()-1)

AF("acfg") 會映射到哪一個集合?

  • [ ] {a,b,c,d,e,f,g}

  • [x] {a,b,c,f,g}

  • [ ] {a,c,f,g}

  • [ ] some other abstract value

  • [ ] no abstract value, because "acfg" does not satisfy the rep invariant

下面哪一個選項會和 "tv"映射到同一個抽象值?

  • [ ] "ttv"

  • [x] "ttuuvv"

  • [x] "ttuv"

  • [ ] "tuv"

Who knows what?

以下哪一些選項是使用者需要了解的?

  • [x] 抽象域

  • [ ] 抽象函數

  • [x] 創建者

  • [x] 觀察者

  • [ ] 表示域

  • [ ] 表示不變量

以下哪一些選項是開發者需要了解的?

  • [x] 抽象域
  • [x] 抽象函數
  • [x] 創建者
  • [x] 觀察者
  • [x] 表示域
  • [x] 表示不變量

Rep invariant pieces

假設 C 這種抽象數據類型的表示用到了兩個字符串:

class C {private String s;private String t;... }

假設你不知道任何關于C抽象的信息,以下哪一些選項可能是C的表示不變量?

  • [x] s 只能包含字母

  • [x] s.length() == t.length()

  • [ ] s represents a set of characters

  • [ ] C’s observers

  • [x] s 是 t反序過來的結果

  • [ ] s+t

Trying to implement without an AF/RI

假設Louis 是這樣表示CharSet的:

public class CharSet {private String s;... }

不幸的是,Louis忘記寫下抽象函數(AF)和表示不變量(RI)了。這里有四中可能的AF/RI對。它們在之前的例子中已經提到過了:

SortedRep:

// AF(s) = {s[i] | 0 <= i < s.length()} // RI: s[0] < s[1] < ... < s[s.length()-1]

SortedRangeRep:

// AF(s) = union of { c | s[2i] <= c <= s[2i+1] } // for all 0 <= i < s.length()/2 // RI: s.length() is even, and s[0] <= s[1] <= ... <= s[s.length()-1]

NoRepeatsRep:

// AF(s) = {s[i] | 0 <= i < s.length()} // RI: s contains no character more than once

AnyRep:

// AF(s) = {s[i] | 0 <= i < s.length()} // RI: true

假設Louis有三個不同的朋友在幫助他分別實現該類型的三個操作: add(), remove(), and contains(),每一個朋友對這種類型的表示都有自己的猜想。

對于下面 add()的實現,哪一種AF/RI是可以對的上的?

/*** Modifies this set by adding c to the set.* @param c character to add*/ public void add(char c) {s = s + c; }
  • [ ] SortedRep

  • [ ] SortedRangeRep

  • [ ] NoRepeatsRep

  • [x] AnyRep

Trying to implement without an AF/RI #2

對于下面 remove()的實現,哪一種AF/RI是可以對的上的?

/*** Modifies this set by removing c, if found.* If c is not found in the set, has no effect.* @param c character to remove*/ public void remove(char c) {int position = s.indexOf(c);if (position >= 0) {s = s.substring(0, position) + s.substring(position+1, s.length());} }
  • [x] SortedRep

  • [ ] SortedRangeRep

  • [x] NoRepeatsRep

  • [ ] AnyRep

Trying to implement without an AF/RI #3

對于下面 contains()的實現,哪一種AF/RI是可以對的上的?

/*** Test for membership.* @param c a character* @return true iff this set contains c*/ public boolean contains(char c) {for (int i = 0; i < s.length(); i += 2) {char low = s.charAt(i);char high = s.charAt(i+1);if (low <= c && c <= high) {return true;}}return false; }
  • [ ] SortedRep

  • [x] SortedRangeRep

  • [ ] NoRepeatsRep

  • [ ] AnyRep

例子:有理數

這里列出了一個表示有理數的例子。仔細觀察表示不變量和抽象函數。我們似乎可以允許更多的表示值是合法的,但是這樣做會讓一些操作的實現變得復雜(假設變了),另一些操作則可能變得簡單。

public class RatNum {private final int numerator;private final int denominator;// Rep invariant:// denominator > 0// numerator/denominator is in reduced form// Abstraction function:// AF(numerator, denominator) = numerator/denominator/** Make a new RatNum == n.* @param n value */public RatNum(int n) {numerator = n;denominator = 1;checkRep();}/** Make a new RatNum == (n / d).* @param n numerator* @param d denominator* @throws ArithmeticException if d == 0 */public RatNum(int n, int d) throws ArithmeticException {// reduce ratio to lowest termsint g = gcd(n, d);n = n / g;d = d / g;// make denominator positiveif (d < 0) {numerator = -n;denominator = -d;} else {numerator = n;denominator = d;}checkRep();} }

閱讀小練習

RatNum

閱讀上面的代碼和快照圖,對于下面的每一種現象/屬性,哪一行代碼“負有最大的責任”(導致)?

RatNum(1,-2) 出現在 R的紅色區域:

  • [ ] private final int numerator;

  • [ ] private final int denominator;

  • [ ] // Rep invariant:

  • [x] // denominator > 0

  • [ ] // numerator/denominator is in reduced form

  • [ ] // Abstraction function:

  • [ ] // AF(numerator, denominator) = numerator/denominator

RatNum(2,4) 出現在 R的紅色區域:

  • [ ] private final int numerator;

  • [ ] private final int denominator;

  • [ ] // Rep invariant:

  • [ ] // denominator > 0

  • [x] // numerator/denominator is in reduced form

  • [ ] // Abstraction function:

  • [ ] // AF(numerator, denominator) = numerator/denominator

RatNum(-1,2)到 -1/2 有一個箭頭:

  • [ ] private final int numerator;

  • [ ] private final int denominator;

  • [ ] // Rep invariant:

  • [ ] // denominator > 0

  • [ ] // numerator/denominator is in reduced form

  • [ ] // Abstraction function:

  • [x] // AF(numerator, denominator) = numerator/denominator

檢查表示不變量

表示不變量不僅是一個簡潔的數學概念,你還可以通過斷言檢查它的不變屬性來動態捕捉bug。例如上面的RatNum,這里就舉出了一種檢查的方法:

// Check that the rep invariant is true // *** Warning: this does nothing unless you turn on assertion checking // by passing -enableassertions to Java private void checkRep() {assert denominator > 0;assert gcd(Math.abs(numerator), denominator) == 1; }

你應該在每一個創建或者改變表示數據的操作后調用 checkRep() 檢查不變量,換句話說,就是在使用創建者、生產者以及改造者之后。在上面的RatNum中,你可以看到我們在兩個創建者的最后都使用了 checkRep() 進行檢查。

雖然說觀察者通常不需要使用 checkRep() 進行檢查,但這也是一個不錯的主意。為什么?因為在每一個操作中調用 checkRep() 檢查不變量更能夠幫助你捕捉因為表示暴露而帶來的bug。

為什么 checkRep() 是私有的?誰應該為為表示不變量負責?使用者還是實現者?

閱讀小練習

Checking the rep invariant

以下哪一個選項的說法是正確的?

  • [ ] checkRep() is the abstraction function

  • [x] checkRep() 斷言檢查了表示不變量

  • [x] 對于實現者來說,在每一個類的公共方法返回前調用 checkRep() 進行檢查是一個好主意

  • [ ] it’s good for a client to call checkRep() just after calling a public method of an ADT class

不要在表示中使用Null

回憶一下我們之前說過的使用null的壞處(譯者注:“規格說明”),我們應該盡可能在編程中避免它。正因為如此,我們之前說如果沒有特殊說明,前置條件和后置條件中都隱式包含不會有null值出現。

現在我們將這種閑置擴展到抽象數據類型的表示中。默認情況下,我們不允許表示中的索引出現null值(包括數組或者列表中的元素)。例如,如果你的表示是:

class CharSet {String s; }

那么表示不變量中默認就會有 s != null ——你不需要專門在表示不變量的注釋中進行說明。

然而,當你在實現檢查表示不變量的 checkRep() 時,你應該顯式的檢查 s != null,確保當 s 是 null 的時候會快速失敗。通常來說,這種檢查會是自動的,因為很多操作在內容是null時會自動拋出異常,例如:

private void checkRep() {assert s.length() % 2 == 0;... }

這個時候你就不需要使用 assert s != null,因為對 s.length() 的調用會在s為null的時候自動失敗報錯。但是如果沒有對null的自動檢查,你就需要顯式的使用 assert s != null了。


友善改動

回憶之前我們對于不可變類型的定義:對象一旦被創建其值不會發生更改?,F在我們學習了抽象數據類型中的表示域和抽象域,我們可以將這個定義更加細化一下:對象一旦被創建,其抽象值不會發生改變。也就是說,對于使用者來說,其代表的值是不會變的,但是實現者可以在底層對表示域做一些改動,這些不會影響到抽象域的改動就稱為友善改動(beneficent mutation).

這里舉出了一個之前提到的RatNum類型,不過我們將表示不變量的限制放寬了,不再要求分子和分母必須是最簡形式:

public class RatNum {private int numerator;private int denominator;// Rep invariant:// denominator != 0// Abstraction function:// AF(numerator, denominator) = numerator/denominator/*** Make a new RatNum == (n / d).* @param n numerator* @param d denominator* @throws ArithmeticException if d == 0*/public RatNum(int n, int d) throws ArithmeticException {if (d == 0) throw new ArithmeticException();numerator = n;denominator = d;checkRep();}... }

這樣的話,再顯示值之前,我們要對其進行簡化:

/*** @return a string representation of this rational number*/@Overridepublic String toString() {int g = gcd(numerator, denominator);numerator /= g;denominator /= g;if (denominator < 0) {numerator = -numerator;denominator = -denominator;}checkRep();return (denominator > 1) ? (numerator + "/" + denominator) : (numerator + "");}

注意到 toString 實現更改了私有區域 numerator 和 denominator, 即它改變了表示域——雖然這還是一個觀察者!但是關鍵點在于,這種改動并沒有改變映射到的抽象值。我們對分子分母進行的約分和同乘-1的操作并沒有改變AF(numerator, denominator) = numerator/denominator的行為。也可以這樣想,AF是一種多對一函數,即一個表示值可以用多種表示值來實現。所以這種改動是無害的,也就是“友善”的。

我們會在后面的課程中看到很多使用友善改動的例子。這種實現上的自由通??梢詭硇阅苌系奶嵘?#xff0c;例如緩沖、數據結構再平衡、延遲清除等策略。


AF, RI以及表示暴露安全性的注解

你應該在抽象類型(私有的)表示聲明后寫上對于抽象函數和表示不變量的注解,這是一個好的實踐要求。我們在上面的例子中也是這么做的。

當你在描述抽象函數和表示不變量的時候,注意要清晰明確:

  • 對于RI(表示不變量),僅僅寬泛的說什么區域是合法的并不夠,你還應該說明是什么使得它合法/不合法。
  • 對于AF(抽象函數)來說,僅僅寬泛的說抽象域表示了什么并不夠。抽象函數的作用是規定合法的表示值會如何被解釋到抽象域。作為一個函數,我們應該清晰的知道從一個輸入到一個輸入是怎么對應的。

本門課程還要求你將表示暴露的安全性注釋出來。這種注釋應該說明表示的每一部分,它們為什么不會發生表示暴露,特別是處理的表示的參數輸入和返回部分(這也是表示暴露發生的位置)。

下面是一個Tweet類的例子,它將表示不變量和抽象函數以及表示暴露的安全性注釋了出來:

// Immutable type representing a tweet. public class Tweet {private final String author;private final String text;private final Date timestamp;// Rep invariant:// author is a Twitter username (a nonempty string of letters, digits, underscores)// text.length <= 140// Abstraction function:// AF(author, text, timestamp) = a tweet posted by author, with content text, // at time timestamp // Safety from rep exposure:// All fields are private;// author and text are Strings, so are guaranteed immutable;// timestamp is a mutable Date, so Tweet() constructor and getTimestamp() // make defensive copies to avoid sharing the rep's Date object with clients.// Operations (specs and method bodies omitted to save space)public Tweet(String author, String text, Date timestamp) { ... }public String getAuthor() { ... }public String getText() { ... }public Date getTimestamp() { ... } }

注意到我們并沒有對 timestamp 的表示不變量進行要求(除了之前說過的默認 timestamp!=null)。但是我們依然需要對timestamp 的表示暴露的安全性進行說明,因為整個類型的不變性依賴于所有的成員變量的不變性。

下面是關于 RatNum的另一個例子:

// Immutable type representing a rational number. public class RatNum {private final int numerator;private final int denominator;// Rep invariant:// denominator > 0// numerator/denominator is in reduced form, i.e. gcd(|numerator|,denominator) = 1// Abstraction function:// AF(numerator, denominator) = numerator/denominator// Safety from rep exposure:// All fields are private, and all types in the rep are immutable.// Operations (specs and method bodies omitted to save space)public RatNum(int n) { ... }public RatNum(int n, int d) throws ArithmeticException { ... }... }

可以看到,對于不可變類型的表示,表示暴露的安全性說明會簡單很多。

你可以在GitHub獲取RatNum的所有代碼

閱讀小練習

Arguing against rep exposure

思考這個抽象數據類型:

// Mutable type representing Twitter users' followers. public class FollowGraph {private final Map<String,Set<String>> followersOf;// Rep invariant:// all Strings in followersOf are Twitter usernames// (i.e., nonempty strings of letters, digits, underscores)// no user follows themselves, i.e. x is not in followersOf.get(x)// Abstraction function:// AF(followersOf) = the follower graph where Twitter user x is followed by user y// if and only if followersOf.get(x).contains(y)// Safety from rep exposure:// All fields are private, and ..???..// Operations (specs and method bodies omitted to save space)public FollowGraph() { ... }public void addFollower(String user, String follower) { ... }public void removeFollower(String user, String follower) { ... }public Set<String> getFollowers(String user) { ... } }

對于上面代碼中的注解,下面哪一個選項可以正確的替代 ..???.. ,從而使得表示暴露的安全性得到說明?

1. “Strings are immutable.”

No

2. “followersOf 是一個可變的 Map, 其包含著可變的 Set 對象,但是 getFollowers() 在返回時會對 Set 進行防御性復制,并且其他的參數和返回值都是不可變類型的 String 或者 void .”

Yes

3. “This class is mutable, so rep exposure isn’t an issue.”

No

4. “followersOf is a mutable Map, but it is never passed or returned from an operation.”

No

5. “FollowGraph() does not expose the rep; addFollower() does not expose the rep; removeFollower() does not expose the rep; getFollowers() does not expose the rep.”

No

6. “String 是不可變的, 并且表示中的 Set 對象都使用了不可變包裝。雖然Map類型是可變的,但是沒有操作傳入或者返回這種類型的對象?!?/p>

Yes

一個ADT的規格說明應該寫什么?

由于我們已經講了如何對表示不變量和抽象函數做注解,現在我們就來更新一下我們對于規格說明的理解,即一個ADT的規格說明應該寫什么?

如上圖所示,規格說明在使用者和實現者之間構建起了一道“防火墻”。抽象類型的規格說明(包含操作的說明)應該只關注使用者可見的部分,這包括參數、返回值、可能拋出的異常。例如規格說明需要引用T的值時,它應該是抽象域的值而非表示域。

規格說明不應該談論具體的表示/實現細節,例如表示域里面的值。它應該認為表示本身(私有區域)對于使用者是不可見的,就像是方法里面的局部變量對外部不可見。這也是為什么我們在注解表示不變量和抽象函數的時候使用的是"\\"注釋而非典型的Javadoc格式。如果我們使用Javadoc注釋的話,內部的實現細節會出現在規格說明中,而這會影響表示獨立性以及信息隱藏。


用ADT不變量替換前置條件

良好設計的ADT的一個大優點在于我們可以使用它將本該寫在前置條件中的限制封裝起來。例如,現在有一個規格說明是這樣:

/** * @param set1 is a sorted set of characters with no repeats* @param set2 is likewise* @return characters that appear in one set but not the other,* in sorted order with no repeats */ static String exclusiveOr(String set1, String set2);

我們可以利用ADT(SortedSet)的不變量屬性要求這種前置條件:

/** @return characters that appear in one set but not the other */ static SortedSet<Character> exclusiveOr(SortedSet<Character> set1, SortedSet<Character> set2);

這滿足了我們所有的要求:

  • 遠離bug:因為要求的條件(排序、無重復)都已經是ADT的不變量了,所以Java可以對其進行靜態檢查,在編譯期阻止所有不滿足的操作。
  • 易于理解:因為這樣寫更簡單,并且ADT SortedSet 的名字就已經表明了它該有的屬性。
  • 可改動:因為我們可以改變 SortedSet 的內部實現而不影響 exclusiveOr 或其他的使用者代碼。

我們以前很多用前置條件的地方現在都可以用定制的ADT來替換。

閱讀小練習

Encapsulating preconditions in ADTs

思考下面這個方法:

/*** Find tweets written by a particular user.* * @param tweets a list of tweets with distinct timestamps, not modified by this method.* @param username Twitter username (a nonempty sequence of letters, digits, and underscore)* @return all and only the tweets in the list whose author is username,* in the same order as in the input list.*/ public static List<Tweet> writtenBy(List<Tweet> tweets, String username) { ... }

你會創建一個什么ADT來避開這種繁雜的前置要求?

  • [ ] TweetsAndUsername

  • [x] TweetList

  • [x] Username

  • [ ] UsernameCharacter

如何建立不變量

不變量是一種在程序中一直為真的屬性,對于對象而言,就是從對象創建開始一直具有的屬性。

為了保持一個不變量,我們需要:

  • 確保在對象創建的時候不變量成立
  • 確保對對象在接下來的每一個改變后不變量依然成立
  • 譯者注:這就是狀態機中的不變性 狀態機:如何構建穩定的婚姻

翻譯成對于ADT的操作,就是:

  • 創建者和生產者必須對新的對象就建立不變量
  • 改造者和觀察者必須保持/保護這種不變量

表示暴露會使得情況更加復雜,如果一個表示被暴露出來,那么程序的任何地方都可能對其進行修改,我們也就沒法確保不變量一直成立了。所以使用不變量完整的規則應該是:

結構歸納法. 如果一個抽象數據類型的不變量滿足:

  • 被創建者或生產者創建;
  • 被改造者和觀察者保持;
  • 沒有表示暴露。
  • 那么這種類型的所有實例的不變量都是成立的。

    閱讀小練習

    Structural induction

    Recall this data type from the first exercise in this reading:回憶在第一個練習中的數據類型:

    /** Represents an immutable right triangle. */ class RightTriangle {private double[] sides;// RI: ???// AF: ???// sides[0] and sides[1] are the two legs,// and sides[2] is the hypotenuse, so declare it to avoid having a// magic number in the code:public static final int HYPOTENUSE = 2;/** Make a right triangle.* @param legA, legB the two legs of the triangle* @param hypotenuse the hypotenuse of the triangle.* Requires hypotenuse^2 = legA^2 + legB^2 * (within the error tolerance of double arithmetic)*/public RightTriangle(double legA, double legB, double hypotenuse) {this.sides = new double[] { legA, legB, hypotenuse };}/** Get all the sides of the triangle.* @return three-element array with the triangle's side lengths*/public double[] getAllSides() {return sides;}/** @return length of the triangle's hypotenuse */ public double getHypotenuse() {return sides[HYPOTENUSE];}/** @param factor to multiply the sides by* @return a triangle made from this triangle by * multiplying all side lengths by factor.*/public RightTriangle scale(double factor) {return new RightTriangle (sides[0]*factor, sides[1]*factor, sides[2]*factor);}/** @return a regular triangle made from this triangle.* A regular right triangle is one in which* both legs have the same length.*/public RightTriangle regularize() {double bigLeg = Math.max(sides[0], sides[1]);return new RightTriangle (bigLeg, bigLeg, sides[2]);}}

    這個數據類型中有一個重要的不變量,那就是直角邊和斜邊之間的勾股關系。

    假設使用者遵守了規格說明,以下哪一個說法是正確的?

    • [x] 創建者 RightTriangle() 建立的不變量

    • [ ] The observer getAllSides() preserves the invariant
    • [x] 觀察者 getHypotenuse() 保持了不變量
    • [x] 生產者 scale() 保持了不變量
    • [ ] The producer regularize() preserves the invariant


    總結

    • 不變量是指對于一個對象,它有一種能夠在整個生命周期保證為真的屬性。
    • 一個好的ADT會確保它的不變量為真。不變量是由創建者和生產者創建,被觀察者和改造者保持。
    • 表示不變量明確了什么是合法的表示值,并且這些表示應該在運行時調用checkRep()檢查。
    • 抽象函數將具體的表示映射到抽象值上。
    • 表示暴露會威脅到表示獨立性和表示不變量。

    下面將這篇閱讀的知識點與我們的三個目標聯系起來:

    • 遠離bug. 一個好的ADT會確保它的不變量為真,因此它們不會被使用者代碼中的bug所影響。同時,通過顯式的聲明和動態檢查不變量,我們可以盡早的發現bug,而不是讓錯誤的行為繼續下去。
    • 易于理解. 表示不變量和抽象函數詳細的表述了抽象類型中表示的意義,以及它們是如何聯系到抽象值的。
    • 可改動. 抽象數據類型分離了抽象域和表示域,這使得實現者可以改動具體實現而不影響使用者的代碼。

    轉載于:https://www.cnblogs.com/liqiuhao/p/8688759.html

    總結

    以上是生活随笔為你收集整理的麻省理工18年春软件构造课程阅读11“抽象函数与表示不变量”的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    国内精品九九久久久精品 | 又紧又大又爽精品一区二区 | 久久精品中文字幕一区 | 国产精品无码永久免费888 | 精品国产一区二区三区av 性色 | 亚洲男人av香蕉爽爽爽爽 | 一本久道高清无码视频 | 美女极度色诱视频国产 | 国产精品a成v人在线播放 | 少女韩国电视剧在线观看完整 | 女高中生第一次破苞av | 精品 日韩 国产 欧美 视频 | 国产亚洲欧美日韩亚洲中文色 | 国产日产欧产精品精品app | 国产精品无码mv在线观看 | 欧美老妇与禽交 | 色妞www精品免费视频 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 国产av无码专区亚洲awww | 日韩人妻少妇一区二区三区 | 丁香花在线影院观看在线播放 | 成人欧美一区二区三区黑人 | 综合激情五月综合激情五月激情1 | 欧美xxxxx精品 | 亚洲自偷精品视频自拍 | 久久亚洲中文字幕无码 | 青青久在线视频免费观看 | 在线看片无码永久免费视频 | 精品偷自拍另类在线观看 | 午夜精品一区二区三区的区别 | 国产成人无码av在线影院 | 丰满妇女强制高潮18xxxx | 色窝窝无码一区二区三区色欲 | 成熟女人特级毛片www免费 | 日韩精品无码一本二本三本色 | 九九久久精品国产免费看小说 | 人人爽人人爽人人片av亚洲 | 午夜精品一区二区三区在线观看 | 国产超级va在线观看视频 | 人妻无码久久精品人妻 | 国产性生大片免费观看性 | 久久国产自偷自偷免费一区调 | 老熟女重囗味hdxx69 | 少妇久久久久久人妻无码 | 国产精品内射视频免费 | 国产人成高清在线视频99最全资源 | 99久久精品国产一区二区蜜芽 | 强奷人妻日本中文字幕 | 一个人看的视频www在线 | 麻花豆传媒剧国产免费mv在线 | 国产麻豆精品一区二区三区v视界 | 牲欲强的熟妇农村老妇女视频 | 天堂在线观看www | 少妇无套内谢久久久久 | 亚洲中文字幕无码中字 | 国产色视频一区二区三区 | 老熟妇乱子伦牲交视频 | 亲嘴扒胸摸屁股激烈网站 | 国产精品亚洲一区二区三区喷水 | 老子影院午夜精品无码 | 国产一区二区三区精品视频 | 日韩人妻系列无码专区 | 清纯唯美经典一区二区 | 国产亚洲精品久久久久久 | 欧美日本免费一区二区三区 | 色老头在线一区二区三区 | 男人扒开女人内裤强吻桶进去 | 丰满少妇弄高潮了www | 欧美乱妇无乱码大黄a片 | 在线天堂新版最新版在线8 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 一二三四社区在线中文视频 | 欧美日韩人成综合在线播放 | 熟女俱乐部五十路六十路av | 成年女人永久免费看片 | 欧美日韩一区二区综合 | 亚洲欧美日韩综合久久久 | 久久久精品国产sm最大网站 | 亚洲精品www久久久 | 精品无码av一区二区三区 | 夜夜夜高潮夜夜爽夜夜爰爰 | 久久国产36精品色熟妇 | 欧美野外疯狂做受xxxx高潮 | 亚洲啪av永久无码精品放毛片 | 亚洲成在人网站无码天堂 | 日韩视频 中文字幕 视频一区 | 亚洲精品综合五月久久小说 | 性欧美videos高清精品 | 内射后入在线观看一区 | 精品 日韩 国产 欧美 视频 | 亚洲成a人片在线观看无码 | 永久黄网站色视频免费直播 | 99精品国产综合久久久久五月天 | 国产精品久久国产精品99 | 亚洲の无码国产の无码步美 | 中文字幕乱妇无码av在线 | 欧美日韩人成综合在线播放 | 青青久在线视频免费观看 | 日本精品人妻无码免费大全 | 日韩亚洲欧美中文高清在线 | 麻豆国产97在线 | 欧洲 | 国产亚洲精品久久久久久 | 日本乱偷人妻中文字幕 | 国产精品人人爽人人做我的可爱 | 国产婷婷色一区二区三区在线 | 妺妺窝人体色www在线小说 | 无码人妻av免费一区二区三区 | 日韩精品久久久肉伦网站 | 国产小呦泬泬99精品 | 久久久国产一区二区三区 | 精品无码国产一区二区三区av | 无套内射视频囯产 | 国产农村乱对白刺激视频 | 最近中文2019字幕第二页 | 国产精品内射视频免费 | 人人爽人人爽人人片av亚洲 | 无码任你躁久久久久久久 | 久久久久久久久蜜桃 | 亚洲精品国产精品乱码不卡 | 国产成人综合色在线观看网站 | 少妇的肉体aa片免费 | 亚洲欧美日韩国产精品一区二区 | 日韩少妇白浆无码系列 | 国产午夜无码视频在线观看 | 日本乱偷人妻中文字幕 | 中文精品久久久久人妻不卡 | 中文字幕人成乱码熟女app | 一本色道婷婷久久欧美 | 久久精品成人欧美大片 | 久久综合九色综合97网 | 国产精品久久久久久无码 | 免费观看激色视频网站 | 人妻中文无码久热丝袜 | 精品aⅴ一区二区三区 | 国产欧美熟妇另类久久久 | 国产情侣作爱视频免费观看 | 国产精品18久久久久久麻辣 | 久久久久久久久888 | 真人与拘做受免费视频一 | www国产精品内射老师 | 成人亚洲精品久久久久软件 | 97久久精品无码一区二区 | 精品亚洲成av人在线观看 | 少妇邻居内射在线 | 欧美黑人巨大xxxxx | 奇米影视7777久久精品 | 无码帝国www无码专区色综合 | 精品无人区无码乱码毛片国产 | 人妻互换免费中文字幕 | 无码人妻黑人中文字幕 | 成人av无码一区二区三区 | 国产人妻人伦精品 | 少妇愉情理伦片bd | 特大黑人娇小亚洲女 | 日韩人妻无码一区二区三区久久99 | 久久综合给合久久狠狠狠97色 | 亚欧洲精品在线视频免费观看 | 精品乱子伦一区二区三区 | 欧美黑人巨大xxxxx | 激情亚洲一区国产精品 | 午夜精品久久久久久久 | 国产午夜手机精彩视频 | 成在人线av无码免观看麻豆 | 国产真实乱对白精彩久久 | 人人妻人人澡人人爽欧美精品 | 亚洲阿v天堂在线 | 国语自产偷拍精品视频偷 | 精品人妻人人做人人爽 | 午夜男女很黄的视频 | 亚洲中文字幕无码一久久区 | 网友自拍区视频精品 | 精品成在人线av无码免费看 | 麻豆国产人妻欲求不满 | 久久伊人色av天堂九九小黄鸭 | 夜夜夜高潮夜夜爽夜夜爰爰 | 午夜时刻免费入口 | 精品一二三区久久aaa片 | 日欧一片内射va在线影院 | 成人欧美一区二区三区黑人免费 | 成人免费视频在线观看 | 亚洲精品一区三区三区在线观看 | 亚洲综合久久一区二区 | 亚洲aⅴ无码成人网站国产app | 国产 浪潮av性色四虎 | aⅴ亚洲 日韩 色 图网站 播放 | 啦啦啦www在线观看免费视频 | 国产成人综合在线女婷五月99播放 | 日本精品人妻无码77777 天堂一区人妻无码 | 久久亚洲精品成人无码 | 人妻夜夜爽天天爽三区 | 亚洲欧美国产精品专区久久 | 无码人妻黑人中文字幕 | 又大又黄又粗又爽的免费视频 | 亚洲人成影院在线观看 | 永久免费观看美女裸体的网站 | 日本爽爽爽爽爽爽在线观看免 | 18禁黄网站男男禁片免费观看 | 东京热一精品无码av | 在线а√天堂中文官网 | 欧美熟妇另类久久久久久多毛 | 最近免费中文字幕中文高清百度 | 精品久久久久久人妻无码中文字幕 | 伊人久久婷婷五月综合97色 | 国产绳艺sm调教室论坛 | 老熟女重囗味hdxx69 | 日韩av无码中文无码电影 | 国内精品人妻无码久久久影院 | 一本久久a久久精品vr综合 | 日日碰狠狠丁香久燥 | 激情五月综合色婷婷一区二区 | 久久午夜无码鲁丝片午夜精品 | 中国女人内谢69xxxxxa片 | 99视频精品全部免费免费观看 | 亚洲精品午夜国产va久久成人 | 牲欲强的熟妇农村老妇女 | 中文字幕无码免费久久9一区9 | 国内老熟妇对白xxxxhd | 美女黄网站人色视频免费国产 | 国产av一区二区三区最新精品 | 无码人妻少妇伦在线电影 | 2020最新国产自产精品 | 亚洲天堂2017无码中文 | 日本精品人妻无码免费大全 | 欧美大屁股xxxxhd黑色 | 亚洲熟女一区二区三区 | 性色av无码免费一区二区三区 | 少妇无码av无码专区在线观看 | 2020最新国产自产精品 | 亚洲中文字幕在线观看 | 亚洲男人av香蕉爽爽爽爽 | 久久久久国色av免费观看性色 | 性色av无码免费一区二区三区 | 国产情侣作爱视频免费观看 | 人妻中文无码久热丝袜 | 久久久中文字幕日本无吗 | 18禁止看的免费污网站 | 老子影院午夜精品无码 | 色一情一乱一伦一视频免费看 | 国产极品视觉盛宴 | 老司机亚洲精品影院无码 | 精品国精品国产自在久国产87 | 亚洲成熟女人毛毛耸耸多 | 亚洲精品国产精品乱码视色 | 成人精品一区二区三区中文字幕 | 无码人妻久久一区二区三区不卡 | 国产精品福利视频导航 | 国产av一区二区精品久久凹凸 | 日本精品人妻无码免费大全 | 又黄又爽又色的视频 | 中文字幕乱妇无码av在线 | 一区二区三区乱码在线 | 欧洲 | 国产sm调教视频在线观看 | 2019nv天堂香蕉在线观看 | 国产成人一区二区三区别 | 对白脏话肉麻粗话av | 亚洲日本一区二区三区在线 | 亚洲综合久久一区二区 | 欧美日韩在线亚洲综合国产人 | 亚欧洲精品在线视频免费观看 | 欧美性猛交内射兽交老熟妇 | 真人与拘做受免费视频一 | 无码人妻丰满熟妇区五十路百度 | 极品嫩模高潮叫床 | 国产精品久久久久久无码 | 亚洲中文字幕在线观看 | 狂野欧美性猛xxxx乱大交 | 成人亚洲精品久久久久软件 | 18黄暴禁片在线观看 | 国产成人精品久久亚洲高清不卡 | 亚洲国产成人av在线观看 | 久久久久国色av免费观看性色 | 伦伦影院午夜理论片 | 国产精品18久久久久久麻辣 | 中文字幕日产无线码一区 | 免费看男女做好爽好硬视频 | 在教室伦流澡到高潮hnp视频 | 日韩欧美中文字幕在线三区 | 久久99精品国产.久久久久 | √天堂中文官网8在线 | 亚洲综合伊人久久大杳蕉 | 亚洲 a v无 码免 费 成 人 a v | 熟妇人妻中文av无码 | 性生交大片免费看女人按摩摩 | 性欧美熟妇videofreesex | 妺妺窝人体色www在线小说 | 又大又硬又爽免费视频 | 我要看www免费看插插视频 | 国产亚洲精品久久久久久久久动漫 | 天天躁夜夜躁狠狠是什么心态 | 中文精品无码中文字幕无码专区 | 精品成人av一区二区三区 | 成人精品天堂一区二区三区 | 网友自拍区视频精品 | 亚洲精品国产品国语在线观看 | 久久99久久99精品中文字幕 | 亚洲s码欧洲m码国产av | 亚洲中文字幕乱码av波多ji | 精品日本一区二区三区在线观看 | 国产精品人人妻人人爽 | 日韩无套无码精品 | 久久aⅴ免费观看 | 久久国产劲爆∧v内射 | 久久久婷婷五月亚洲97号色 | 久久久久免费精品国产 | 色情久久久av熟女人妻网站 | 未满成年国产在线观看 | 亚洲国产精品久久久天堂 | 欧美精品一区二区精品久久 | 国产亚洲美女精品久久久2020 | 红桃av一区二区三区在线无码av | 国产乱子伦视频在线播放 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 99久久亚洲精品无码毛片 | 51国偷自产一区二区三区 | 国产午夜亚洲精品不卡 | 亚洲精品综合一区二区三区在线 | 2020久久香蕉国产线看观看 | 丰满护士巨好爽好大乳 | 国产精品久久久久久久影院 | 亚洲精品一区国产 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 98国产精品综合一区二区三区 | 国产精品爱久久久久久久 | 亲嘴扒胸摸屁股激烈网站 | 成人三级无码视频在线观看 | 国产精品亚洲一区二区三区喷水 | 亚洲色大成网站www国产 | 夫妻免费无码v看片 | 日本一本二本三区免费 | 亚洲欧美国产精品专区久久 | 亚洲一区二区三区无码久久 | 久9re热视频这里只有精品 | 日本精品高清一区二区 | 国产成人无码a区在线观看视频app | 亚洲精品一区二区三区大桥未久 | 少妇高潮喷潮久久久影院 | 精品国产一区二区三区av 性色 | 国产激情精品一区二区三区 | 熟女体下毛毛黑森林 | 少妇一晚三次一区二区三区 | 99riav国产精品视频 | 日本又色又爽又黄的a片18禁 | 牲交欧美兽交欧美 | 久久久精品成人免费观看 | 奇米影视7777久久精品人人爽 | 麻豆果冻传媒2021精品传媒一区下载 | 亚洲精品午夜无码电影网 | 日本爽爽爽爽爽爽在线观看免 | 中文字幕人成乱码熟女app | 国产精品无码永久免费888 | 久久zyz资源站无码中文动漫 | 亚洲国产成人av在线观看 | 日本va欧美va欧美va精品 | 人妻人人添人妻人人爱 | 1000部啪啪未满十八勿入下载 | 国产综合色产在线精品 | 最新国产麻豆aⅴ精品无码 | 小sao货水好多真紧h无码视频 | 国产一区二区三区精品视频 | 麻豆国产97在线 | 欧洲 | 给我免费的视频在线观看 | 国产亚洲精品精品国产亚洲综合 | a国产一区二区免费入口 | 欧美刺激性大交 | 国产人妻大战黑人第1集 | 人人妻人人藻人人爽欧美一区 | 色婷婷综合中文久久一本 | 久久综合给合久久狠狠狠97色 | 国产精品久久久久影院嫩草 | 国产电影无码午夜在线播放 | 人人爽人人爽人人片av亚洲 | 激情爆乳一区二区三区 | 国内老熟妇对白xxxxhd | 久久成人a毛片免费观看网站 | 精品日本一区二区三区在线观看 | 99久久亚洲精品无码毛片 | 国产亚洲欧美在线专区 | 国产成人精品久久亚洲高清不卡 | 丰满人妻翻云覆雨呻吟视频 | www一区二区www免费 | 国产成人无码专区 | 国产精品福利视频导航 | 亚洲综合另类小说色区 | 亚洲精品国产精品乱码视色 | 国产人妻人伦精品1国产丝袜 | 乌克兰少妇性做爰 | 久久国产精品精品国产色婷婷 | 国产xxx69麻豆国语对白 | 成人无码精品1区2区3区免费看 | 无码人妻丰满熟妇区毛片18 | 国产成人无码专区 | 狠狠色噜噜狠狠狠狠7777米奇 | 风流少妇按摩来高潮 | 麻豆果冻传媒2021精品传媒一区下载 | 三上悠亚人妻中文字幕在线 | 少妇厨房愉情理9仑片视频 | 99久久精品午夜一区二区 | 久久精品成人欧美大片 | 国产无遮挡又黄又爽免费视频 | 亚洲精品久久久久久一区二区 | 狂野欧美性猛交免费视频 | 亚洲一区二区三区 | 色爱情人网站 | 国产亚洲欧美日韩亚洲中文色 | 青青草原综合久久大伊人精品 | 日日摸夜夜摸狠狠摸婷婷 | 免费播放一区二区三区 | 精品国产麻豆免费人成网站 | 99久久精品无码一区二区毛片 | 国产精品亚洲综合色区韩国 | 日本xxxx色视频在线观看免费 | 国产激情一区二区三区 | 最近免费中文字幕中文高清百度 | 在线成人www免费观看视频 | 久久久久久久人妻无码中文字幕爆 | 国产日产欧产精品精品app | 亚洲精品一区三区三区在线观看 | a在线亚洲男人的天堂 | 亚洲精品久久久久久一区二区 | 国产乱子伦视频在线播放 | 久久人妻内射无码一区三区 | 国产一区二区三区四区五区加勒比 | 水蜜桃av无码 | 亚洲人成影院在线无码按摩店 | 亚洲热妇无码av在线播放 | 免费人成网站视频在线观看 | 日本一卡2卡3卡四卡精品网站 | 成人性做爰aaa片免费看 | 伊人久久大香线蕉午夜 | 亚洲色大成网站www国产 | 18无码粉嫩小泬无套在线观看 | 狠狠亚洲超碰狼人久久 | aⅴ在线视频男人的天堂 | 亚洲国产欧美国产综合一区 | 国产一区二区不卡老阿姨 | av人摸人人人澡人人超碰下载 | 狠狠色丁香久久婷婷综合五月 | 色诱久久久久综合网ywww | 2020久久超碰国产精品最新 | 亚洲狠狠色丁香婷婷综合 | 十八禁视频网站在线观看 | 精品无码国产一区二区三区av | 亚洲综合色区中文字幕 | 天堂а√在线地址中文在线 | 国产成人无码av一区二区 | 亚洲中文无码av永久不收费 | 色综合久久久无码中文字幕 | 亚洲精品欧美二区三区中文字幕 | 亚洲乱码中文字幕在线 | 亚洲日韩一区二区三区 | 99久久亚洲精品无码毛片 | 亚洲日韩av一区二区三区中文 | 99久久精品无码一区二区毛片 | 国产极品美女高潮无套在线观看 | 亚洲 高清 成人 动漫 | 色综合久久久久综合一本到桃花网 | 人人澡人摸人人添 | 国产熟女一区二区三区四区五区 | 超碰97人人做人人爱少妇 | 亚洲第一网站男人都懂 | 无码任你躁久久久久久久 | 久久久av男人的天堂 | 久久国产36精品色熟妇 | 国产高清av在线播放 | 日日躁夜夜躁狠狠躁 | 国产手机在线αⅴ片无码观看 | 性做久久久久久久免费看 | 影音先锋中文字幕无码 | 欧美日韩精品 | 日本va欧美va欧美va精品 | 免费乱码人妻系列无码专区 | 天天综合网天天综合色 | 老头边吃奶边弄进去呻吟 | 日本va欧美va欧美va精品 | 日韩人妻系列无码专区 | 欧美丰满熟妇xxxx | 粗大的内捧猛烈进出视频 | 中文字幕乱码人妻二区三区 | 欧美性色19p | 国产精品理论片在线观看 | 亚洲一区二区三区偷拍女厕 | 亚洲国产精华液网站w | 伦伦影院午夜理论片 | 超碰97人人做人人爱少妇 | 女人被男人爽到呻吟的视频 | 一本久道久久综合狠狠爱 | 麻豆av传媒蜜桃天美传媒 | 2020久久超碰国产精品最新 | av无码久久久久不卡免费网站 | 国产成人综合在线女婷五月99播放 | 极品尤物被啪到呻吟喷水 | 久久亚洲精品中文字幕无男同 | √天堂资源地址中文在线 | 亚洲熟妇色xxxxx欧美老妇 | 久久久精品国产sm最大网站 | 欧美人与物videos另类 | 六月丁香婷婷色狠狠久久 | 国产特级毛片aaaaaaa高清 | 国产无遮挡又黄又爽又色 | 中文字幕乱码亚洲无线三区 | 久久综合久久自在自线精品自 | 国产内射老熟女aaaa | 国内少妇偷人精品视频 | 国产精品永久免费视频 | 女人和拘做爰正片视频 | 亚洲人成网站免费播放 | 人妻中文无码久热丝袜 | 精品偷自拍另类在线观看 | 色噜噜亚洲男人的天堂 | 国产一区二区三区影院 | 久久久久久亚洲精品a片成人 | 午夜性刺激在线视频免费 | 中文字幕+乱码+中文字幕一区 | 日本熟妇人妻xxxxx人hd | 97色伦图片97综合影院 | 久久久av男人的天堂 | 伊人久久大香线蕉av一区二区 | 黑森林福利视频导航 | 久久婷婷五月综合色国产香蕉 | 亚洲中文字幕在线无码一区二区 | 亚洲天堂2017无码 | 亚洲s码欧洲m码国产av | 377p欧洲日本亚洲大胆 | 国产九九九九九九九a片 | 亚洲欧美精品伊人久久 | 日日碰狠狠躁久久躁蜜桃 | 波多野结衣av一区二区全免费观看 | 色婷婷综合激情综在线播放 | 国产精品手机免费 | 高清国产亚洲精品自在久久 | 亚洲熟女一区二区三区 | 久久亚洲中文字幕精品一区 | 国产绳艺sm调教室论坛 | 国语精品一区二区三区 | 香港三级日本三级妇三级 | 久久国产精品偷任你爽任你 | 日日摸夜夜摸狠狠摸婷婷 | 高清国产亚洲精品自在久久 | 夜夜夜高潮夜夜爽夜夜爰爰 | 丰满少妇熟乱xxxxx视频 | 欧美老妇交乱视频在线观看 | 亚洲色欲色欲天天天www | 国产精品久久久久无码av色戒 | 夜精品a片一区二区三区无码白浆 | 夜夜高潮次次欢爽av女 | 国产莉萝无码av在线播放 | 久久无码专区国产精品s | 极品尤物被啪到呻吟喷水 | 国产人成高清在线视频99最全资源 | 精品久久综合1区2区3区激情 | 一本久道久久综合狠狠爱 | 久青草影院在线观看国产 | 国产凸凹视频一区二区 | 成年女人永久免费看片 | 国产农村妇女高潮大叫 | 亚洲一区av无码专区在线观看 | 国产尤物精品视频 | 国产午夜亚洲精品不卡下载 | 九一九色国产 | 国产亚洲精品久久久久久久 | 亚洲性无码av中文字幕 | 5858s亚洲色大成网站www | 亚洲大尺度无码无码专区 | 国产特级毛片aaaaaaa高清 | 国产精品a成v人在线播放 | 国产精品二区一区二区aⅴ污介绍 | 亚洲人成网站免费播放 | 国精产品一区二区三区 | 欧美日韩一区二区三区自拍 | 国产高清不卡无码视频 | 人妻少妇精品久久 | 丁香花在线影院观看在线播放 | 亚洲综合色区中文字幕 | 国产人妻精品午夜福利免费 | 欧美xxxx黑人又粗又长 | 亚洲精品www久久久 | 亚洲午夜福利在线观看 | 久久久无码中文字幕久... | 亚洲成色www久久网站 | 国产成人精品视频ⅴa片软件竹菊 | 久久无码专区国产精品s | 色综合天天综合狠狠爱 | 久久成人a毛片免费观看网站 | 国产精品人妻一区二区三区四 | 一本久道久久综合狠狠爱 | 欧美午夜特黄aaaaaa片 | 久久国产36精品色熟妇 | 久久久久国色av免费观看性色 | 精品国产一区二区三区av 性色 | 亚洲成a人片在线观看无码 | 国产特级毛片aaaaaaa高清 | 麻豆蜜桃av蜜臀av色欲av | 亚洲gv猛男gv无码男同 | 人妻有码中文字幕在线 | 毛片内射-百度 | 国产真实夫妇视频 | 丝袜人妻一区二区三区 | 国产网红无码精品视频 | 国产av久久久久精东av | 国产精品久久久久9999小说 | 99久久人妻精品免费二区 | 欧美国产亚洲日韩在线二区 | 偷窥日本少妇撒尿chinese | 欧美三级不卡在线观看 | 亚洲狠狠色丁香婷婷综合 | 中文字幕乱码中文乱码51精品 | 婷婷五月综合缴情在线视频 | 99精品国产综合久久久久五月天 | √天堂中文官网8在线 | 欧美性色19p | 少妇邻居内射在线 | 天天综合网天天综合色 | 亚洲日韩av一区二区三区四区 | 国产精华av午夜在线观看 | 一个人看的视频www在线 | 久久99精品国产.久久久久 | 成 人影片 免费观看 | 亚洲日韩av一区二区三区四区 | 国产精品多人p群无码 | 国内精品人妻无码久久久影院 | 亚洲男女内射在线播放 | 永久黄网站色视频免费直播 | 欧洲熟妇色 欧美 | 国产亚洲人成在线播放 | 国产成人无码a区在线观看视频app | 国产va免费精品观看 | 一本久久a久久精品vr综合 | 在线欧美精品一区二区三区 | 亚洲乱亚洲乱妇50p | 色综合久久久久综合一本到桃花网 | 国产乱人偷精品人妻a片 | 婷婷五月综合激情中文字幕 | 日日鲁鲁鲁夜夜爽爽狠狠 | 一本久道久久综合狠狠爱 | 欧美刺激性大交 | 亚洲aⅴ无码成人网站国产app | 久久99热只有频精品8 | 麻豆蜜桃av蜜臀av色欲av | 欧美第一黄网免费网站 | 亚洲国产精品一区二区美利坚 | 色婷婷香蕉在线一区二区 | 亚洲成av人片天堂网无码】 | 午夜精品一区二区三区的区别 | 国产热a欧美热a在线视频 | 久久久久99精品成人片 | 永久黄网站色视频免费直播 | 国产欧美精品一区二区三区 | 国产人妻大战黑人第1集 | 宝宝好涨水快流出来免费视频 | 久久精品无码一区二区三区 | 国产美女精品一区二区三区 | 美女极度色诱视频国产 | 嫩b人妻精品一区二区三区 | 久久国产精品精品国产色婷婷 | 中文字幕色婷婷在线视频 | 亚洲一区二区三区播放 | 久久亚洲中文字幕无码 | 国产成人一区二区三区别 | 人人澡人人妻人人爽人人蜜桃 | 日韩欧美成人免费观看 | 丰满岳乱妇在线观看中字无码 | 妺妺窝人体色www婷婷 | 天天综合网天天综合色 | 亚洲国产精品一区二区美利坚 | 久久久中文久久久无码 | 日韩精品无码一本二本三本色 | 亚洲国产精品美女久久久久 | 曰本女人与公拘交酡免费视频 | 激情亚洲一区国产精品 | 亚洲一区二区三区无码久久 | 成人片黄网站色大片免费观看 | 国产精品亚洲五月天高清 | 久久熟妇人妻午夜寂寞影院 | 久久 国产 尿 小便 嘘嘘 | 国产精品亚洲а∨无码播放麻豆 | 高潮毛片无遮挡高清免费 | 精品无码国产自产拍在线观看蜜 | 亚洲乱码国产乱码精品精 | 东京无码熟妇人妻av在线网址 | 全黄性性激高免费视频 | 18禁黄网站男男禁片免费观看 | 亚洲精品综合一区二区三区在线 | 少妇人妻av毛片在线看 | 中文字幕无码日韩专区 | 成人一区二区免费视频 | 成 人 网 站国产免费观看 | 久久综合色之久久综合 | 午夜精品久久久久久久 | 精品无码一区二区三区爱欲 | 亚洲欧美日韩综合久久久 | 国产精品无码一区二区桃花视频 | 中文字幕 人妻熟女 | 99久久久无码国产精品免费 | 中文字幕无码免费久久99 | 性欧美疯狂xxxxbbbb | 麻豆精品国产精华精华液好用吗 | 色窝窝无码一区二区三区色欲 | 中文字幕无码免费久久9一区9 | 欧美日韩一区二区免费视频 | 丝袜足控一区二区三区 | 亚洲成av人综合在线观看 | www国产精品内射老师 | 日韩 欧美 动漫 国产 制服 | 日韩精品无码一区二区中文字幕 | 色婷婷欧美在线播放内射 | 欧美性生交xxxxx久久久 | 欧洲精品码一区二区三区免费看 | 激情国产av做激情国产爱 | 国产在线无码精品电影网 | 国产深夜福利视频在线 | 国产高清av在线播放 | 天天做天天爱天天爽综合网 | 2020久久香蕉国产线看观看 | 国产97在线 | 亚洲 | 欧美精品免费观看二区 | 人妻少妇精品无码专区二区 | 天天躁日日躁狠狠躁免费麻豆 | 亚洲第一网站男人都懂 | 精品无人国产偷自产在线 | 丰满少妇女裸体bbw | 亚洲色偷偷偷综合网 | 熟妇人妻无码xxx视频 | 欧美三级不卡在线观看 | 日本丰满护士爆乳xxxx | 给我免费的视频在线观看 | 国产麻豆精品一区二区三区v视界 | 熟妇人妻无码xxx视频 | 夜先锋av资源网站 | 亚洲s码欧洲m码国产av | 欧美激情内射喷水高潮 | 精品水蜜桃久久久久久久 | 亚洲午夜无码久久 | 国产在线精品一区二区三区直播 | 性开放的女人aaa片 | 麻花豆传媒剧国产免费mv在线 | 久久无码中文字幕免费影院蜜桃 | 又粗又大又硬毛片免费看 | 妺妺窝人体色www在线小说 | 成 人 网 站国产免费观看 | 99视频精品全部免费免费观看 | 国产超级va在线观看视频 | 青草青草久热国产精品 | 国产人成高清在线视频99最全资源 | 在线天堂新版最新版在线8 | 国产电影无码午夜在线播放 | 婷婷五月综合激情中文字幕 | 亚洲男女内射在线播放 | 97久久精品无码一区二区 | 人人妻人人澡人人爽人人精品 | 亚洲欧洲日本综合aⅴ在线 | 午夜精品久久久久久久 | 成人av无码一区二区三区 | 亚洲精品综合五月久久小说 | 亚洲精品一区二区三区婷婷月 | 久久久久成人片免费观看蜜芽 | 无套内谢的新婚少妇国语播放 | 亚洲精品一区国产 | 性欧美牲交xxxxx视频 | 一区二区三区乱码在线 | 欧洲 | 国产精品久久久av久久久 | 内射老妇bbwx0c0ck | 亚洲成a人片在线观看无码3d | 大胆欧美熟妇xx | 亚洲日韩av片在线观看 | aⅴ在线视频男人的天堂 | 三上悠亚人妻中文字幕在线 | 无码人妻丰满熟妇区五十路百度 | a片免费视频在线观看 | 久久久久久av无码免费看大片 | 亚洲日韩中文字幕在线播放 | 亚洲男人av香蕉爽爽爽爽 | а天堂中文在线官网 | 亚洲国产精品无码一区二区三区 | 特大黑人娇小亚洲女 | 一本色道久久综合亚洲精品不卡 | 黑人粗大猛烈进出高潮视频 | 999久久久国产精品消防器材 | 大屁股大乳丰满人妻 | 国产精品va在线观看无码 | 理论片87福利理论电影 | 久久99精品国产麻豆 | 欧美激情综合亚洲一二区 | 精品一区二区不卡无码av | 国产精品国产三级国产专播 | 国产情侣作爱视频免费观看 | 真人与拘做受免费视频 | 亚洲中文字幕成人无码 | 国产成人无码av一区二区 | 激情综合激情五月俺也去 | 国产av人人夜夜澡人人爽麻豆 | 久久久久久亚洲精品a片成人 | 天堂亚洲免费视频 | 少妇人妻av毛片在线看 | 久久精品国产大片免费观看 | 无码人妻精品一区二区三区下载 | 丰满少妇人妻久久久久久 | 久久久久久av无码免费看大片 | 亚洲天堂2017无码 | 国产亚洲精品精品国产亚洲综合 | 人人妻人人澡人人爽欧美一区 | 人人澡人人透人人爽 | 久久久久亚洲精品中文字幕 | 中文久久乱码一区二区 | 亚洲精品久久久久中文第一幕 | 国产午夜亚洲精品不卡 | 国产黑色丝袜在线播放 | 给我免费的视频在线观看 | 精品乱子伦一区二区三区 | 久久综合给合久久狠狠狠97色 | 亚洲热妇无码av在线播放 | 东京热男人av天堂 | 无码人妻久久一区二区三区不卡 | 永久免费精品精品永久-夜色 | 日韩精品久久久肉伦网站 | 国产精品丝袜黑色高跟鞋 | 人人妻人人澡人人爽欧美一区 | 无码午夜成人1000部免费视频 | 少妇太爽了在线观看 | 亚洲精品鲁一鲁一区二区三区 | 一本久久a久久精品vr综合 | 亚洲欧美综合区丁香五月小说 | 无码国产色欲xxxxx视频 | 日本一卡2卡3卡四卡精品网站 | 亚洲日本在线电影 | 中文精品久久久久人妻不卡 | 亚洲无人区午夜福利码高清完整版 | 久久久久久a亚洲欧洲av冫 | 丰满人妻精品国产99aⅴ | 少妇性俱乐部纵欲狂欢电影 | 久久综合激激的五月天 | 波多野结衣乳巨码无在线观看 | 国产精品自产拍在线观看 | 丰满少妇人妻久久久久久 | 久久99精品国产.久久久久 | 国产香蕉尹人综合在线观看 | 小sao货水好多真紧h无码视频 | 精品久久8x国产免费观看 | 黑人大群体交免费视频 | 中文字幕日产无线码一区 | 性啪啪chinese东北女人 | 国产激情综合五月久久 | 99麻豆久久久国产精品免费 | 偷窥日本少妇撒尿chinese | 女高中生第一次破苞av | 成 人影片 免费观看 | 狂野欧美激情性xxxx | 精品欧洲av无码一区二区三区 | 曰本女人与公拘交酡免费视频 | 日韩精品无码一区二区中文字幕 | 国产女主播喷水视频在线观看 | 国产明星裸体无码xxxx视频 | 噜噜噜亚洲色成人网站 | 国产无套内射久久久国产 | 东京无码熟妇人妻av在线网址 | 中文字幕无线码 | 岛国片人妻三上悠亚 | 免费观看激色视频网站 | 国语自产偷拍精品视频偷 | 精品无码国产自产拍在线观看蜜 | 四虎影视成人永久免费观看视频 | 牲交欧美兽交欧美 | 亚拍精品一区二区三区探花 | 亚洲中文字幕乱码av波多ji | 成人免费视频一区二区 | 精品国偷自产在线视频 | 国产色在线 | 国产 | 免费乱码人妻系列无码专区 | 免费无码一区二区三区蜜桃大 | 嫩b人妻精品一区二区三区 | 少妇被黑人到高潮喷出白浆 | 国产内射爽爽大片视频社区在线 | 51国偷自产一区二区三区 | 熟女体下毛毛黑森林 | 中文字幕无码热在线视频 | 熟女体下毛毛黑森林 | 亚洲国产午夜精品理论片 | 免费无码的av片在线观看 | 老熟女乱子伦 | 一本色道久久综合亚洲精品不卡 | 性啪啪chinese东北女人 | 香港三级日本三级妇三级 | 成在人线av无码免观看麻豆 | 国产一区二区三区四区五区加勒比 | 女人高潮内射99精品 | 久久亚洲精品中文字幕无男同 | 国产精品久久久av久久久 | 欧美黑人乱大交 | 成年女人永久免费看片 | 丰满人妻被黑人猛烈进入 | 色婷婷综合激情综在线播放 | 色欲久久久天天天综合网精品 | 国产精品久久精品三级 | 激情综合激情五月俺也去 | 国产精品亚洲专区无码不卡 | 久久精品成人欧美大片 | 亚洲精品www久久久 | 色诱久久久久综合网ywww | 无码乱肉视频免费大全合集 | 波多野结衣av一区二区全免费观看 | 国产精品久久福利网站 | 国产超级va在线观看视频 | 国产一区二区三区精品视频 | 大地资源中文第3页 | 亚洲日本在线电影 | 女人和拘做爰正片视频 | 亚洲欧洲日本综合aⅴ在线 | 99久久久无码国产aaa精品 | 亚洲精品综合五月久久小说 | 成人一区二区免费视频 | 久久精品人人做人人综合 | 天海翼激烈高潮到腰振不止 | 日韩无码专区 | 欧美日韩人成综合在线播放 | 国产无套内射久久久国产 | 日本乱人伦片中文三区 | 国产一精品一av一免费 | 亚洲精品一区国产 | 午夜熟女插插xx免费视频 | 久久久精品国产sm最大网站 | 亚洲性无码av中文字幕 | 波多野结衣aⅴ在线 | 国产无遮挡又黄又爽免费视频 | 国产真人无遮挡作爱免费视频 | 亚洲一区二区三区偷拍女厕 | 国产成人无码区免费内射一片色欲 | 成人一在线视频日韩国产 | 人人妻人人澡人人爽人人精品 | 少女韩国电视剧在线观看完整 | 日日麻批免费40分钟无码 | 免费男性肉肉影院 | 综合激情五月综合激情五月激情1 | 成人免费视频在线观看 | 天堂久久天堂av色综合 | 午夜精品久久久久久久久 | 国产三级久久久精品麻豆三级 | 国产精品国产三级国产专播 | 国产两女互慰高潮视频在线观看 | 99麻豆久久久国产精品免费 | 扒开双腿疯狂进出爽爽爽视频 | 午夜无码区在线观看 | 我要看www免费看插插视频 | 久久99国产综合精品 | 国产女主播喷水视频在线观看 | 少妇被黑人到高潮喷出白浆 | 亚洲成a人片在线观看日本 | 亚洲精品一区二区三区在线观看 | √天堂资源地址中文在线 | 欧美 亚洲 国产 另类 | 亚洲伊人久久精品影院 | 中文字幕无线码免费人妻 | 亚洲中文字幕va福利 | 内射爽无广熟女亚洲 | 人人爽人人澡人人人妻 | 极品嫩模高潮叫床 | 亚洲精品一区二区三区在线 | 成人精品视频一区二区三区尤物 | 久久久中文字幕日本无吗 | 久久zyz资源站无码中文动漫 | 无码帝国www无码专区色综合 | 牲交欧美兽交欧美 | 日本又色又爽又黄的a片18禁 | 美女黄网站人色视频免费国产 | 日韩视频 中文字幕 视频一区 | 欧美日韩亚洲国产精品 | 亚洲精品国产精品乱码视色 | 久久国内精品自在自线 | 国产精品无码久久av | 呦交小u女精品视频 | 午夜男女很黄的视频 | 色窝窝无码一区二区三区色欲 | 天天爽夜夜爽夜夜爽 | 精品无人区无码乱码毛片国产 | 亚洲欧美中文字幕5发布 | 欧美刺激性大交 | 色婷婷香蕉在线一区二区 | 欧美性生交xxxxx久久久 | 少妇高潮喷潮久久久影院 | 在线欧美精品一区二区三区 | 欧美人妻一区二区三区 | 国产成人午夜福利在线播放 | 国产区女主播在线观看 | 日本乱人伦片中文三区 | 久久亚洲国产成人精品性色 | 欧美人与动性行为视频 | 人人妻人人澡人人爽人人精品浪潮 | 露脸叫床粗话东北少妇 | 999久久久国产精品消防器材 | 亚欧洲精品在线视频免费观看 | 少妇无码一区二区二三区 | 国产亚av手机在线观看 | 日韩精品成人一区二区三区 | 女人高潮内射99精品 | 亚洲国产精品久久久久久 | 一个人看的www免费视频在线观看 | 极品嫩模高潮叫床 | 亚洲一区二区三区香蕉 | 国产三级精品三级男人的天堂 | 色偷偷人人澡人人爽人人模 | 亚洲中文字幕无码中文字在线 | 国产精品久久久久无码av色戒 | 精品国产一区二区三区av 性色 | 中文无码伦av中文字幕 | 亚洲成av人在线观看网址 | 国产精品亚洲а∨无码播放麻豆 | 亚洲色欲色欲欲www在线 | 久久久久免费看成人影片 | 亚洲日韩一区二区 | 国产一精品一av一免费 | 欧美日本免费一区二区三区 | 久久天天躁夜夜躁狠狠 | 中文字幕+乱码+中文字幕一区 | 国产精品久久久久久无码 | 人妻无码久久精品人妻 | 国产香蕉尹人综合在线观看 | 日本肉体xxxx裸交 | 国产成人一区二区三区在线观看 | 亚洲欧洲中文日韩av乱码 | 久久天天躁狠狠躁夜夜免费观看 | 亚洲色欲久久久综合网东京热 | 中国女人内谢69xxxxxa片 | 国产内射爽爽大片视频社区在线 | 国产精品久久久久无码av色戒 | 亚洲高清偷拍一区二区三区 | 国产亚洲人成a在线v网站 | 曰本女人与公拘交酡免费视频 | 国产精品内射视频免费 | 亚洲va中文字幕无码久久不卡 | 国产精品久久久久久久影院 | 131美女爱做视频 | 色欲av亚洲一区无码少妇 | 欧美日韩视频无码一区二区三 | 成人影院yy111111在线观看 | 99视频精品全部免费免费观看 | 久久久国产精品无码免费专区 | 四虎4hu永久免费 | 牛和人交xxxx欧美 | 熟妇人妻中文av无码 | 精品一二三区久久aaa片 | 成在人线av无码免费 | 亚洲乱码中文字幕在线 | 一个人看的视频www在线 | 美女极度色诱视频国产 | 六月丁香婷婷色狠狠久久 | 国产色精品久久人妻 | 欧美精品一区二区精品久久 | 国产av久久久久精东av | aa片在线观看视频在线播放 | 免费看少妇作爱视频 | 日日碰狠狠躁久久躁蜜桃 | 97无码免费人妻超级碰碰夜夜 | 久久99精品久久久久久动态图 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 亚洲成av人片天堂网无码】 | 国产精品亚洲综合色区韩国 | 强开小婷嫩苞又嫩又紧视频 | 人人妻人人澡人人爽欧美一区 | 亚洲 日韩 欧美 成人 在线观看 | 黑人巨大精品欧美黑寡妇 | 日本精品久久久久中文字幕 | 黑人巨大精品欧美黑寡妇 | 亚洲精品欧美二区三区中文字幕 | 久久久久99精品成人片 | 国产国语老龄妇女a片 | 中文字幕av无码一区二区三区电影 | 日本爽爽爽爽爽爽在线观看免 | 亚洲精品久久久久久久久久久 | 欧美阿v高清资源不卡在线播放 | 波多野结衣高清一区二区三区 | 国产香蕉97碰碰久久人人 | 荫蒂被男人添的好舒服爽免费视频 | 国产成人无码一二三区视频 | 日韩欧美成人免费观看 | 伊人久久大香线蕉av一区二区 | 国产一区二区三区精品视频 | 国产国产精品人在线视 | 性色av无码免费一区二区三区 | 少妇邻居内射在线 | 丰满护士巨好爽好大乳 | 国产乱子伦视频在线播放 | 在线播放亚洲第一字幕 | 又粗又大又硬毛片免费看 | 2019nv天堂香蕉在线观看 | 4hu四虎永久在线观看 | 99久久99久久免费精品蜜桃 | 日日噜噜噜噜夜夜爽亚洲精品 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | а√资源新版在线天堂 | 又湿又紧又大又爽a视频国产 | 精品水蜜桃久久久久久久 | 日韩av无码一区二区三区 | 午夜福利试看120秒体验区 | 日日麻批免费40分钟无码 | 久久 国产 尿 小便 嘘嘘 | 国产精华av午夜在线观看 | www国产精品内射老师 | 午夜福利一区二区三区在线观看 | 欧美激情综合亚洲一二区 | 亚洲色欲色欲天天天www | 久久久久久a亚洲欧洲av冫 | 中文字幕人妻无码一区二区三区 | 欧美人与动性行为视频 | 天天摸天天碰天天添 | 丁香花在线影院观看在线播放 | www一区二区www免费 | 大色综合色综合网站 | 亚洲日韩精品欧美一区二区 | 国产成人午夜福利在线播放 | 国产成人人人97超碰超爽8 | 国产内射爽爽大片视频社区在线 | 久久精品国产一区二区三区肥胖 | 日本精品人妻无码77777 天堂一区人妻无码 | 亚洲成a人片在线观看日本 | 中文字幕av无码一区二区三区电影 | 国产精品久久久一区二区三区 | 久久久精品成人免费观看 | 亚洲国产欧美日韩精品一区二区三区 | 国产美女极度色诱视频www | 狠狠亚洲超碰狼人久久 | 日韩人妻少妇一区二区三区 | 国产无遮挡又黄又爽免费视频 | 无码av中文字幕免费放 | 红桃av一区二区三区在线无码av | 女人被男人躁得好爽免费视频 | 曰韩少妇内射免费播放 | 亚洲色在线无码国产精品不卡 | 久热国产vs视频在线观看 | 一本精品99久久精品77 | 精品国产乱码久久久久乱码 | aa片在线观看视频在线播放 | 色噜噜亚洲男人的天堂 | 欧美 丝袜 自拍 制服 另类 | 高潮毛片无遮挡高清免费视频 | 精品午夜福利在线观看 | 久久久久免费精品国产 | 精品久久久久久亚洲精品 | 秋霞特色aa大片 | 国产香蕉尹人综合在线观看 | av无码久久久久不卡免费网站 | 无码人妻丰满熟妇区毛片18 | 久久天天躁狠狠躁夜夜免费观看 | 99精品久久毛片a片 | 日本精品久久久久中文字幕 | 呦交小u女精品视频 | 欧美大屁股xxxxhd黑色 | 国产午夜手机精彩视频 | 人妻少妇精品久久 | 7777奇米四色成人眼影 | 无码纯肉视频在线观看 | 麻豆成人精品国产免费 | 性欧美牲交xxxxx视频 | √天堂中文官网8在线 | 国产成人精品一区二区在线小狼 | 妺妺窝人体色www在线小说 | 九九在线中文字幕无码 | 国产精品99久久精品爆乳 | 乱人伦人妻中文字幕无码久久网 | 熟妇人妻中文av无码 | 亚洲国产午夜精品理论片 | 麻花豆传媒剧国产免费mv在线 | 精品国偷自产在线视频 | 乱人伦人妻中文字幕无码 | 人妻插b视频一区二区三区 | 免费网站看v片在线18禁无码 | 小sao货水好多真紧h无码视频 | 色狠狠av一区二区三区 | 亚洲中文字幕在线观看 | 欧美日韩人成综合在线播放 | aⅴ亚洲 日韩 色 图网站 播放 | 午夜福利试看120秒体验区 | 日韩视频 中文字幕 视频一区 | 久激情内射婷内射蜜桃人妖 | 无码av岛国片在线播放 | 初尝人妻少妇中文字幕 | 亚洲人成人无码网www国产 | 欧美人与物videos另类 | 天天综合网天天综合色 | 领导边摸边吃奶边做爽在线观看 | 99精品无人区乱码1区2区3区 | 1000部啪啪未满十八勿入下载 | 在线播放免费人成毛片乱码 | 国产片av国语在线观看 | 欧美日韩一区二区三区自拍 | 亚洲日本一区二区三区在线 | 国产在线精品一区二区三区直播 | 国产小呦泬泬99精品 | 乌克兰少妇性做爰 | 亚洲欧美日韩综合久久久 | 国产成人精品视频ⅴa片软件竹菊 | 国产成人精品一区二区在线小狼 | 成人av无码一区二区三区 | 精品久久久中文字幕人妻 | 精品国产aⅴ无码一区二区 | 任你躁在线精品免费 | 十八禁真人啪啪免费网站 | 亚洲乱码国产乱码精品精 | 国产无套粉嫩白浆在线 | 国产精品va在线播放 | 少妇无码吹潮 | 久久久久亚洲精品男人的天堂 | 欧美 亚洲 国产 另类 | 女高中生第一次破苞av | 特级做a爰片毛片免费69 | 正在播放东北夫妻内射 | 国产亚洲精品久久久久久国模美 | 蜜臀av在线播放 久久综合激激的五月天 | 国产真实伦对白全集 | 无码一区二区三区在线观看 | 色综合天天综合狠狠爱 | 亚洲小说春色综合另类 | 婷婷丁香六月激情综合啪 | 成人毛片一区二区 | 亚洲成色在线综合网站 | 亚洲国产一区二区三区在线观看 | 亚洲国产一区二区三区在线观看 | 一二三四社区在线中文视频 | 一本色道久久综合亚洲精品不卡 | 久久综合九色综合97网 | 国产精品久久久久无码av色戒 | 久久精品女人天堂av免费观看 | 亚洲成色在线综合网站 | 国产后入清纯学生妹 | 狠狠色丁香久久婷婷综合五月 | 亚洲精品久久久久久久久久久 | 久久天天躁狠狠躁夜夜免费观看 | 荡女精品导航 | 乌克兰少妇xxxx做受 | 精品国产aⅴ无码一区二区 | √天堂中文官网8在线 | 久久久久se色偷偷亚洲精品av | 欧美怡红院免费全部视频 | 欧美 日韩 亚洲 在线 | 国产精品怡红院永久免费 | 成人亚洲精品久久久久 | 亚洲成a人片在线观看无码3d | 亚洲精品国产a久久久久久 | 99久久精品午夜一区二区 | 成人女人看片免费视频放人 | 婷婷六月久久综合丁香 | 国产精品久久久久久亚洲影视内衣 | 老头边吃奶边弄进去呻吟 | 亚洲中文字幕乱码av波多ji | 国产内射爽爽大片视频社区在线 | 成人精品视频一区二区三区尤物 | 亚洲色偷偷偷综合网 | 无码人妻出轨黑人中文字幕 | 少妇的肉体aa片免费 | 中国女人内谢69xxxxxa片 | 日韩人妻少妇一区二区三区 | 色欲久久久天天天综合网精品 | 国产精品视频免费播放 | 欧美人与禽zoz0性伦交 | 三上悠亚人妻中文字幕在线 | 成年美女黄网站色大免费视频 | 国产精品久久久久久久9999 | 熟妇激情内射com | 野狼第一精品社区 | 无码免费一区二区三区 | 好爽又高潮了毛片免费下载 | 青草青草久热国产精品 | 久久99精品国产麻豆蜜芽 | 日韩精品无码一区二区中文字幕 | 性欧美熟妇videofreesex | 中文字幕无码热在线视频 | 熟妇人妻中文av无码 | 亚洲 欧美 激情 小说 另类 | 国产成人无码a区在线观看视频app | 久久久亚洲欧洲日产国码αv | 亚洲精品国产精品乱码视色 | 日日橹狠狠爱欧美视频 | 超碰97人人射妻 | 人妻少妇精品视频专区 | 熟女体下毛毛黑森林 | aⅴ亚洲 日韩 色 图网站 播放 | 性史性农村dvd毛片 | 伊在人天堂亚洲香蕉精品区 | 精品久久8x国产免费观看 | 一个人免费观看的www视频 | 中文字幕无线码免费人妻 | 久久精品视频在线看15 | 激情综合激情五月俺也去 | 久久人人97超碰a片精品 | 欧美亚洲日韩国产人成在线播放 | 国模大胆一区二区三区 | 欧美一区二区三区视频在线观看 | 国产三级精品三级男人的天堂 | 亚洲成av人综合在线观看 | 人妻中文无码久热丝袜 | 色狠狠av一区二区三区 | 少妇被黑人到高潮喷出白浆 | 爆乳一区二区三区无码 | 熟女俱乐部五十路六十路av | 国产无遮挡又黄又爽免费视频 | 国产成人一区二区三区在线观看 | 国内揄拍国内精品少妇国语 | 国产在线精品一区二区高清不卡 | 4hu四虎永久在线观看 | 中文字幕色婷婷在线视频 | 在线看片无码永久免费视频 | 国产黄在线观看免费观看不卡 | 黑人大群体交免费视频 | 国精产品一品二品国精品69xx | 捆绑白丝粉色jk震动捧喷白浆 | 日本乱偷人妻中文字幕 | 欧美 日韩 亚洲 在线 | 国产精品国产自线拍免费软件 | 色一情一乱一伦 | 荡女精品导航 | 欧美日韩在线亚洲综合国产人 | 国产亚洲精品久久久久久久久动漫 | 内射白嫩少妇超碰 | 帮老师解开蕾丝奶罩吸乳网站 | 久久99精品国产麻豆蜜芽 | 欧美野外疯狂做受xxxx高潮 | 性色欲网站人妻丰满中文久久不卡 | 精品久久久久香蕉网 | 国精品人妻无码一区二区三区蜜柚 | 日本大香伊一区二区三区 | 国产精品久久久久久亚洲影视内衣 | 特大黑人娇小亚洲女 | 亚洲 a v无 码免 费 成 人 a v | 国产人妻大战黑人第1集 | 亚洲成a人片在线观看无码3d | 高潮喷水的毛片 | 久久久久久久久蜜桃 | 亚洲国产av精品一区二区蜜芽 | 亚洲欧美日韩成人高清在线一区 | 国产人妻人伦精品1国产丝袜 | 精品国产一区二区三区av 性色 | 成人无码精品一区二区三区 | 麻豆人妻少妇精品无码专区 | 亚洲日韩av一区二区三区中文 | 97色伦图片97综合影院 | 午夜男女很黄的视频 | 亚洲欧美日韩国产精品一区二区 | 亚洲乱码中文字幕在线 | 色欲av亚洲一区无码少妇 | 奇米影视7777久久精品人人爽 | 无人区乱码一区二区三区 | 欧美老熟妇乱xxxxx | 无码纯肉视频在线观看 | 亚洲日韩av片在线观看 | 久久久久免费精品国产 | 国内精品久久久久久中文字幕 | 激情内射亚州一区二区三区爱妻 | 乱人伦中文视频在线观看 | 日韩精品a片一区二区三区妖精 | 久久久久人妻一区精品色欧美 | 亚洲自偷精品视频自拍 | 日韩成人一区二区三区在线观看 | 一本久道久久综合婷婷五月 | 欧美真人作爱免费视频 | 精品aⅴ一区二区三区 | 丰满少妇高潮惨叫视频 | 偷窥村妇洗澡毛毛多 | 国産精品久久久久久久 | 亚洲а∨天堂久久精品2021 | aⅴ亚洲 日韩 色 图网站 播放 | 亚洲国产成人av在线观看 | 色综合天天综合狠狠爱 | 亚洲精品无码人妻无码 | 两性色午夜免费视频 | 国产精品自产拍在线观看 | 无码毛片视频一区二区本码 | 俺去俺来也www色官网 | 美女毛片一区二区三区四区 | 亚洲午夜久久久影院 | 久久久无码中文字幕久... | 亚洲男人av香蕉爽爽爽爽 | av无码不卡在线观看免费 | 无码福利日韩神码福利片 | 国产成人精品必看 | 最新国产麻豆aⅴ精品无码 | 又湿又紧又大又爽a视频国产 | 国产麻豆精品精东影业av网站 | 国产无遮挡又黄又爽免费视频 | 中文字幕无码人妻少妇免费 | 中文无码成人免费视频在线观看 | 成人影院yy111111在线观看 | 精品人妻人人做人人爽夜夜爽 | 俺去俺来也在线www色官网 | 亚洲精品美女久久久久久久 | 久久综合狠狠综合久久综合88 | а√资源新版在线天堂 | 在线精品亚洲一区二区 | 欧洲vodafone精品性 | 色综合天天综合狠狠爱 | 欧美丰满少妇xxxx性 | 国产高清不卡无码视频 | 亚洲欧洲中文日韩av乱码 | 久久久久亚洲精品中文字幕 | 全黄性性激高免费视频 | 一个人看的视频www在线 | 国语自产偷拍精品视频偷 | 国产亚av手机在线观看 | 国产亚洲人成a在线v网站 | 女人被男人爽到呻吟的视频 | 久久久无码中文字幕久... | 人妻少妇被猛烈进入中文字幕 | 牲欲强的熟妇农村老妇女视频 | 乌克兰少妇xxxx做受 | 国产成人无码区免费内射一片色欲 | 激情亚洲一区国产精品 | 国产成人一区二区三区别 | 一个人看的视频www在线 | 久久亚洲精品中文字幕无男同 | 欧美老人巨大xxxx做受 | 欧美午夜特黄aaaaaa片 | 荫蒂添的好舒服视频囗交 | 一本色道久久综合狠狠躁 | 精品少妇爆乳无码av无码专区 | 日本www一道久久久免费榴莲 | 久久久中文久久久无码 | 精品久久久久久亚洲精品 | 熟妇激情内射com | 双乳奶水饱满少妇呻吟 | 久久精品中文字幕大胸 | 免费看男女做好爽好硬视频 | 欧美人与物videos另类 | 久久久久久av无码免费看大片 | 天堂久久天堂av色综合 | 蜜桃视频插满18在线观看 | 无码午夜成人1000部免费视频 | 欧美第一黄网免费网站 | 澳门永久av免费网站 | 国产av无码专区亚洲a∨毛片 | 亚洲区欧美区综合区自拍区 | 久久精品无码一区二区三区 | 少妇久久久久久人妻无码 | 国内丰满熟女出轨videos | 性生交大片免费看女人按摩摩 | 亚洲欧美国产精品久久 | 欧美性猛交xxxx富婆 | 人人超人人超碰超国产 | 熟女体下毛毛黑森林 | 精品久久久久久亚洲精品 | 撕开奶罩揉吮奶头视频 | 国产婷婷色一区二区三区在线 | 美女黄网站人色视频免费国产 | 男女下面进入的视频免费午夜 | 中国女人内谢69xxxxxa片 | 青草青草久热国产精品 | 美女极度色诱视频国产 | 国产电影无码午夜在线播放 | 久久久久久国产精品无码下载 | 成 人 免费观看网站 | 久久精品99久久香蕉国产色戒 | 51国偷自产一区二区三区 | 宝宝好涨水快流出来免费视频 | 美女张开腿让人桶 | 麻豆国产人妻欲求不满谁演的 | 色婷婷欧美在线播放内射 | 国产一区二区三区精品视频 | 丁香花在线影院观看在线播放 | 精品aⅴ一区二区三区 | 99久久久国产精品无码免费 | 日韩精品无码一本二本三本色 | 夜夜躁日日躁狠狠久久av | 亚洲综合无码一区二区三区 | 小sao货水好多真紧h无码视频 | 日韩av激情在线观看 | 亚洲大尺度无码无码专区 | 水蜜桃亚洲一二三四在线 | 国产午夜无码精品免费看 | 激情内射亚州一区二区三区爱妻 | 暴力强奷在线播放无码 | 久久亚洲日韩精品一区二区三区 | 亚洲欧美国产精品久久 | 999久久久国产精品消防器材 | 人妻少妇精品无码专区动漫 | 国产明星裸体无码xxxx视频 | 日本大香伊一区二区三区 | 无码一区二区三区在线观看 | 最新国产乱人伦偷精品免费网站 | 大肉大捧一进一出好爽视频 | 欧美日韩亚洲国产精品 | 国产人妻精品一区二区三区不卡 | 青青青爽视频在线观看 | 黑人大群体交免费视频 | 欧美老熟妇乱xxxxx | 亚洲色大成网站www | 日本一区二区三区免费高清 | 久久无码专区国产精品s | 天堂а√在线中文在线 | 中文字幕av无码一区二区三区电影 | 最新版天堂资源中文官网 | 国产一区二区三区日韩精品 | 玩弄中年熟妇正在播放 | 欧美乱妇无乱码大黄a片 | 亚洲国产精品成人久久蜜臀 | 99精品国产综合久久久久五月天 | 午夜成人1000部免费视频 | 理论片87福利理论电影 | 国内精品久久久久久中文字幕 | 人人爽人人爽人人片av亚洲 | 国产97人人超碰caoprom | 亚洲国产精品无码久久久久高潮 | 亚洲精品一区二区三区婷婷月 | 久久无码专区国产精品s | 国产精品高潮呻吟av久久 | 无码人妻精品一区二区三区不卡 | 激情内射日本一区二区三区 | 国产极品视觉盛宴 | 少妇性荡欲午夜性开放视频剧场 | 黑人大群体交免费视频 | 麻豆md0077饥渴少妇 | 亚洲男女内射在线播放 | 真人与拘做受免费视频一 | 久久精品国产一区二区三区肥胖 | 曰韩少妇内射免费播放 | 狠狠综合久久久久综合网 | 亚洲最大成人网站 | 欧美35页视频在线观看 | 色婷婷综合中文久久一本 | 老司机亚洲精品影院无码 | 黑人粗大猛烈进出高潮视频 | 国产绳艺sm调教室论坛 | 99久久精品日本一区二区免费 | 秋霞特色aa大片 | 熟妇激情内射com | 国产乱子伦视频在线播放 | 亚洲欧美国产精品久久 | 无码av免费一区二区三区试看 | 最近免费中文字幕中文高清百度 | 国色天香社区在线视频 | 亚洲欧美日韩综合久久久 | 亚洲午夜无码久久 | 人妻少妇精品无码专区动漫 | 久久天天躁夜夜躁狠狠 | 男人扒开女人内裤强吻桶进去 | 在线观看国产午夜福利片 | 天天拍夜夜添久久精品大 | 亚洲欧美日韩综合久久久 | 国产凸凹视频一区二区 | 波多野结衣av一区二区全免费观看 | 欧美野外疯狂做受xxxx高潮 | 毛片内射-百度 | 秋霞成人午夜鲁丝一区二区三区 | 亚洲爆乳无码专区 | 亚洲精品国产精品乱码不卡 | 麻花豆传媒剧国产免费mv在线 | 国产农村乱对白刺激视频 | 欧美肥老太牲交大战 | 久久午夜夜伦鲁鲁片无码免费 | 日韩无套无码精品 | 中文无码成人免费视频在线观看 | 欧美午夜特黄aaaaaa片 | 激情内射亚州一区二区三区爱妻 | 国产精品国产自线拍免费软件 | 麻豆国产丝袜白领秘书在线观看 | 亚洲欧洲无卡二区视頻 | 国精产品一区二区三区 | 帮老师解开蕾丝奶罩吸乳网站 | 日本精品久久久久中文字幕 | 亚洲一区二区三区香蕉 | 性色欲网站人妻丰满中文久久不卡 | 中文字幕人妻无码一夲道 | 无码国产色欲xxxxx视频 | 欧美黑人巨大xxxxx | 国产精品亚洲专区无码不卡 | 欧美午夜特黄aaaaaa片 | 亚洲男女内射在线播放 | 激情人妻另类人妻伦 | 亚洲综合伊人久久大杳蕉 | 国产亚洲精品久久久久久久 | av小次郎收藏 | 欧美freesex黑人又粗又大 | 亚洲欧美综合区丁香五月小说 | 国产av剧情md精品麻豆 | 亚洲日本在线电影 | 欧美老妇与禽交 | 精品国产成人一区二区三区 | 无码国产色欲xxxxx视频 | 国产女主播喷水视频在线观看 | 中文字幕日韩精品一区二区三区 | 精品国产麻豆免费人成网站 | 中文精品久久久久人妻不卡 | 欧美激情一区二区三区成人 | 波多野结衣av一区二区全免费观看 | 久久熟妇人妻午夜寂寞影院 | 国产精品久久福利网站 | 国产亚洲欧美日韩亚洲中文色 | 久久亚洲精品成人无码 | 精品久久久无码人妻字幂 | 97无码免费人妻超级碰碰夜夜 | 国产精品二区一区二区aⅴ污介绍 | 人人妻在人人 | 无码国产激情在线观看 | 丰满肥臀大屁股熟妇激情视频 | 天海翼激烈高潮到腰振不止 | 荫蒂添的好舒服视频囗交 | 97无码免费人妻超级碰碰夜夜 | 国产av无码专区亚洲awww | 中文字幕av日韩精品一区二区 | 麻豆国产人妻欲求不满 | a在线亚洲男人的天堂 | 精品人妻中文字幕有码在线 | 无人区乱码一区二区三区 | 免费看男女做好爽好硬视频 | 狠狠色欧美亚洲狠狠色www | 国产热a欧美热a在线视频 | 精品久久综合1区2区3区激情 | 漂亮人妻洗澡被公强 日日躁 | 99国产精品白浆在线观看免费 | 自拍偷自拍亚洲精品被多人伦好爽 | 少妇激情av一区二区 | 久久久久成人片免费观看蜜芽 | 乱人伦人妻中文字幕无码 | 亚洲精品国产精品乱码不卡 | 对白脏话肉麻粗话av | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 日本精品久久久久中文字幕 | 亚洲综合在线一区二区三区 | 无码人妻精品一区二区三区不卡 | 欧美日韩综合一区二区三区 | 久久国产精品_国产精品 | 久久国产精品_国产精品 | 精品乱码久久久久久久 | 人人澡人人透人人爽 | 久久久精品国产sm最大网站 | 国产综合久久久久鬼色 | 无码帝国www无码专区色综合 | 好屌草这里只有精品 | 国产乱人偷精品人妻a片 | 中文字幕人成乱码熟女app | 少妇高潮一区二区三区99 | 无码福利日韩神码福利片 | 国产免费久久久久久无码 | 欧美熟妇另类久久久久久不卡 | 少妇人妻av毛片在线看 | 偷窥日本少妇撒尿chinese | 久久精品一区二区三区四区 | 亚洲中文字幕久久无码 | 国模大胆一区二区三区 | 四虎国产精品一区二区 | 红桃av一区二区三区在线无码av | 亚洲午夜无码久久 | 精品水蜜桃久久久久久久 | 1000部啪啪未满十八勿入下载 | 永久免费观看美女裸体的网站 | 澳门永久av免费网站 | 亚洲国产精华液网站w | 国产精品久久久久久亚洲影视内衣 | 日韩精品无码一区二区中文字幕 | 夫妻免费无码v看片 | 好男人www社区 | 欧美性猛交xxxx富婆 | 国产精品久久精品三级 | 三级4级全黄60分钟 | 搡女人真爽免费视频大全 | 国产 精品 自在自线 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 少妇人妻av毛片在线看 | 色婷婷综合中文久久一本 | yw尤物av无码国产在线观看 | 欧美35页视频在线观看 | 麻豆av传媒蜜桃天美传媒 | 伊人久久大香线蕉亚洲 | 久久久国产一区二区三区 | 国产高清av在线播放 | а√天堂www在线天堂小说 | 女人高潮内射99精品 | 少妇被粗大的猛进出69影院 | 天天综合网天天综合色 | 国产综合色产在线精品 | 日韩欧美群交p片內射中文 | 人人爽人人爽人人片av亚洲 | 老司机亚洲精品影院 | 一本色道久久综合狠狠躁 | 色妞www精品免费视频 | 久久婷婷五月综合色国产香蕉 | 亚洲七七久久桃花影院 | 成人性做爰aaa片免费看 | 动漫av一区二区在线观看 | 久久综合久久自在自线精品自 | 欧美阿v高清资源不卡在线播放 | 日日摸日日碰夜夜爽av |