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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

Java并发编程与技术内幕:ConcurrentHashMap源码解析

發布時間:2024/3/12 java 57 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Java并发编程与技术内幕:ConcurrentHashMap源码解析 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

? ? ? ? ??

? ? ? 林炳文Evankaka原創作品。轉載請注明出處http://blog.csdn.net/evankaka

? ? ? ?摘要:本文主要講了Java中ConcurrentHashMap?的源碼

? ? ? ?ConcurrentHashMap 是java并發包中非常有用的一個類,在高并發場景用得非常多,它是線程安全的。要注意到雖然HashTable雖然也是線程安全的,但是它的性能在高并發場景下完全比不上ConcurrentHashMap ,這也是由它們的結構所決定的,可以認為ConcurrentHashMap 是HashTable的加強版,不過這加強版和原來的HashTable有非常大的區別,不僅是在結構上,而且在方法上也有差別。

? ? ? ? ?下面先來簡單說說它們的區別吧HashMap、?HashTable、ConcurrentHashMap 的區別吧

1、HashMap是非線程安全,HashTable、ConcurrentHashMap 都是線程安全,而且ConcurrentHashMap 、Hashtable不能傳入nul的key或value,HashMap可以。

2、Hashtable是將數據放入到一個Entrty數組或者它Entrty數組上一個Entrty的鏈表節點。而ConcurrentHashMap 是由Segment數組組成,每一個Segment可以看成是一個單獨的Map.然后每個Segment里又有一個HashEntrty數組用來存放數據。

3、HashTable的get/put/remove方法都是基于同步的synchronized方法,而ConcurrentHashMap 是基本鎖的機制,并且每次不是鎖全表,而是鎖單獨的一個Segment。所以ConcurrentHashMap 的性能比HashTable好。

4、如果不考慮線程安全因素,推薦使用HashMap,因為它性能最好。


首先來看看它包含的結構吧!

public class ConcurrentHashMap<K, V> extends AbstractMap<K, V>implements ConcurrentMap<K, V>, Serializable {private static final long serialVersionUID = 7249069246763182397L;//默認數組容量大小static final int DEFAULT_INITIAL_CAPACITY = 16;//默認裝載因子static final float DEFAULT_LOAD_FACTOR = 0.75f;//默認層級static final int DEFAULT_CONCURRENCY_LEVEL = 16;//最大的每一個數組容量大小static final int MAXIMUM_CAPACITY = 1 << 30;//最大的分組數目static final int MAX_SEGMENTS = 1 << 16; // slightly conservative//調用remove/contain/replace方法時不加鎖的情況下操作重試次數static final int RETRIES_BEFORE_LOCK = 2;//segments 數組索引相關final int segmentMask;//segments 數組偏移相關final int segmentShift;//segments數組,每個segments單獨就可以認為是一個mapfinal Segment<K,V>[] segments;這里看到了一個Segment<K,V>[] segments;數組。下面再來看看Segment這個類。在下面可以看到Segment這個類繼承了ReentrantLock鎖。所以它也是一個鎖。然后它里面還有一個HashEntry<K,V>[] table。這是真正用來存放數據的結構。

/*** Segment內部類,注意它也是一個鎖!可以認為它是一個帶有鎖方法的map*/static final class Segment<K,V> extends ReentrantLock implements Serializable {private static final long serialVersionUID = 2249069246763182397L;//元素個數transient volatile int count;//修改次數transient int modCount;//閾值,超過這個數會重新reSizetransient int threshold;//注意,這里又一個數組,這個是真正存放數據元素的地方transient volatile HashEntry<K,V>[] table;//裝載因子,用來計算thresholdfinal float loadFactor;
HashEntry它的結構很簡單:

static final class HashEntry<K,V> {final K key;final int hash;//用來保存Segment索引的信息volatile V value;final HashEntry<K,V> next;HashEntry(K key, int hash, HashEntry<K,V> next, V value) {this.key = key;this.hash = hash;this.next = next;this.value = value;}@SuppressWarnings("unchecked")static final <K,V> HashEntry<K,V>[] newArray(int i) {return new HashEntry[i];}}
經過上面的分析:可以得出如下的ConcurrentHashMap結構圖


全部源碼分析:

package java.util.concurrent; import java.util.concurrent.locks.*; import java.util.*; import java.io.Serializable; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream;public class ConcurrentHashMap<K, V> extends AbstractMap<K, V>implements ConcurrentMap<K, V>, Serializable {private static final long serialVersionUID = 7249069246763182397L;//默認數組容量大小static final int DEFAULT_INITIAL_CAPACITY = 16;//默認裝載因子static final float DEFAULT_LOAD_FACTOR = 0.75f;//默認層級static final int DEFAULT_CONCURRENCY_LEVEL = 16;//最大的每一個數組容量大小static final int MAXIMUM_CAPACITY = 1 << 30;//最大的分組數目static final int MAX_SEGMENTS = 1 << 16; // slightly conservative//調用remove/contain/replace方法時不加鎖的情況下操作重試次數static final int RETRIES_BEFORE_LOCK = 2;//segments 數組索引相關final int segmentMask;//segments 數組偏移相關final int segmentShift;//segments數組,每個segments單獨就可以認為是一個mapfinal Segment<K,V>[] segments;/*** 哈希算法*/private static int hash(int h) {// Spread bits to regularize both segment and index locations,// using variant of single-word Wang/Jenkins hash.h += (h << 15) ^ 0xffffcd7d;h ^= (h >>> 10);h += (h << 3);h ^= (h >>> 6);h += (h << 2) + (h << 14);return h ^ (h >>> 16);}/*** 根據哈希值計算應該落在哪個segments上*/final Segment<K,V> segmentFor(int hash) {return segments[(hash >>> segmentShift) & segmentMask];}/*** 內部類,每個HashEntry都會存入到一個Segment中去*/static final class HashEntry<K,V> {final K key;//關鍵字final int hash;//哈希值volatile V value;//值final HashEntry<K,V> next;//不同的關鍵字,相再的哈希值時會組成 一個鏈表HashEntry(K key, int hash, HashEntry<K,V> next, V value) {this.key = key;this.hash = hash;this.next = next;this.value = value;}@SuppressWarnings("unchecked")static final <K,V> HashEntry<K,V>[] newArray(int i) {return new HashEntry[i];}}/*** Segment內部類,注意它也是一個鎖!可以認為它是一個帶有鎖方法的map*/static final class Segment<K,V> extends ReentrantLock implements Serializable {private static final long serialVersionUID = 2249069246763182397L;//元素個數transient volatile int count;//修改次數transient int modCount;//閾值,超過這個數會重新reSizetransient int threshold;//注意,這里又一個數組,這個是真正存放數據元素的地方transient volatile HashEntry<K,V>[] table;//裝載因子,用來計算thresholdfinal float loadFactor;//構造函數,由initialCapacity確定table的大小Segment(int initialCapacity, float lf) {loadFactor = lf;setTable(HashEntry.<K,V>newArray(initialCapacity));}@SuppressWarnings("unchecked")static final <K,V> Segment<K,V>[] newArray(int i) {return new Segment[i];}//設置threshold、tablevoid setTable(HashEntry<K,V>[] newTable) {threshold = (int)(newTable.length * loadFactor);//注意,當table的元素個數超過這個時,會觸發reSize;table = newTable;}//取得頭一個HashEntry<K,V> getFirst(int hash) {HashEntry<K,V>[] tab = table;return tab[hash & (tab.length - 1)];}//在加鎖情況下讀數據,注意這個類繼續了鎖的方法V readValueUnderLock(HashEntry<K,V> e) {lock();try {return e.value;} finally {unlock();}}//取元素V get(Object key, int hash) {if (count != 0) { //注意,沒有加鎖HashEntry<K,V> e = getFirst(hash);//取得頭一個while (e != null) { //依次從table中取出元素判斷if (e.hash == hash && key.equals(e.key)) { //hash和key同時相等才表示存在V v = e.value;if (v != null) //有可能在這里時,運行了刪除元素導致為Null,一般發生比較少return v;return readValueUnderLock(e); // 重新在加鎖情況下讀數據}e = e.next;}}return null;}//是否包含一個元素boolean containsKey(Object key, int hash) {if (count != 0) { // HashEntry<K,V> e = getFirst(hash);while (e != null) {if (e.hash == hash && key.equals(e.key))return true;e = e.next;}}return false;}//是否包含一個元素boolean containsValue(Object value) {if (count != 0) { // read-volatileHashEntry<K,V>[] tab = table;int len = tab.length;for (int i = 0 ; i < len; i++) {for (HashEntry<K,V> e = tab[i]; e != null; e = e.next) { //table數組循環讀數V v = e.value;if (v == null) // recheckv = readValueUnderLock(e);if (value.equals(v))return true;}}}return false;}//替換時要加鎖boolean replace(K key, int hash, V oldValue, V newValue) {lock();try {HashEntry<K,V> e = getFirst(hash);while (e != null && (e.hash != hash || !key.equals(e.key)))//hash和key要同時相等才表示是找到了這個元素e = e.next;boolean replaced = false;if (e != null && oldValue.equals(e.value)) { //判斷是否要進行替換replaced = true;e.value = newValue;}return replaced;} finally {unlock();}}//替換時要加鎖V replace(K key, int hash, V newValue) {lock();try {HashEntry<K,V> e = getFirst(hash);while (e != null && (e.hash != hash || !key.equals(e.key)))e = e.next;V oldValue = null;if (e != null) {oldValue = e.value;e.value = newValue;}return oldValue;} finally {unlock();}}//放入一個元素,onlyIfAbsent如果有false表示替換原來的舊值V put(K key, int hash, V value, boolean onlyIfAbsent) {lock();try {int c = count;if (c++ > threshold) // table數組里的元素超過threshold。觸發rehash,其實也就是擴大tablerehash();HashEntry<K,V>[] tab = table;int index = hash & (tab.length - 1);HashEntry<K,V> first = tab[index];//頭一個HashEntry<K,V> e = first;while (e != null && (e.hash != hash || !key.equals(e.key)))//一直不斷判斷不重復才停止e = e.next;V oldValue;if (e != null) { //這個key、hash已經存在,修改原來的oldValue = e.value;if (!onlyIfAbsent)e.value = value; //替換原來的舊值}else { //這個key、hash已經不存在,加入一個新的oldValue = null;++modCount;tab[index] = new HashEntry<K,V>(key, hash, first, value);//加入一個新的元素count = c; // 個數變化}return oldValue;} finally {unlock();}}//重新哈希void rehash() {HashEntry<K,V>[] oldTable = table;int oldCapacity = oldTable.length;//舊容量if (oldCapacity >= MAXIMUM_CAPACITY) //超過默認的最大容量時就退出了return;HashEntry<K,V>[] newTable = HashEntry.newArray(oldCapacity<<1);//這里直接在原來的基礎上擴大1倍threshold = (int)(newTable.length * loadFactor);//重新計算新的閾值int sizeMask = newTable.length - 1;for (int i = 0; i < oldCapacity ; i++) { //下面要做的就是將舊的table上的數據拷貝到新的tableHashEntry<K,V> e = oldTable[i];if (e != null) { //舊table上該處有數據HashEntry<K,V> next = e.next;int idx = e.hash & sizeMask;// 單個節點key-valueif (next == null)newTable[idx] = e;else { //鏈表節點key-valueHashEntry<K,V> lastRun = e;int lastIdx = idx;for (HashEntry<K,V> last = next;last != null;last = last.next) { //這里重新計算了鏈表上最后一個節點的位置int k = last.hash & sizeMask;if (k != lastIdx) {lastIdx = k;lastRun = last;}}newTable[lastIdx] = lastRun;//將原table上對應的鏈表上的最后一個元素放在新table對應鏈表的首位置for (HashEntry<K,V> p = e; p != lastRun; p = p.next) { //for循環依次拷貝鏈表上的數據,注意最后整個鏈表相對原來會倒序排列int k = p.hash & sizeMask;HashEntry<K,V> n = newTable[k];newTable[k] = new HashEntry<K,V>(p.key, p.hash,n, p.value);//新table數據賦值}}}}table = newTable;}//刪除一個元素V remove(Object key, int hash, Object value) {lock(); //刪除要加鎖try {int c = count - 1;HashEntry<K,V>[] tab = table;int index = hash & (tab.length - 1);HashEntry<K,V> first = tab[index];HashEntry<K,V> e = first;while (e != null && (e.hash != hash || !key.equals(e.key)))e = e.next;V oldValue = null;if (e != null) { ///找到元素V v = e.value;if (value == null || value.equals(v)) { //為null或者value相等時才刪除oldValue = v;++modCount;HashEntry<K,V> newFirst = e.next;for (HashEntry<K,V> p = first; p != e; p = p.next)newFirst = new HashEntry<K,V>(p.key, p.hash,newFirst, p.value);//注意它這里會倒換原來鏈表的位置tab[index] = newFirst;count = c; //記錄數減去1}}return oldValue;} finally {unlock();}}//清空整個mapvoid clear() {if (count != 0) {lock();try {HashEntry<K,V>[] tab = table;for (int i = 0; i < tab.length ; i++)tab[i] = null;//直接賦值為null++modCount;count = 0; // write-volatile} finally {unlock();}}}}//構造函數public ConcurrentHashMap(int initialCapacity,float loadFactor, int concurrencyLevel) {if (!(loadFactor > 0) || initialCapacity < 0 || concurrencyLevel <= 0) //loadFactor和initialCapacity都得大于0throw new IllegalArgumentException();if (concurrencyLevel > MAX_SEGMENTS)concurrencyLevel = MAX_SEGMENTS;// Find power-of-two sizes best matching argumentsint sshift = 0;int ssize = 1;while (ssize < concurrencyLevel) {++sshift;ssize <<= 1;}segmentShift = 32 - sshift;segmentMask = ssize - 1;this.segments = Segment.newArray(ssize);if (initialCapacity > MAXIMUM_CAPACITY)initialCapacity = MAXIMUM_CAPACITY;int c = initialCapacity / ssize;if (c * ssize < initialCapacity)++c;int cap = 1;while (cap < c)cap <<= 1;for (int i = 0; i < this.segments.length; ++i)this.segments[i] = new Segment<K,V>(cap, loadFactor);//為每個segments初始化其里面的數組}//構造函數public ConcurrentHashMap(int initialCapacity, float loadFactor) {this(initialCapacity, loadFactor, DEFAULT_CONCURRENCY_LEVEL);}//構造函數public ConcurrentHashMap(int initialCapacity) {this(initialCapacity, DEFAULT_LOAD_FACTOR, DEFAULT_CONCURRENCY_LEVEL);}//默認構造函數public ConcurrentHashMap() {this(DEFAULT_INITIAL_CAPACITY, DEFAULT_LOAD_FACTOR, DEFAULT_CONCURRENCY_LEVEL);}//構造函數public ConcurrentHashMap(Map<? extends K, ? extends V> m) {this(Math.max((int) (m.size() / DEFAULT_LOAD_FACTOR) + 1,DEFAULT_INITIAL_CAPACITY),DEFAULT_LOAD_FACTOR, DEFAULT_CONCURRENCY_LEVEL);putAll(m);}//判斷 是否為空public boolean isEmpty() {final Segment<K,V>[] segments = this.segments;//取得整個Segment數組int[] mc = new int[segments.length];int mcsum = 0;for (int i = 0; i < segments.length; ++i) {if (segments[i].count != 0) //有一個segments數組元素個數不為0,那么整個map肯定不為空return false;elsemcsum += mc[i] = segments[i].modCount;//累加總的修改次數}if (mcsum != 0) {for (int i = 0; i < segments.length; ++i) {if (segments[i].count != 0 ||mc[i] != segments[i].modCount)//這里又做了一次mc[i] != segments[i].modCount判斷,因為segments[i].count = 0時才會跳到這里,不相等那么肯定是又有元素加入return false;}}return true;}//整個mapr的大小,這里的大小指的是存放元素的個數public int size() {final Segment<K,V>[] segments = this.segments;long sum = 0;long check = 0;int[] mc = new int[segments.length];//這是里的for循環是嘗試在不加鎖的情況下來獲取整個map的元素個數for (int k = 0; k < RETRIES_BEFORE_LOCK; ++k) { //這里RETRIES_BEFORE_LOCK=2,最大會做兩次的循環check = 0;sum = 0;int mcsum = 0;for (int i = 0; i < segments.length; ++i) {sum += segments[i].count;//累加每一個segments上的countmcsum += mc[i] = segments[i].modCount;//累加每一個segments上的modCount}if (mcsum != 0) { //修改次數不為0,要再做一次判斷前后兩次的modCount,count的累加for (int i = 0; i < segments.length; ++i) {check += segments[i].count;if (mc[i] != segments[i].modCount) { //前后兩次數據發生了變化check = -1; // 前后兩次取的個數不一到,注意sum還是之前的break;}}}if (check == sum) //前后兩次取的元素個數一樣,直接跳出循環break;}//這里會嘗試在加鎖的情況下來獲取整個map的元素個數if (check != sum) { // 這里一般check會等于-1才發生sum = 0;//重新置0for (int i = 0; i < segments.length; ++i)segments[i].lock();//每一個segments上鎖for (int i = 0; i < segments.length; ++i)sum += segments[i].count;//重新累加for (int i = 0; i < segments.length; ++i)segments[i].unlock();//依次釋放鎖}if (sum > Integer.MAX_VALUE)return Integer.MAX_VALUE;//如果大于最大值,返回最大值elsereturn (int)sum;}//取得一個元素,先是不加鎖情況下去讀public V get(Object key) {int hash = hash(key.hashCode());return segmentFor(hash).get(key, hash);//具體看上面的代碼注釋}//是否包含一個元素,根據key來獲取public boolean containsKey(Object key) {int hash = hash(key.hashCode());return segmentFor(hash).containsKey(key, hash);}//是否包含一個元素,根據value來獲取public boolean containsValue(Object value) {if (value == null)throw new NullPointerException();//取得整個Segment的內容final Segment<K,V>[] segments = this.segments;int[] mc = new int[segments.length];// 嘗試在不加鎖的情況下做判斷for (int k = 0; k < RETRIES_BEFORE_LOCK; ++k) { //RETRIES_BEFORE_LOCK這里=2int sum = 0;int mcsum = 0;for (int i = 0; i < segments.length; ++i) {int c = segments[i].count;//累加個數mcsum += mc[i] = segments[i].modCount;//累加修改次數if (segments[i].containsValue(value)) //判斷是否包含return true;}boolean cleanSweep = true;if (mcsum != 0) { //成立說明發生了改變for (int i = 0; i < segments.length; ++i) { //再循環一次取得segmentsint c = segments[i].count;//累加第二次循環得到的countif (mc[i] != segments[i].modCount) { //如果有一個segments前后兩次不一樣,那么它的元素肯定發生了變化 cleanSweep = false;//break;//跳出}}}if (cleanSweep) //為ture表示經過上面的兩次判斷還是無法找到return false;}// cleanSweepo為false時,進行下面。注意,這里是在加鎖情況下for (int i = 0; i < segments.length; ++i)segments[i].lock();//取得每一個segments的鎖boolean found = false;try {for (int i = 0; i < segments.length; ++i) { //每個segments取出來做判斷if (segments[i].containsValue(value)) {found = true;break;}}} finally { for (int i = 0; i < segments.length; ++i) //依次釋放segments的鎖segments[i].unlock();}return found;}//是否包含public boolean contains(Object value) {return containsValue(value);}//放入一個元素public V put(K key, V value) {if (value == null)throw new NullPointerException();int hash = hash(key.hashCode());return segmentFor(hash).put(key, hash, value, false);//放入時先根據key的hash值找到存放 的segments,再調用其put方法}//放入一個元素,如果key或value為null,那么為招出一個異常public V putIfAbsent(K key, V value) {if (value == null)throw new NullPointerException();int hash = hash(key.hashCode());return segmentFor(hash).put(key, hash, value, true);}//放入一個mappublic void putAll(Map<? extends K, ? extends V> m) {for (Map.Entry<? extends K, ? extends V> e : m.entrySet()) //遍歷entrySet取出再放入put(e.getKey(), e.getValue());}//刪除一個元素,根據keypublic V remove(Object key) {int hash = hash(key.hashCode());return segmentFor(hash).remove(key, hash, null);//根據key的hash值找到存放的segments,再調用其remove方法}//刪除一個元素,根據key-valuepublic boolean remove(Object key, Object value) {int hash = hash(key.hashCode());if (value == null)return false;return segmentFor(hash).remove(key, hash, value) != null;//根據key的hash值找到存放的segments,再調用其remove方法}//替換元素public boolean replace(K key, V oldValue, V newValue) {if (oldValue == null || newValue == null)throw new NullPointerException();int hash = hash(key.hashCode());return segmentFor(hash).replace(key, hash, oldValue, newValue);//根據key的hash值找到存放的segments,再調用其replace方法}//替換元素public V replace(K key, V value) {if (value == null)throw new NullPointerException();int hash = hash(key.hashCode());return segmentFor(hash).replace(key, hash, value);}//清空public void clear() {for (int i = 0; i < segments.length; ++i)segments[i].clear();}//序列化方法private void writeObject(java.io.ObjectOutputStream s) throws IOException {s.defaultWriteObject();for (int k = 0; k < segments.length; ++k) {Segment<K,V> seg = segments[k];seg.lock();//注意加鎖了try {HashEntry<K,V>[] tab = seg.table;for (int i = 0; i < tab.length; ++i) {for (HashEntry<K,V> e = tab[i]; e != null; e = e.next) {s.writeObject(e.key);s.writeObject(e.value);}}} finally {seg.unlock();}}s.writeObject(null);s.writeObject(null);}//反序列化方法private void readObject(java.io.ObjectInputStream s)throws IOException, ClassNotFoundException {s.defaultReadObject();for (int i = 0; i < segments.length; ++i) {segments[i].setTable(new HashEntry[1]);}for (;;) {K key = (K) s.readObject();V value = (V) s.readObject();if (key == null)break;put(key, value);}} }

總結

以上是生活随笔為你收集整理的Java并发编程与技术内幕:ConcurrentHashMap源码解析的全部內容,希望文章能夠幫你解決所遇到的問題。

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

wwwav视频| 久久综合九色九九 | 伊色综合久久之综合久久 | 999久久久国产精品 高清av免费观看 | 91福利视频免费观看 | 97色狠狠 | 五月婷婷一区 | 国产特级毛片aaaaaa毛片 | 成年人在线免费看视频 | 99久久精品免费看国产麻豆 | 久草免费在线观看 | 黄色小网站在线观看 | 精品999久久久 | 特级毛片在线免费观看 | 中文字幕成人 | 天天操天天摸天天爽 | 欧美特一级 | 欧美精品免费视频 | 黄色成人av | 久久久亚洲麻豆日韩精品一区三区 | 天天搞天天干天天色 | 国产一区二区在线免费播放 | 国产爽视频 | 人人插人人费 | av免费在线播放 | 久久视精品 | 久久夜夜夜| 美女视频国产 | 久久久 精品 | 夜夜躁狠狠躁日日躁视频黑人 | 黄色亚洲精品 | 日本精品一区二区 | 成人av影视在线 | 在线v片免费观看视频 | 特黄特色特刺激视频免费播放 | 中文字幕欲求不满 | 久久久久网站 | 91爱爱电影 | 国产精品黄色影片导航在线观看 | 国产精成人品免费观看 | 国产精品h在线观看 | 久草网免费 | 亚洲电影av在线 | 亚洲久草在线视频 | www.91av在线| 99色在线播放 | 东方av在| 久久免费精品 | 久久国产午夜精品理论片最新版本 | 婷婷国产在线观看 | 亚洲国产精品va在线看黑人动漫 | 婷婷av资源 | 97国产视频 | 国产欧美精品一区二区三区四区 | 亚洲三级在线免费观看 | 99热在线网站 | 婷婷六月综合网 | 狠狠夜夜| 18女毛片| 亚洲视频在线播放 | av超碰在线 | 特级a老妇做爰全过程 | 九九久久影院 | 亚洲人在线7777777精品 | 久久综合99 | 天天爽天天搞 | 一本色道久久综合亚洲二区三区 | 日本中文字幕电影在线免费观看 | 18做爰免费视频网站 | 人人爽人人舔 | 婷婷久久国产 | 日韩av在线不卡 | www.色午夜,com | 中文字幕高清在线播放 | 午夜精品一区二区三区免费 | 丁香六月av | 亚洲精品mv在线观看 | 99视频在线精品国自产拍免费观看 | 免费在线黄色av | 国产成人精品午夜在线播放 | 天天综合网在线观看 | 粉嫩aⅴ一区二区三区 | 国产福利av在线 | 国产精品一区二区av影院萌芽 | 亚洲免费一级电影 | 99久久精品久久久久久动态片 | 99麻豆视频 | 日日干天天爽 | 亚洲韩国一区二区三区 | 成人一区二区三区在线 | 97在线免费 | 高清在线一区 | 超碰99人人 | 国产精品一区二区三区99 | 成人欧美一区二区三区黑人麻豆 | 午夜精品久久久99热福利 | 国产三级午夜理伦三级 | 日韩在线一区二区免费 | 成人久久久精品国产乱码一区二区 | 亚洲黄色在线免费观看 | 综合色综合色 | 超碰在线99| 日韩.com| 欧美电影黄色 | 亚洲欧美成aⅴ人在线观看 四虎在线观看 | www夜夜操 | 日韩精品久久久久久久电影竹菊 | 91视频黄色 | 天天操福利视频 | 最新不卡av| 欧美91精品久久久久国产性生爱 | 亚州中文av| 午夜久久久影院 | 久草视频在线观 | 黄色三级免费观看 | 亚洲四虎在线 | 亚洲国产一二三 | 欧美精品一区二区免费 | 91激情小视频 | 欧美大香线蕉线伊人久久 | 欧美一级片免费 | 麻豆精品在线视频 | 97高清免费视频 | 天天草视频 | 五月婷婷色播 | 国产午夜在线观看视频 | 九九99视频 | 不卡av免费在线观看 | 91精品视频网站 | 日韩av快播电影网 | 色综合五月 | 在线观看视频你懂 | 少妇bbbb| 日韩资源视频 | 天天艹日日干 | 一级欧美一级日韩 | 99精品成人| 日本中文字幕在线免费观看 | 热99久久精品 | 麻豆视频免费版 | 天天色天天干天天色 | 免费亚洲一区二区 | 黄色毛片在线观看 | 久久精品视频在线 | 国产精品一区二区在线播放 | 操操色 | 色网站国产精品 | 欧美日韩另类视频 | 亚洲综合视频在线观看 | 成人黄色资源 | 久久福利在线 | 日本不卡久久 | 一区二区三区四区不卡 | 97电院网手机版 | 国产综合福利在线 | 日韩精品一区二区三区在线视频 | 视频一区视频二区在线观看 | 国产精品久久久久久久99 | 免费看毛片网站 | 久99久中文字幕在线 | 日本黄色片一区二区 | 麻豆精品传媒视频 | 狠狠狠狠狠狠操 | 国产中文字幕免费 | 国产码电影 | 成人h在线播放 | 91av免费观看 | 久久人操 | 中文在线免费观看 | 91| 午夜精品福利一区二区 | 精品一区欧美 | 日韩高清二区 | av中文字幕在线观看网站 | 欧美日韩免费看 | 成年人在线免费看视频 | 一区中文字幕 | 国产精品久久久久免费a∨ 欧美一级性生活片 | 婷婷五综合 | 欧美天天干 | 狠狠色丁香婷婷综合久小说久 | 亚洲综合色视频在线观看 | 狠狠色丁香久久婷婷综合丁香 | 五月婷av| 九九99视频 | www.久久久久| 免费黄在线观看 | 在线只有精品 | 国产成人一区二区三区影院在线 | 欧美精品久久久 | 久久综合影视 | 亚洲一区二区三区四区精品 | 久久久久久久久影视 | 欧美性生活免费看 | 97av视频| 欧美激情视频一区二区三区免费 | 色狠狠久久av五月综合 | 伊人婷婷在线 | 黄色一区二区在线观看 | 亚洲a免费 | 婷婷伊人网 | 亚洲男模gay裸体gay | 亚洲区另类春色综合小说校园片 | 国产区在线视频 | 一级黄色片在线免费观看 | 亚洲欧美在线综合 | 欧美大片在线观看一区 | 超碰精品在线观看 | 午夜999| 国产成在线观看免费视频 | 免费91在线观看 | 伊人亚洲综合 | 久久综合久久鬼 | 久精品在线 | 亚洲免费av片 | 黄色中文字幕在线 | 久久er99热精品一区二区三区 | 久久综合99 | 国产精品成人久久久久 | 在线不卡中文字幕播放 | 99一区二区三区 | 麻豆视频入口 | 久99久中文字幕在线 | 国产在线欧美在线 | 91精品国产欧美一区二区成人 | 欧美一级电影免费观看 | 色婷婷视频在线 | 麻豆va一区二区三区久久浪 | 国产伦精品一区二区三区无广告 | 国产欧美精品在线观看 | 中文字幕三区 | 在线色亚洲| 六月婷婷色 | 久操免费视频 | 久久成人一区 | 1区2区视频 | 九七在线视频 | 免费av大全 | www.狠狠插.com| 最新三级在线 | 毛片永久新网址首页 | www.777奇米| 国产大片黄色 | 精品一区二区日韩 | 91久久久久久久一区二区 | 国产日韩视频在线播放 | 在线观看日韩视频 | 欧美一区二视频在线免费观看 | 99久久国产免费免费 | 精品国产一区二区三区不卡 | 欧美另类成人 | 久久久天天操 | 在线观看日韩中文字幕 | 99久久国产免费免费 | 国产小视频在线观看 | 国产精品欧美久久久久三级 | 日韩久久激情 | 亚欧日韩av | 久久爱资源网 | 国产精品18久久久久久vr | 亚洲开心激情 | 亚洲深夜影院 | av日韩不卡 | 亚洲精品久久久久www | 久久香蕉电影网 | 青春草免费视频 | 久久成人综合视频 | 深爱激情五月网 | 亚洲精品视频在线免费 | 国内精品久久久久久久久久清纯 | 丁香国产视频 | 国产精品久久久毛片 | 91久久在线观看 | 91在线免费看片 | 国产一级在线免费观看 | 久久久久久久久久久高潮一区二区 | 国产在线资源 | 婷婷色在线播放 | 国产一级特黄毛片在线毛片 | 最近中文字幕大全中文字幕免费 | 99精品视频在线播放观看 | 最新国产精品亚洲 | www黄色软件 | 成人试看120秒 | 特级西西444www大胆高清无视频 | 久久久久久久久久久久影院 | 婷婷在线网站 | 瑞典xxxx性hd极品 | 婷婷伊人五月 | 久久伊99综合婷婷久久伊 | www.黄色在线 | 一级a性色生活片久久毛片波多野 | 亚洲成成品网站 | 欧美国产日韩久久 | www.狠狠操.com | 国产精彩视频一区二区 | 欧美人交a欧美精品 | 精品一区在线看 | 免费69视频 | 亚洲每日更新 | 人人爽人人舔 | 一级一片免费观看 | 久久官网 | av永久网址 | 久久不射电影网 | 国产成人精品电影久久久 | 久久国产一二区 | 日韩黄色软件 | 色视频网站在线观看一=区 a视频免费在线观看 | 黄色毛片一级 | 色网站在线 | 欧美一级片在线 | 99热只有精品在线观看 | 久久国产精品一区二区三区 | 人人爽人人av | 97精品国产手机 | 亚av在线 | 香蕉97视频观看在线观看 | 久久a v视频 | 一级黄色大片在线观看 | 欧美二区三区91 | 欧美成人影音 | 日韩亚洲欧美中文字幕 | 日日操日日插 | 国产中文字幕在线播放 | 五月天电影免费在线观看一区 | 91视频网址入口 | 国产精品12345 | 亚洲欧洲视频 | 免费看特级毛片 | 97视频在线免费 | .国产精品成人自产拍在线观看6 | 久久天天躁狠狠躁亚洲综合公司 | 亚洲精品国偷自产在线91正片 | 久久久免费少妇 | 人人爽久久涩噜噜噜网站 | 九九视频在线观看视频6 | 久久久久99精品成人片三人毛片 | 久二影院 | 五月天欧美精品 | 亚洲麻豆精品 | 国产字幕av| 成片免费观看视频 | 日韩最新在线视频 | www.亚洲视频.com | 中文字幕a在线 | 美女国产 | 欧美一级在线观看视频 | 欧美少妇bbwhd | 国产精品二区三区 | 十八岁以下禁止观看的1000个网站 | 深夜免费福利视频 | 中文字幕一区二区三区乱码在线 | 成人午夜精品福利免费 | 国产精品第一页在线 | 欧美一二三四在线 | 1区2区视频 | 国产精品成人a免费观看 | 久久男人中文字幕资源站 | 人人爽人人爽人人片av | 激情丁香月 | 天堂av在线网址 | 亚洲专区视频在线观看 | av中文国产 | 国产精品门事件 | 91精品一区在线观看 | 亚洲一区久久久 | 狠狠色丁香婷综合久久 | 九九激情视频 | 97成人资源| 99re亚洲国产精品 | 操久久免费视频 | 狠狠色丁香久久婷婷综合_中 | 久久资源总站 | 久久伦理 | 91av超碰| 狠狠色丁香 | 91精品国产欧美一区二区成人 | 国产精品久久一区二区无卡 | 日韩精品观看 | 免费色视频网站 | 91精品国产欧美一区二区 | 欧美日韩国产精品一区 | 7777xxxx| 四虎成人免费观看 | 天天干夜夜夜操天 | 欧美日韩在线视频一区二区 | 在线a人v观看视频 | 97av在线视频免费播放 | 91麻豆精品 | 免费网址在线播放 | 成年人精品 | 色在线高清 | 成人国产精品一区二区 | 国产一区二区视频在线 | 91精品国产三级a在线观看 | 日韩成人免费电影 | 人成电影网| av成人在线网站 | 超碰在线人 | 亚洲精品国产精品国自产观看 | 欧美一级在线 | 免费看色视频 | a黄色片在线观看 | 久久亚洲免费 | 欧美网站黄色 | 91最新中文字幕 | 91成人免费看 | 美女久久久 | 色噜噜在线观看视频 | 视频在线观看入口黄最新永久免费国产 | 99av国产精品欲麻豆 | 亚洲精品一区二区三区高潮 | 中文字幕在线观看视频一区二区三区 | 国产精品video爽爽爽爽 | 热久久影视 | 激情av网址 | 成人a级网站 | 最近中文字幕视频网 | 激情综合网五月 | 天天干天天碰 | 国产专区在线视频 | 久久国语露脸国产精品电影 | 伊人影院av | 懂色av懂色av粉嫩av分享吧 | 九九在线国产视频 | 一级做a视频 | 夜夜操天天 | 亚洲第一中文网 | 亚洲一区二区精品 | 欧美日韩视频一区二区三区 | 在线日韩一区 | 特黄免费av | 97国产在线视频 | 99在线免费视频 | 欧美性色综合 | 国产91在线 | 美洲 | 免费福利在线视频 | 精品在线二区 | 国产麻豆剧果冻传媒视频播放量 | 亚洲专区欧美专区 | 顶级欧美色妇4khd | 久av电影 | 91av官网 | 97在线免费| 成人h在线观看 | 91精品国产99久久久久久红楼 | 国产成人亚洲在线观看 | 久久9999久久 | 日日精品 | 97手机电影网 | 欧美aaa大片 | 久久精品麻豆 | 在线观影网站 | 91成人小视频 | 亚洲 欧洲 国产 精品 | 久久久久免费精品视频 | 成人99免费视频 | 亚洲美女视频在线观看 | 国产成人在线免费观看 | 久久久高清视频 | 天天操天天干天天综合网 | 欧美一区二区三区在线看 | 高清不卡一区二区在线 | 欧美精品中文在线免费观看 | 五月婷丁香 | 亚洲精品国产日韩 | 激情av一区二区 | 国产又粗又猛又色又黄网站 | 一本一本久久a久久精品综合小说 | 中文字幕亚洲欧美日韩 | 国产日韩中文字幕在线 | 日韩午夜在线播放 | 91高清在线看 | 99re6热在线精品视频 | 91视频国产高清 | 欧美一区二区三区激情视频 | 69热国产视频 | 日韩av资源在线观看 | 国产日产欧美在线观看 | 国产美女精品视频免费观看 | 久久久久久久久久影视 | 日本性xxx| 国产专区视频在线 | 国产精品一区二区白浆 | 色五丁香| 免费亚洲视频在线观看 | 欧美一级片在线免费观看 | 午夜日b视频 | av激情五月 | 91精品国产综合久久婷婷香蕉 | 九九热精品视频在线观看 | 黄色成人影院 | 中文字幕av在线不卡 | 日韩av二区 | 国产精品久久久久久久av电影 | 69性欧美 | 天天做天天爱天天综合网 | 夜夜夜夜操 | 99在线热播| 综合亚洲视频 | 亚洲高清精品在线 | 亚洲精品国偷自产在线99热 | 国产一二三四在线观看视频 | a在线观看视频 | 亚洲特级片| 国产成人精品区 | 欧美国产91 | 人人爱人人舔 | 超碰在线97观看 | 日韩午夜网站 | 亚洲国产资源 | 国产一区二区在线播放 | 91精品久久久久久综合五月天 | 99人成在线观看视频 | 亚洲欧美日韩国产 | 日本精品视频在线观看 | 99这里只有久久精品视频 | 中文字幕色站 | 国产亚洲婷婷 | 激情视频在线观看网址 | 国产视频精品久久 | 欧美成人按摩 | www.91av在线 | 波多野结衣综合网 | 91麻豆视频 | 免费日韩 精品中文字幕视频在线 | 在线观看韩日电影免费 | 久久久网址 | 午夜精品久久久久久久爽 | 黄色精品视频 | 激情五月婷婷丁香 | 一区二区视频网站 | 91久久精品一区二区三区 | 91成人免费| 国产在线专区 | 日韩精品短视频 | 日韩欧美综合在线视频 | 91精品一区二区在线观看 | 亚洲在线成人精品 | 在线观看mv的中文字幕网站 | 99久久久国产精品免费观看 | 日韩黄在线观看 | 免费精品在线 | 99久久精品免费看 | 日操操 | 久久免费激情视频 | 又紧又大又爽精品一区二区 | 色多多污污 | 99激情网 | 亚洲女裸体| 超碰大片 | 日韩在线观看小视频 | 精品视频网站 | 黄色精品免费 | 国产美女精品视频 | 中文字幕在线观 | 亚洲 欧洲 国产 精品 | 91在线中字 | 国产高清在线a视频大全 | 亚洲精品观看 | 色国产精品一区在线观看 | 中文字幕 国产视频 | 欧美成人69av | 天天操比| 欧美激情第八页 | 久久久久久久网 | 亚洲欧美日韩一二三区 | 色婷婷视频 | 天天·日日日干 | 久久爱综合 | 日日干视频 | 丁香色婷 | 亚洲精品一区二区久 | 成人av午夜 | 国内精品久久久久久中文字幕 | 成人免费视频免费观看 | 国产精品18久久久久久不卡孕妇 | 久久伊人色综合 | 国产日韩欧美在线播放 | 午夜精品在线看 | 日日日日日 | 国产成人精品一区二区三区在线 | 日韩欧美国产精品 | 国产成人高清 | 91av观看 | 成人黄色电影在线播放 | 日韩欧美视频免费在线观看 | 一区二区三区免费在线观看 | 婷婷在线综合 | 99精品在线直播 | 国产原创在线观看 | 久久久久久久久爱 | 美女网站色 | 欧美天天综合 | 丁香六月婷婷开心婷婷网 | 日本资源中文字幕在线 | 四虎www | 亚洲国产网站 | 亚洲黄色区 | 亚洲乱码国产乱码精品天美传媒 | 色狠狠婷婷 | 狠狠色噜噜狠狠 | 国产在线播放不卡 | 国产精品国产亚洲精品看不卡 | 曰韩精品 | 欧美日韩在线观看不卡 | av在线播放快速免费阴 | 懂色av懂色av粉嫩av分享吧 | 国产一区二区精品 | 午夜国产一区 | 欧美91视频| 日b视频国产 | 日日操夜夜操狠狠操 | 一级欧美日韩 | 高清av在线免费观看 | 92中文资源在线 | 欧美精品久久久久a | 欧美日韩午夜爽爽 | 91在线一区 | 伊人久久在线观看 | 久久精品久久综合 | 超碰在线99 | 人人讲| 国产精品9999| 欧洲精品在线视频 | 中文字幕电影在线 | 人人干狠狠干 | 蜜桃麻豆www久久囤产精品 | 夜夜操天天干 | 久久久久色 | 国产精品久久网 | 免费在线观看日韩欧美 | 久久艹在线观看 | 99精品电影 | 一级免费观看 | 亚洲午夜久久久久久久久电影网 | 国产精品18久久久久白浆 | 亚洲精品国偷拍自产在线观看 | 黄色大片网| 久久久免费高清视频 | 日韩av片无码一区二区不卡电影 | 国产精品密入口果冻 | 91chinesexxx| 亚洲黄色成人av | 国产 欧美 在线 | 毛片美女网站 | 亚洲欧美色婷婷 | 国产精品综合久久 | 日韩伦理一区二区三区av在线 | 中国一级片在线播放 | 91在线观看高清 | 天天操夜操 | 成年人视频在线免费观看 | 免费一级片久久 | 黄色软件网站在线观看 | 久久99精品国产91久久来源 | 精品国产自在精品国产精野外直播 | 中文字幕区 | 欧美色图狠狠干 | 91精品啪啪| 欧美在线你懂的 | 国产传媒一区在线 | 国产黄色大片 | 91精品视频一区二区三区 | 亚洲精品国产精品国自产在线 | 九九亚洲精品 | 鲁一鲁影院 | 精品视频在线播放 | 中文字幕一区二区三区在线播放 | 免费看黄色小说的网站 | 久久久久久久国产精品影院 | 81国产精品久久久久久久久久 | 91av视频在线免费观看 | 97超碰人人澡人人爱学生 | 97操操操| 国产精品video爽爽爽爽 | 免费日韩 精品中文字幕视频在线 | 肉色欧美久久久久久久免费看 | 成人免费毛片aaaaaa片 | 粉嫩av一区二区三区四区在线观看 | www日韩在线| 久久乐九色婷婷综合色狠狠182 | 国产黄色精品在线观看 | 日韩一区二区免费视频 | 五月天婷亚洲天综合网鲁鲁鲁 | 人人爽人人搞 | 日韩不卡高清视频 | 国产亚洲成av片在线观看 | 成人久久18免费网站图片 | 国产一级在线视频 | 亚洲午夜久久久久久久久电影网 | 国产又粗又猛又爽又黄的视频免费 | 五月婷婷开心中文字幕 | 欧美久久电影 | 在线视频一二区 | 久久av在线播放 | 亚洲精品在线一区二区三区 | 伊人亚洲综合网 | 婷婷色婷婷 | 在线免费av网站 | 国产精品久久久区三区天天噜 | 国产美女精品人人做人人爽 | 久久久久国产精品免费网站 | 狠狠操影视 | 日本狠狠干 | 国产精品久久久久久吹潮天美传媒 | 在线观看a视频 | 久草精品视频在线观看 | 人人超碰免费 | 国产成人免费在线观看 | 天天操天天干天天操天天干 | 国产精品久久视频 | 美女视频a美女大全免费下载蜜臀 | 亚洲成人动漫在线观看 | 成人国产精品久久久久久亚洲 | 蜜桃视频在线观看一区 | 日本性视频 | 97色在线观看 | 日韩欧美xxxx| 日韩免费在线视频观看 | 欧美日韩中文在线观看 | 久久不见久久见免费影院 | 亚洲成a人片综合在线 | 97香蕉超级碰碰久久免费软件 | av电影在线免费观看 | 亚洲成人国产 | 久香蕉 | 丁香六月天婷婷 | 91传媒在线观看 | 一区二区三区高清在线观看 | 日日夜夜天天干 | 国产精品igao视频网入口 | 日本精品视频免费观看 | 免费在线电影网址大全 | 久久av电影 | 精品国产午夜 | 欧美精品久久久久性色 | 日日碰狠狠躁久久躁综合网 | 2023天天干 | 亚洲春色综合另类校园电影 | 日韩一区二区三区观看 | 日韩二区在线观看 | 黄色软件在线观看免费 | 免费成人av网站 | 五月天综合在线 | 久久久久久电影 | 久久午夜精品影院一区 | 亚洲精品国产成人 | 国产成人av在线影院 | www九九热 | 国产精品久久久久久电影 | 国产黄在线 | 天天看天天干天天操 | 美女视频黄的免费的 | 伊人电影在线观看 | 日韩中文字幕免费看 | 亚洲天天干 | 国产精品你懂的在线观看 | 亚洲国产成人精品在线观看 | 麻豆久久一区二区 | 成年人国产在线观看 | 综合久久综合久久 | 国产精品亚洲视频 | 成年人免费看 | 91精品国产高清自在线观看 | 日韩精品一区二区三区在线视频 | 国内小视频| 3d黄动漫免费看 | 91视频这里只有精品 | 亚洲另类久久 | 久热电影 | 国产99在线播放 | 美女视频黄,久久 | 中文字幕在线国产 | 99人成在线观看视频 | 日韩在线免费视频观看 | 九月婷婷人人澡人人添人人爽 | 欧美日韩国产成人 | 91精品国自产拍天天拍 | 久久精品国产亚洲aⅴ | 国产在线不卡视频 | 超碰免费公开 | 亚洲丁香日韩 | 免费看日韩片 | 欧美在线99| 欧美精品久久久久久久久久 | 国产专区视频在线观看 | 超碰人人在线观看 | 成人97视频 | 久久8精品 | 亚洲欧美日韩精品久久奇米一区 | 亚洲精品麻豆视频 | 天天草天天干天天射 | 美女久久久久 | 成人羞羞视频在线观看免费 | 欧美日韩国产伦理 | 在线观看免费高清视频大全追剧 | 国产亚洲精品久久网站 | 亚洲成av片人久久久 | 国产在线播放一区二区三区 | 亚洲精品一区二区三区高潮 | 国内精品二区 | 午夜精品一二三区 | 五月天com | 色婷婷电影网 | 国产精品永久久久久久久www | 麻豆va一区二区三区久久浪 | 美女视频黄,久久 | 国产精品久久嫩一区二区免费 | 天天躁日日躁狠狠躁av中文 | 久久午夜国产精品 | 青青久草在线 | 丁香综合 | 五月婷婷,六月丁香 | 日韩欧美精品一区 | 人人澡人人草 | 亚洲国产精品一区二区尤物区 | 国产一区二区久久久久 | 操操综合 | 国产一级一片免费播放放 | 国产在线91在线电影 | 婷婷亚洲五月 | 久久久久久久久网站 | 午夜美女av | 国产午夜三级一二三区 | 久久国产精品免费一区 | 在线播放国产精品 | 免费在线观看一区 | 美女视频黄频大全免费 | 在线观看不卡的av | 中文字幕视频免费观看 | 久精品视频免费观看2 | 日批视频国产 | 91精品久久久久久综合五月天 | avsex| 9999国产精品 | 日韩中文字幕a | 一区二区三区免费网站 | 在线电影中文字幕 | 亚洲精品免费在线观看视频 | 国产成人333kkk | 精品国产亚洲日本 | 国产精品中文字幕在线观看 | 最新中文字幕 | 美女久久久久 | 国产午夜一区二区 | 国产破处视频在线播放 | 亚洲国产中文在线 | 久久久免费高清视频 | 成人亚洲网 | 色婷婷亚洲 | 精品久久久久久久久久久久久久久久 | 国产视频中文字幕在线观看 | 色精品视频 | 黄色精品免费 | 97成人在线观看 | 美女久久久久久久 | 黄色a大片 | 欧美色图30p | 999久久国精品免费观看网站 | 在线免费看片 | 五月婷婷深开心 | 欧美精品久久人人躁人人爽 | 亚州av免费 | 99国产成+人+综合+亚洲 欧美 | 国产精品a久久久久 | 亚洲91中文字幕无线码三区 | 亚洲免费观看在线视频 | 国产99一区视频免费 | 丁香婷婷电影 | 国产一级片免费观看 | av中文字幕第一页 | 亚洲污视频 | 国产精品亚洲a | 91av成人| 亚洲精品免费看 | 国产精品人人做人人爽人人添 | 少妇bbb搡bbbb搡bbbb′ | av品善网 | 丰满少妇久久久 | 久草久草在线 | 69xx视频 | 一区二区国产精品 | 免费在线观看黄色网 | 成人h视频在线 | www.888.av| 日韩在线大片 | 久久99国产精品久久 | 免费看三片 | 国产91区| 天天鲁一鲁摸一摸爽一爽 | 久精品在线观看 | 97超碰在线人人 | 天天干天天做 | 婷婷在线网 | 国产精品免费观看国产网曝瓜 | 国产一区二区三区高清播放 | 午夜久操| 精品久久网 | 成人免费观看视频大全 | 天天综合五月天 | 欧美另类交在线观看 | 婷婷在线观看视频 | 亚洲视频免费 | 欧美久久久一区二区三区 | 国产一区国产二区在线观看 | 国产精品99在线播放 | 久99久精品 | 免费中午字幕无吗 | 国产不卡免费 | 久久福利国产 | 97在线看 | 日韩免费中文 | 美女网站色在线观看 | 久草在线资源免费 | 探花视频在线观看免费版 | 天天精品视频 | 国产精品99蜜臀久久不卡二区 | 天天综合成人 | 黄色的视频 | 91久久国产综合精品女同国语 | 免费黄在线看 | 欧美一区二区三区在线视频观看 | 国产精品久久久免费 | 中文久草 | 欧美精品做受xxx性少妇 | 97av在线视频免费播放 | 国产精品99久久久久久久久久久久 | 激情五月婷婷激情 | 99这里有精品 | 在线有码中文字幕 | 精品久久九九 | 色婷婷久久一区二区 | 欧美一级性生活 | 在线国产一区 | 欧美在线1区 | 欧美 日韩精品 | 99视频这里有精品 | 欧美精选一区二区三区 | 国产福利在线 | 在线观看av片 | 久久在线免费观看视频 | 在线观看视频福利 | 国产精品久久久久久久99 | 亚洲一级电影 | 亚洲精品视频在线观看免费视频 | 亚洲激情视频在线观看 | 久久一区二区三区日韩 | 国产欧美精品在线观看 | 天天色中文 | 亚洲电影一区二区 | 久久成人视屏 | 久草视频免费观 | 久久 亚洲视频 | 91精品综合在线观看 | 国产特级毛片aaaaaa高清 | 久久久久久久久综合 | 999在线观看视频 | 超碰免费av| 在线视频你懂得 | 国产成人精品一区一区一区 | 亚洲精品美女在线观看 | 亚洲 欧洲 国产 精品 | 日本精品在线看 | 福利视频导航网址 | 国产精品一区二区av日韩在线 | 久久综合婷婷综合 | 亚洲伊人色 | 久久www免费人成看片高清 | 91人人爽久久涩噜噜噜 | 精品久久网站 | 91麻豆网站 | 免费福利小视频 | 色婷婷国产在线 | 日韩精品三区四区 | 国产精品自产拍在线观看 | 日本中文字幕电影在线免费观看 | 国产福利av| 精品国产一区二区三区四区在线观看 | 久久亚洲福利 | www在线观看视频 | 日韩午夜av电影 | 在线观看视频亚洲 | 午夜色婷婷 | 日本精品久久久久影院 | 日韩久久精品 | 五月激情亚洲 | 欧美一级片在线 | 国产成人福利片 | 香蕉91视频 | 欧美韩国在线 | 久久久久久久久久久久久久免费看 | 国产成人高清在线 | 亚洲成a人片在线观看网站口工 | 字幕网av| 日韩精品电影在线播放 | 五月天.com|