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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

ArrayList LinkedList与HashMap 实现原理

發布時間:2024/10/12 编程问答 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 ArrayList LinkedList与HashMap 实现原理 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

ArrayList

定義

快速了解ArrayList究竟是什么的一個好方法就是看JDK源碼中對ArrayList類的注釋,大致翻譯如下:

/** * 實現了List的接口的可調整大小的數組。實現了所有可選列表操作,并且允許所有類型的元素,* 包括null。除了實現了List接口,這個類還提供了去動態改變內部用于存儲集合元素的數組尺寸* 的方法。(這個類與Vector類大致相同,除了ArrayList是非線程安全外。)size,isEmpty,* get,set,iterator,和listIterator方法均為常數時間復雜度。add方法的攤還時間復雜度為* 常數級別,這意味著,添加n個元素需要的時間為O(n)。所有其他方法的時間復雜度都是線性級別的。* 常數因子要比LinkedList低。* 每個ArrayList實例都有一個capacity。capacity是用于存儲ArrayList的元素的內部數組的大小。* 它通常至少和ArrayList的大小一樣大。當元素被添加到ArrayList時,它的capacity會自動增長。* 在向一個ArrayList中添加大量元素前,可以使用ensureCapacity方法來增加ArrayList的容量。* 使用這個方法來一次性地使ArrayList內部數組的尺寸增長到我們需要的大小提升性能。需要注意的* 是,這個ArrayList實現是未經同步的。若在多線程環境下并發訪問一個ArrayList實例,并且至少* 一個線程對其作了結構型修改,那么必須在外部做同步。(結構性修改指的是任何添加或刪除了一個或* 多個元素的操作,以及顯式改變內部數組尺寸的操作。set操作不是結構性修改)在外部做同步通常通* 過在一些自然地封裝了ArrayList的對象上做同步來實現。如果不存在這樣的對象,ArrayList應* 使用Collections.synchronizedList方法來包裝。最好在創建時就這么做,以防止對ArrayList* 無意的未同步訪問。(List list = Collections.synchronizedList(new ArrayList(...));)* ArrayList類的iterator()方法以及listIterator()方法返回的迭代器是fail-fast的:* 在iterator被創建后的任何時候,若對list進行了結構性修改(以任何除了通過迭代器自己的* remove方法或add方法的方式),迭代器會拋出一個ConcurrentModificationException異常。* 因此,在遇到并發修改時,迭代器馬上拋出異常,而不是冒著以后可能在不確定的時間發生不確定行為* 的風險繼續。需要注意的是,迭代器的fail-fast行為是不能得到保證的,因為通常來說在未同步并發* 修改面前無法做任何保證。fail-fast迭代器會盡力拋出ConcurrentModificationException異常。* 因此,編寫正確性依賴于這個異常的程序是不對的:fail-fast行為應該僅僅在檢測bugs時被使用。* ArrayList類是Java集合框架中的一員。 */

根據源碼中的注釋,我們了解了ArrayList用來組織一系列同類型的數據對象,支持對數據對象的順序迭代與隨機訪問。我們還了解了ArrayList所支持的操作以及各項操作的時間復雜度。接下來我們來看看這個類實現了哪些接口。

public class ArrayList<E> extends AbstractList<E> implements List<E>, RandomAccess, Cloneable, java.io.Serializable

我們可以看到,它實現了4個接口:List、RandomAccess、Cloneable、Serializable。
官方文檔對List接口的說明如下:List是一個有序的集合類型(也被稱作序列)。使用List接口可以精確控制每個元素被插入的位置,并且可以通過元素在列表中的索引來訪問它。列表允許重復的元素,并且在允許null元素的情況下也允許多個null元素。
List接口定義了以下方法:

ListIterator<E> listIterator(); void add(int i, E element); E remove(int i); E get(int i); E set(int i, E element); int indexOf(Object element);

我們可以看到,add、get等方法都是我們在使用ArrayList時經常用到的。
在ArrayList的源碼注釋中提到了,ArrayList使用Object數組來存儲集合元素。我們來一起看下它的源碼中定義的如下幾個字段:

/** * 默認初始capacity. */ private static final int DEFAULT_CAPACITY = 10; /** * 供空的ArrayList實例使用的空的數組實例 */ private static final Object[] EMPTY_ELEMENTDATA = {}; /** * 供默認大小的空的ArrayList實例使用的空的數組實例。* 我們把它和EMPTY_ELEMENTDATA區分開來,一邊指導當地一個元素被添加時把內部數組尺寸設為* 多少 */ private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {}; /** * 存放ArrayList中的元素的內部數組。* ArrayList的capacity就是這個內部數組的大小。* 任何elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA的空ArrayList在第一個元素* 被添加進來時,其capacity都會被擴大至DEFAULT_CAPACITYhe */ transient Object[] elementData; // non-private to simplify nested class access /** *ArrayList所包含的元素數 */ private int size;

通過以上字段,我們驗證了ArrayList內部確實使用一個Object數組來存儲集合元素。
那么接下來我們看一下ArrayList都有哪些構造器,從而了解ArrayList的構造過程。

ArrayList的構造器

首先我們來看一下我們平時經常使用的ArrayList的無參構造器的源碼:

/** * Constructs an empty list with an initial capacity of ten. */ public ArrayList() { this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA; }

我們可以看到,無參構造器僅僅是把ArrayList實例的elementData字段賦值為DEFAULTCAPACITY_EMPTY_ELEMENTDATA。
接下來,我們再來看一下ArrayList的其他構造器:

/** * Constructs an empty list with the specified initial capacity. * * @param initialCapacity the initial capacity of the list * @throws IllegalArgumentException if the specified initial capacity * is negative */ public ArrayList(int initialCapacity) { if (initialCapacity > 0) { this.elementData = new Object[initialCapacity]; } else if (initialCapacity == 0) { this.elementData = EMPTY_ELEMENTDATA; } else { throw new IllegalArgumentException("Illegal Capacity: "+ initialCapacity); } }/** * Constructs a list containing the elements of the specified * collection, in the order they are returned by the collection's * iterator. * * @param c the collection whose elements are to be placed into this list * @throws NullPointerException if the specified collection is null */ public ArrayList(Collection<? extends E> c) { elementData = c.toArray(); if ((size = elementData.length) != 0) { // c.toArray might (incorrectly) not return Object[] (see 6260652) if (elementData.getClass() != Object[].class) elementData = Arrays.copyOf(elementData, size, Object[].class); } else { // replace with empty array. this.elementData = EMPTY_ELEMENTDATA; } }

通過源碼我們可以看到,第一個構造器指定了ArrayList的初始capacity,然后根據這個初始capacity創建一個相應大小的Object數組。若initialCapacity為0,則將elementData賦值為EMPTY_ELEMENTDATA;若initialCapacity為負數,則拋出一個IllegalArgumentException異常。

第二個構造器則指定一個Collection對象作為參數,從而構造一個含有指定集合對象元素的ArrayList對象。這個構造器首先把elementData實例域賦值為集合對象轉為的數組,而后再判斷傳入的集合對象是否不含有任何元素,若是的話,則將elementData賦值為EMPTY_ELEMENTDATA;若傳入的集合對象至少包含一個元素,則進一步判斷c.toArray方法是否正確返回了Object數組,若不是的話,則需要用Arrays.copyOf方法把elementData的元素類型改變為Object。

現在,我們又了解了ArrayList實例的構建過程,那么接下來我們來通過ArrayList的get、set等方法的源碼來進一步了解它的實現原理。

add方法源碼分析

/** * Appends the specified element to the end of this list. * * @param e element to be appended to this list * @return <tt>true</tt> (as specified by {@link Collection#add}) */ public boolean add(E e) { ensureCapacityInternal(size + 1); // Increments modCount!! elementData[size++] = e; return true; }

我們可以看到,在add方法內部,首先調用了ensureCapacityInternal(size+1),這句的作用有兩個:

  • 保證當前ArrayList實例的capacity足夠大;
  • 增加modCount,modCount的作用是判斷在迭代時是否對ArrayList進行了結構性修改。

然后通過將內部數組下一個索引處的元素設置為給定參數來完成了向ArrayList中添加元素,返回true表示添加成功。

get方法源碼分析

/** * Returns the element at the specified position in this list. * * @param index index of the element to return * @return the element at the specified position in this list * @throws IndexOutOfBoundsException {@inheritDoc} */ public E get(int index) { rangeCheck(index); return elementData(index); }

首先調用了rangeCheck方法來檢查我們傳入的index是否在合法范圍內,然后調用了elementData方法,這個方法的源碼如下:

E elementData(int index) { return (E) elementData[index]; }

set方法源碼分析

/** * Replaces the element at the specified position in this list with * the specified element. * * @param index index of the element to replace * @param element element to be stored at the specified position * @return the element previously at the specified position * @throws IndexOutOfBoundsException {@inheritDoc} */ public E set(int index, E element) { rangeCheck(index); E oldValue = elementData(index); elementData[index] = element; return oldValue; }

我們可以看到,set方法的實現也很簡單,首先檢查給定的索引是否在合法范圍內,若在,則先把該索引處原來的元素存儲在oldValue中,然后把新元素放到該索引處并返回oldValue即可。

LinkedList

定義

LinkedList類源碼中的注釋如下:

/** * 實現了List接口的雙向鏈表。實現了所有可選列表操作,并且可以存儲所有類型的元素,包括null。* 對LinkedList指定索引處的訪問需要順序遍歷整個鏈表,直到到達指定元素。* 注意LinkedList是非同步的。若多線程并發訪問LinkedList對象,并且至少一個線程對其做* 結構性修改,則必須在外部對它進行同步。這通常通過在一些自然封裝了LinkedList的對象上* 同步來實現。若不存在這樣的對象,這個list應使用Collections.synchronizedList來包裝。 * 這最好在創建時完成,以避免意外的非同步訪問。* LinkedList類的iterator()方法以及listIterator()方法返回的迭代器是fail-fast的:* 在iterator被創建后的任何時候,若對list進行了結構性修改(以任何除了通過迭代器自己的* remove方法或add方法的方式),迭代器會拋出一個ConcurrentModificationException異常。* 因此,在遇到并發修改時,迭代器馬上拋出異常,而不是冒著以后可能在不確定的時間發生不確定行為* 的風險繼續。需要注意的是,迭代器的fail-fast行為是不能得到保證的,因為通常來說在未同步并發* 修改面前無法做任何保證。fail-fast迭代器會盡力拋出ConcurrentModificationException異常。* 因此,編寫正確性依賴于這個異常的程序是不對的:fail-fast行為應該僅僅在檢測bugs時被使用。* LinkedList類是Java集合框架中的一員。 */

LinkedList是對鏈表這種數據結構的實現(對鏈表還不太熟悉的小伙伴可以參考深入理解數據結構之鏈表),當我們需要一種支持高效刪除/添加元素的數據結構時,可以考慮使用鏈表。
總的來說,鏈表具有以下兩個優點:

  • 插入及刪除操作的時間復雜度為O(1)
  • 可以動態改變大小

鏈表主要的缺點是:由于其鏈式存儲的特性,鏈表不具備良好的空間局部性,也就是說,鏈表是一種緩存不友好的數據結構。

支持的操作

LinkedList主要支持以下操作:

void addFirst(E element); void addLast(E element); E getFirst(); E getLast(); E removeFirst(); E removeLast(); boolean add(E e) //把元素e添加到鏈表末尾 void add(int index, E element) //在指定索引處添加元素

以上操作除了add(int index, E element)外,時間復雜度均為O(1),而add(int index, E element)的時間復雜度為O(N)。

Node類

在LinkedList類中我們能看到以下幾個字段:

transient int size = 0; /** * 指向頭結點 */ transient Node<E> first; /** * 指向尾結點 */ transient Node<E> last;

我們看到,LinkedList只保存了頭尾節點的引用作為其實例域,接下來我們看一下LinkedList的內部類Node的源碼如下:

private static class Node<E> { E item; Node<E> next; Node<E> prev; Node(Node<E> prev, E element, Node<E> next) { this.item = element; this.next = next; this.prev = prev; } }

每個Node對象的next域指向它的下一個結點,prev域指向它的上一個結點,item為本結點所存儲的數據對象。

addFirst源碼分析

/** * Inserts the specified element at the beginning of this list. * * @param e the element to add */ public void addFirst(E e) { linkFirst(e); }

實際干活的是linkFirst,它的源碼如下:

/** * Links e as first element. */ private void linkFirst(E e) { final Node<E> f = first; final Node<E> newNode = new Node<>(null, e, f); first = newNode; if (f == null) last = newNode; else f.prev = newNode; size++; modCount++; }

首先把頭結點引用存于變量f中,而后創建一個新結點,這個新結點的數據為我們傳入的參數e,prev指針為null,next指針為f。然后把頭結點指針指向新創建的結點newNode。而后判斷f是否為null,若為null,說明之前鏈表中沒有結點,所以last也指向newNode;若f不為null,則把f的prev指針設為newNode。最后還需要把size和modCount都加一,modCount的作用與在ArrayList中的相同。

getFirst方法源碼分析

/** * Returns the first element in this list. * * @return the first element in this list * @throws NoSuchElementException if this list is empty */ public E getFirst() { final Node<E> f = first; if (f == null) throw new NoSuchElementException(); return f.item; }

這個方法的實現很簡單,主需要直接返回first的item域(當first不為null時),若first為null,則拋出NoSuchElementException異常。

removeFirst方法源碼分析

/** * Removes and returns the first element from this list. * * @return the first element from this list * @throws NoSuchElementException if this list is empty */ public E removeFirst() { final Node<E> f = first; if (f == null) throw new NoSuchElementException(); return unlinkFirst(f); }

unlinkFirst方法的源碼如下:

/** * Unlinks non-null first node f. */ private E unlinkFirst(Node<E> f) { // assert f == first && f != null; final E element = f.item; final Node<E> next = f.next; f.item = null; f.next = null; // help GC first = next; if (next == null) last = null; else next.prev = null; size--; modCount++; return element; }

add(int index, E e)方法源碼分析

/** * Inserts the specified element at the specified position in this list. * Shifts the element currently at that position (if any) and any * subsequent elements to the right (adds one to their indices). * * @param index index at which the specified element is to be inserted * @param element element to be inserted * @throws IndexOutOfBoundsException {@inheritDoc} */ public void add(int index, E element) { checkPositionIndex(index); if (index == size) linkLast(element); else linkBefore(element, node(index)); }

這個方法中,首先調用checkPositionIndex方法檢查給定index是否在合法范圍內。然后若index等于size,這說明要在鏈表尾插入元素,直接調用linkLast方法,這個方法的實現與之前介紹的linkFirst類似;若index小于size,則調用linkBefore方法,在index處的Node前插入一個新Node(node(index)會返回index處的Node)。linkBefore方法的源碼如下:

/** * Inserts element e before non-null Node succ. */ void linkBefore(E e, Node<E> succ) { // assert succ != null; final Node<E> pred = succ.prev; final Node<E> newNode = new Node<>(pred, e, succ); succ.prev = newNode; if (pred == null) first = newNode; else pred.next = newNode; size++; modCount++; }

我們可以看到,在知道要在哪個結點前插入一個新結點時,插入操作是很容易的,時間復雜度也只有O(1)。下面我們來看一下node方法是如何獲取指定索引處的Node的:

/** * Returns the (non-null) Node at the specified element index. */ Node<E> node(int index) { // assert isElementIndex(index); if (index < (size >> 1)) { Node<E> x = first; for (int i = 0; i < index; i++) x = x.next; return x; } else { Node<E> x = last; for (int i = size - 1; i > index; i--) x = x.prev; return x; } }

首先判斷index位于鏈表的前半部分還是后半部分,若是前半部分,則從頭結點開始遍歷,否則從尾結點開始遍歷,這樣可以提升效率。我們可以看到,這個方法的時間復雜度為O(N)。

HashMap

Map接口

我們先來看下它的定義:

一個把鍵映射到值的對象被稱作一個映射表對象。映射表不能包含重復的鍵,每個鍵至多可以與一個值關聯。Map接口提供了三個集合視圖:鍵的集合視圖、值的集合視圖以及鍵值對的集合視圖。一個映射表的順序取決于它的集合視圖的迭代器返回元素的順序。一些Map接口的具體實現(比如TreeMap)保證元素有一定的順序,其它一些實現(比如HashMap)則不保證元素在其內部有序。

也就是說,Map接口定義了一個類似于“字典”的規范,讓我們能夠根據鍵快速檢索到它所關聯的值。我們先來看看Map接口定義了哪些方法:

void clear() boolean containsKey(Object key) //判斷是否包含指定鍵 boolean containsValue(Object value) //判斷是否包含指定值 boolean isEmpty() V get(Object key) //返回指定鍵映射的值 V put(K key, V value) //放入指定的鍵值對 V remove(Object key) int size() Set<Map.Entry<K,V>> entrySet() Set<K> keySet() Collection<V> values()

HashMap的定義

HashMap<K, V>是基于哈希表這個數據結構的Map接口具體實現,允許null鍵和null值(最多只允許一個key為null,但允許多個value為null)。這個類與HashTable近似等價,區別在于HashMap不是線程安全的并且允許null鍵和null值。由于基于哈希表實現,所以HashMap內部的元素是無序的。HashMap對與get與put操作的時間復雜度是常數級別的(在散列均勻的前提下)。對HashMap的集合視圖進行迭代所需時間與HashMap的capacity(bucket的數量)加上HashMap的尺寸(鍵值對的數量)成正比。因此,若迭代操作的性能很重要,不要把初始capacity設的過高(不要把load factor設的過低)。

(對散列表(哈希表)這種數據結構還不太熟悉的小伙伴請戳這里散列表的原理與實現)
有兩個因素會影響一個HashMap的性能:intial capacity(初始容量)和load factor(負載因子)。intial capacity就是HashMap對象剛創建時其內部的哈希表的“桶”的數量。load factor等于maxSize / capacity,也就是HashMap所允許的最大鍵值對數與桶數的比值。增大load factor可以節省空間但查找一個元素的時間會增加,減小load factor會占用更多的存儲空間,但是get與put的操作會更快。當HashMap中的鍵值對數量超過了maxSize(即load factor與capacity的乘積),它會再散列,再散列會重建內部數據結構,桶數(capacity)大約會增加到原來的兩
倍。
HashMap默認的load factor大小為0.75,這個數值在時間與空間上做了很好的權衡。當我們清楚自己將要大概存放多少數據時,也可以自定義load factor的大小。
HashMap的常用方法如下:

void clear() boolean containsKey(Object key) boolean containsValue(Object value) V get(Object key) V put(K key, V value) boolean isEmpty() V remove(Object key) int size() Collection<V> values() Set<Map.Entry<K,V>> entrySet() Set<K> keySet()

HashMap的構造器

HashMap有以下幾個構造器:

HashMap() HashMap(int initialCapacity) HashMap(int initialCapacity, float loadFactor) HashMap(Map<? extends K,? extends V> m) //創建一個新的HashMap,用m的數據填充

無參構造器的源碼如下:

/** * Constructs an empty <tt>HashMap</tt> with the default initial capacity * (16) and the default load factor (0.75). */ public HashMap() { this.loadFactor = DEFAULT_LOAD_FACTOR; // all other fields defaulted }

這個構造器把loadFactor域設為DEFAULT_LOAD_FACTOR(0.75),其他域都保持默認值。

我們再來看下第三個構造器的源碼:

/** * Constructs an empty <tt>HashMap</tt> with the specified initial * capacity and load factor. * * @param initialCapacity the initial capacity * @param loadFactor the load factor * @throws IllegalArgumentException if the initial capacity is negative * or the load factor is nonpositive */ public HashMap(int initialCapacity, float loadFactor) { if (initialCapacity < 0) throw new IllegalArgumentException("Illegal initial capacity: " + initialCapacity); if (initialCapacity > MAXIMUM_CAPACITY) initialCapacity = MAXIMUM_CAPACITY; if (loadFactor <= 0 || Float.isNaN(loadFactor)) throw new IllegalArgumentException("Illegal load factor: " + loadFactor); this.loadFactor = loadFactor; this.threshold = tableSizeFor(initialCapacity); }

以上源碼中的threshold即為上面提到的maxSize(loadFactor與capacity的乘積)。tableSizeFor方法會根據給定的initialCapacity返回一個值作為maxSize。

基本實現原理

HashMap是基于拉鏈法處理碰撞的散列表的實現,一個存儲整型元素的HashMap的內部存儲結構如下圖所示:


linked.jpg


我們可以看到,HashMap是采用數組+鏈表實現的,在JDK 1.8中,對HashMap做了進一步優化,引入了紅黑樹。當鏈表的長度大于8時,就會使用紅黑樹來代替鏈表。

put方法源碼分析

在分析put方法前,我們先來看下HashMap的如下字段:

/** * The table, initialized on first use, and resized as * necessary. When allocated, length is always a power of two. * (We also tolerate length zero in some operations to allow * bootstrapping mechanics that are currently not needed.) */ transient Node<K,V>[] table;

table字段是一個Node<K, V>數組,這個數組由鏈表的頭結點組成。我們再來看一下Node<K, V>的定義:

static class Node<K,V> implements Map.Entry<K,V> { final int hash; final K key; V value; Node<K,V> next; Node(int hash, K key, V value, Node<K,V> next) { this.hash = hash; //"桶號",即該Node在數組的索引 this.key = key; this.value = value; this.next = next; } public final K getKey() { return key; } public final V getValue() { return value; } public final String toString() { return key + "=" + value; } public final int hashCode() { return Objects.hashCode(key) ^ Objects.hashCode(value); } public final V setValue(V newValue) { V oldValue = value; value = newValue; return oldValue; } . . . }

Node類的hash域為它在Node數組中的索引,next域為它的下一個Node,key、value分別為保存在Node中的鍵和值。
接下來我們看看put方法的源碼:

public V put(K key, V value) { return putVal(hash(key), key, value, false, true); }

這個方法內部實際上調用了putVal方法來干活,hash方法會返回給定key在HashMap中的桶號(即key所在Node在Node數組中的索引),實際上hash方法的作用是在key的hashCode方法的基礎上進一步增加哈希值的隨機度。putVal方法的源碼如下:

final V putVal(int hash, K key, V value, boolean onlyIfAbsent, boolean evict) { Node<K,V>[] tab; Node<K,V> p; int n, i; //若table為空或table的length為0則需要通過resize方法擴容if ((tab = table) == null || (n = tab.length) == 0) n = (tab = resize()).length; //讓傳入的hash與n-1做與運算從而得到目標Node的索引//若該索引處為null,則直接插入包含了key-value pair的new Node if ((p = tab[i = (n - 1) & hash]) == null) tab[i] = newNode(hash, key, value, null); else { //若索引處不為null,則判斷key是否存在Node<K,V> e; K k; //若key存在,則直接覆蓋valueif (p.hash == hash && ((k = p.key) == key || (key != null && key.equals(k))))e = p; //若key不存在,則判斷table[i]是否為TreeNode else if (p instanceof TreeNode) //若是的話,說明此處為紅黑樹,直接插入key-value paire = ((TreeNode<K,V>)p).putTreeVal(this, tab, hash, key, value);//否則遍歷鏈表 else { for (int binCount = 0; ; ++binCount) { if ((e = p.next) == null) { p.next = newNode(hash, key, value, null); //鏈表長度大于8則轉為紅黑樹 if (binCount >= TREEIFY_THRESHOLD - 1) // -1 for 1st treeifyBin(tab, hash); break; }//若key已經存在則直接覆蓋value if (e.hash == hash && ((k = e.key) == key || (key != null && key.equals(k)))) break; p = e; } } if (e != null) { // existing mapping for key V oldValue = e.value; if (!onlyIfAbsent || oldValue == null) e.value = value; afterNodeAccess(e); return oldValue; } } ++modCount; //若超過maxSize,則擴容if (++size > threshold) resize(); afterNodeInsertion(evict); return null; }

以上代碼的工作過程可以總結為下圖:


put.png


關于HashMap我們還需要知道它的擴容方法resize的時間消耗比較大,因此我們在能夠估計到大致需要存儲的數據量時,應該為其指定一個合適的初始容量。




總結

以上是生活随笔為你收集整理的ArrayList LinkedList与HashMap 实现原理的全部內容,希望文章能夠幫你解決所遇到的問題。

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

欧美精品第一 | 亚欧日韩成人h片 | 中文在线中文a | 网址你懂的在线观看 | 欧美婷婷色 | 不卡的av电影在线观看 | 蜜臀91丨九色丨蝌蚪老版 | 久久精品婷婷 | 国产精品美女久久久久久久 | 国产精品99久久久久久久久 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 国产高清第一页 | 亚洲国产精彩中文乱码av | 超碰在线最新地址 | 亚洲a成人v | 丝袜美女在线 | 国产91九色视频 | 欧美一二三视频 | 91精品国产成人www | 99热这里只有精品国产首页 | 国产精品一区二区 91 | 国产一二区免费视频 | 亚洲精品久久久久久中文传媒 | 狠狠做深爱婷婷综合一区 | 中文字幕区 | 日韩天天综合 | 97超碰福利久久精品 | 丁香视频 | 国产成人精品亚洲 | 九月婷婷色 | 精品福利在线观看 | 日韩精品中文字幕久久臀 | 超碰成人网 | 蜜臀av网址 | 久久精品这里热有精品 | 91成人看片 | 久久国产精品免费视频 | 高清av中文在线字幕观看1 | 日韩精品欧美视频 | 婷婷国产一区二区三区 | 在线国产日本 | 免费在线观看成年人视频 | 久久精品美女视频网站 | 久草精品电影 | 精品国产精品久久一区免费式 | 91热视频在线观看 | 久久久三级视频 | 欧美在线观看小视频 | 天天色天天射天天干 | 久久高清毛片 | 免费视频91 | 九九久久精品视频 | 亚洲午夜久久久久久久久电影网 | a在线播放 | 欧美成年网站 | 免费看麻豆 | 亚洲视频 中文字幕 | 婷婷九九| 久久综合给合久久狠狠色 | 天天se天天cao天天干 | .国产精品成人自产拍在线观看6 | se婷婷 | 国产福利免费在线观看 | 伊人久久电影网 | 亚洲国产影院av久久久久 | 一区二区三区四区精品视频 | 日本xxxx.com | 国产精品区免费视频 | 精品免费99久久 | 91人人视频在线观看 | 蜜桃av人人夜夜澡人人爽 | 成人h视频 | 欧美影片| 综合成人在线 | 四虎在线视频免费观看 | 精品视频久久 | 最新av在线播放 | 91av综合| 美女视频国产 | 这里只有精彩视频 | 丁香婷婷激情国产高清秒播 | 国产剧情一区二区 | 视频在线观看入口黄最新永久免费国产 | 亚洲欧美视频网站 | 久久精品99国产精品 | 日韩二区在线观看 | 91亚洲永久精品 | 99久久99久国产黄毛片 | 中文在线资源 | 久久久久久综合网天天 | 久久久久久网站 | 久久精品免费播放 | 久久视频在线免费观看 | 欧美一区成人 | 伊香蕉大综综综合久久啪 | www.色在线| 91夜夜夜| 在线免费观看麻豆视频 | 欧美另类美少妇69xxxx | 欧美日韩高清一区 | 亚洲视频999| 天天干天天做 | 91精品第一页| av片中文字幕 | 999一区二区三区 | 国产99久久久精品视频 | 日韩大片在线看 | 日韩免费福利 | 国产成人av电影在线 | 国产精品毛片一区视频播不卡 | 日本久久成人中文字幕电影 | 国产在线视频一区二区 | 最近中文字幕第一页 | 中文字幕最新精品 | 99精品欧美一区二区蜜桃免费 | 中文字幕黄色 | 97综合视频 | 日本黄色大片免费看 | 成人免费在线播放视频 | 久久精品在线 | 在线看免费| 99资源网| 日韩精品在线看 | 九草在线视频 | 狠狠干2018 | 国产精品美女久久久久久久 | 97人人精品 | 国产精品久久一区二区无卡 | 干天天 | 国产在线高清精品 | 欧美日韩视频在线播放 | 九九热国产视频 | 久久不卡国产精品一区二区 | 日韩av成人在线观看 | av免费网站观看 | 在线日韩中文字幕 | 在线播放你懂 | 探花视频在线观看免费版 | 国产二区精品 | www.色国产 | 在线亚洲观看 | 日韩欧美视频在线 | 在线观看va | 91精品在线视频观看 | 五月天,com | 91中文视频 | 99 视频 高清 | 亚洲人天堂 | 狠狠干狠狠操 | 国产精品精| 国产精品综合久久久久 | 夜夜婷婷 | 国产免费大片 | 激情欧美日韩一区二区 | 999久久久久 | 国产日韩精品一区二区在线观看播放 | 亚洲精品大片www | 久久成人18免费网站 | 在线免费视频 你懂得 | 婷婷天天色 | 国产精品一区二区在线观看 | 日韩精品一区二区三区水蜜桃 | 中文字幕在线播放一区 | 婷婷久久一区 | 一区二区三区日韩视频在线观看 | 成人免费在线观看入口 | 激情五月视频 | 国产成人61精品免费看片 | 日本一区二区不卡高清 | 久插视频 | 91人人在线 | 国产午夜在线 | 国产在线精品播放 | 激情xxxx| 午夜91视频| 天堂在线免费视频 | 免费视频一区二区 | 亚洲黄色一级电影 | 成年人国产视频 | 最新av中文字幕 | 91精品国产三级a在线观看 | 欧洲激情综合 | 十八岁免进欧美 | 日本xxxx裸体xxxx17| 天天射成人| 久久久久亚洲a | 国产亚洲精品美女久久 | 精品久久福利 | 久久官网 | 国产成人三级在线观看 | 亚洲三级网站 | 99一区二区三区 | 日韩超碰在线 | 成人免费一区二区三区在线观看 | 亚洲精品在线观看av | 欧美在线观看禁18 | 91av视频免费观看 | 激情影音| 亚洲最新毛片 | 99这里精品| 国产精品手机在线 | 97精品国产| 久草网在线| 色综合小说 | 久久久久久久久免费 | 激情小说久久 | 久久午夜影院 | 五月天激情综合 | 最近中文字幕国语免费av | 欧美一级特黄aaaaaa大片在线观看 | 国产精品一区二区久久精品 | 色噜噜噜 | 免费视频网| 成人免费视频在线观看 | 欧美亚洲xxx | 五月天色网站 | 久久永久免费 | 国产精品国产三级国产专区53 | 日本三级国产 | 91九色在线播放 | 色视频 在线 | 日日夜夜人人精品 | 中国一级片在线观看 | 国产精品12| www.亚洲黄色| 91av在 | 久久精品99国产精品酒店日本 | 成人网444ppp | 91精品一区在线观看 | 午夜精品久久久99热福利 | 日日夜夜精品 | 亚洲精品在线观看网站 | 人人看人人做人人澡 | 国产明星视频三级a三级点| 黄色三级免费看 | adn—256中文在线观看 | 成人在线观看免费视频 | 久久久久9999亚洲精品 | 色网免费观看 | 91精品老司机久久一区啪 | 成人国产精品免费 | 久操中文字幕在线观看 | 天堂视频一区 | 黄色av电影网 | 91av在| 婷婷视频导航 | 欧美另类xxx | 亚洲欧美日韩一二三区 | 在线精品亚洲一区二区 | 青青射| 91福利小视频 | 国产国语在线 | 91av视频在线播放 | 又大又硬又黄又爽视频在线观看 | 91黄色免费看 | 国产 欧美 在线 | 国产亚洲精品美女 | 天天天干天天射天天天操 | 国产成人精品av久久 | 男女免费视频观看 | 在线免费性生活片 | 九九久久久久久久久激情 | 国产精品久久久久9999吃药 | 国产亚洲精品久久久久秋 | 丰满少妇麻豆av | 中文av在线免费观看 | 9热精品 | 一级理论片在线观看 | 精品九九九| 在线黄色国产 | 超碰在线亚洲 | 99r在线播放 | 中文字幕xxxx | 日韩免费在线网站 | 91九色视频在线观看 | 日韩av片无码一区二区不卡电影 | 久热电影 | 操操日日 | 九9热这里真品2 | 日韩精品久久一区二区三区 | 天天插日日射 | 91精彩在线视频 | 亚洲成人资源在线观看 | 男女激情网址 | 999视频在线播放 | 91成人精品一区在线播放 | 亚洲精品视频中文字幕 | 依人成人综合网 | 日韩av电影国产 | 亚洲精品2区| 色婷婷综合视频在线观看 | 亚洲最大免费成人网 | 又黄又爽又刺激视频 | 国产无遮挡又黄又爽在线观看 | 成人影片免费 | av不卡网站 | 亚洲精品乱码白浆高清久久久久久 | 欧美男女爱爱视频 | 伊人中文字幕在线 | 日韩 精品 一区 国产 麻豆 | 亚洲高清在线精品 | 亚洲综合色网站 | 91精品网站在线观看 | 91精品资源 | 成人国产精品久久久春色 | 日韩久久精品一区二区三区下载 | 人人插人人爱 | 亚洲aⅴ在线 | 亚洲综合在 | 韩国av免费| 免费观看一区二区三区视频 | 亚洲污视频 | 综合在线亚洲 | 久久久久久免费视频 | 99精品免费久久久久久日本 | 国产精品视频地址 | 日韩在线字幕 | 韩国视频一区二区三区 | 五月天综合色 | 久久66热这里只有精品 | 在线色亚洲 | 911香蕉 | 国产精品av电影 | 亚洲国产午夜精品 | 成年人视频免费在线播放 | 婷婷国产在线 | 极品美女被弄高潮视频网站 | 国产高清不卡 | 99re亚洲国产精品 | 久草精品视频在线播放 | 黄色片亚洲| 免费看毛片在线 | av在线精品 | 亚洲精品国产第一综合99久久 | 天天爱天天操天天爽 | 九色porny真实丨国产18 | 久久综合五月天婷婷伊人 | 国产剧情在线一区 | 免费在线观看一区二区三区 | 欧美日韩国产综合网 | 夜夜躁日日躁狠狠久久88av | 婷婷久久亚洲 | 国产男女爽爽爽免费视频 | 五月开心激情 | 夜夜操网站 | 一区二区精品视频 | 亚州av网站 | 成年人视频免费在线 | 国产高清视频 | 99久久久| 中文字幕二区 | 97超碰资源网 | 久久久久久久久久免费视频 | 天天干婷婷 | 免费在线观看av不卡 | 在线观看成人 | 国产在线p| 国产精品 日本 | 精品网站999www| 久久久wwww| 欧美日韩久久久 | 激情影院在线观看 | 综合在线色 | 免费观看一区 | 五月婷婷一区二区三区 | 亚洲一区二区观看 | 人人澡人摸人人添学生av | 亚洲高清不卡av | 永久免费在线 | 性色xxxxhd| 国产精品不卡视频 | 国产精品视屏 | 一级片黄色片网站 | 国产一级视频免费看 | 欧美性大胆 | 亚洲国产中文字幕在线视频综合 | 国产在线精品一区 | 亚洲精品国偷自产在线91正片 | 日韩精品免费在线播放 | 日日干网 | 国际精品久久久 | 久久a久久 | 97夜夜澡人人双人人人喊 | 91在线网站| 日本中文字幕在线播放 | 成人在线黄色电影 | 有码一区二区三区 | 操操日日 | 亚洲国产一二三 | 天天艹天天操 | 日韩av电影网站在线观看 | 日韩三区在线 | 久久婷婷影视 | 国内精品久久久久影院优 | 视频在线观看一区 | 黄色片毛片 | 色com网 | 亚洲精品国产精品久久99 | 美女视频黄免费 | 亚洲精品中文在线资源 | a黄色片 | 五月av在线| 久久久久久久久久久影视 | 中文字幕亚洲在线观看 | 亚洲一区二区黄色 | 久久视频 | 免费在线观看不卡av | av天天澡天天爽天天av | 免费av成人在线 | 亚洲 欧美日韩 国产 中文 | 久久伦理 | 欧美另类一二三四区 | 久久久久日本精品一区二区三区 | 精品成人a区在线观看 | 亚洲在线a| 国产 日韩 欧美 中文 在线播放 | 在线观看色网站 | 人人干人人干人人干 | 欧美地下肉体性派对 | 在线观看中文字幕网站 | 久久久69| 国产精品成人自产拍在线观看 | 国产精品久久一卡二卡 | 久久一区二区免费视频 | 欧美激情精品久久久 | 三级黄色免费 | 国产视频一区精品 | 日韩中文字幕在线看 | 日本精品久久久一区二区三区 | 91人人爽人人爽人人精88v | 欧美高清成人 | 99精品乱码国产在线观看 | 99精品视频免费观看 | 日韩高清一区二区 | 超碰成人网 | 美女精品久久久 | 久久久激情网 | 欧美大片在线看免费观看 | 婷婷四房综合激情五月 | 国内一级片在线观看 | 天天综合网 天天 | 国产一区二区午夜 | 在线中文日韩 | 国产精品美女久久久久久免费 | 综合久久久久久 | 深爱激情婷婷网 | 久久婷婷丁香 | 国产私拍在线 | 日韩免费一区 | 久久久久久久久亚洲精品 | 麻豆视频www | 日韩欧美69 | 亚洲天堂视频在线 | av在线一| 综合网av| 四虎在线永久免费观看 | 精品视频在线免费观看 | 91黄站| www.国产在线观看 | 四虎国产视频 | 中文字幕电影一区 | 日日夜夜人人精品 | 91亚色免费视频 | 色综合久久综合中文综合网 | jizz欧美性9 国产一区高清在线观看 | 天天干天天操天天干 | 精选久久 | 久久刺激视频 | 97人人爽人人| 丰满少妇麻豆av | 国产色在线视频 | 午夜精品久久久久久久99无限制 | 免费色网 | 亚洲欧美观看 | 99精品在线免费观看 | 欧美性爽爽 | 国产白浆在线观看 | 九九九在线观看视频 | 欧美va电影| a级片韩国 | 91福利在线导航 | 在线观看www视频 | 免费h漫在线观看 | 看片在线亚洲 | av色综合网| 精品在线视频一区二区三区 | 久久精品国产免费观看 | 亚洲精品视频网站在线观看 | 在线观看午夜av | 日韩精品在线免费观看 | 日韩av播放在线 | av电影不卡在线 | 国产精品人人做人人爽人人添 | 久久国产免费 | 久久久久亚洲精品中文字幕 | 日日日操操 | 精品视频9999 | 丁香婷婷色综合亚洲电影 | 久久99久久99精品中文字幕 | 伊人影院得得 | 亚洲激情在线 | 亚洲九九| 国产精品对白一区二区三区 | 91最新视频在线观看 | 婷婷在线视频 | 狠狠的操你 | 国产在线最新 | 日韩黄色大片在线观看 | 欧美91视频 | 欧美日韩国产区 | 色视频在线 | 日韩中文字幕免费电影 | 亚洲一区av | 日韩精品一区二区在线视频 | 中文字幕一区二区三区四区视频 | 免费观看十分钟 | 中文字幕在线观看91 | 天天爽天天摸 | 久久亚洲综合国产精品99麻豆的功能介绍 | 成人午夜剧场在线观看 | 国产日本在线观看 | 国产不卡视频在线播放 | 一区二区中文字幕在线播放 | 一区在线免费观看 | 亚洲成人av在线播放 | 亚洲人视频在线 | 西西www4444大胆视频 | 国产精品18久久久 | 日韩欧美精品免费 | 精品久久精品久久 | 欧美一区日韩一区 | 日韩免费av片| 成人在线免费观看网站 | 国产资源精品 | 在线天堂中文www视软件 | 18久久久| 69精品 | 色综合久久精品 | www.亚洲精品 | 国产精品中文字幕在线 | 国产精品成人aaaaa网站 | 久久经典国产 | 米奇影视7777 | 9797在线看片亚洲精品 | 色天天中文 | 五月天久久久久久 | 麻豆传媒一区二区 | 五月婷丁香网 | 天天·日日日干 | 欧美午夜精品久久久久久孕妇 | 丁香高清视频在线看看 | 五月婷婷综合在线视频 | 天天色天天综合网 | 91桃色免费视频 | 欧美激情综合色综合啪啪五月 | 91精品在线免费观看视频 | 成人在线免费观看网站 | 亚洲综合色丁香婷婷六月图片 | 91传媒视频在线观看 | 欧美精品黑人性xxxx | 狠狠干 狠狠操 | 日韩av中文| 一级黄色片在线免费观看 | 婷婷香蕉| 91高清免费在线观看 | 99久久综合狠狠综合久久 | 久久综合色婷婷 | 久久久免费| 黄色影院在线播放 | 久久香蕉国产 | 国产成人av在线影院 | 精品久久久久久久久久岛国gif | 久久免费精品一区二区三区 | 色婷婷在线观看视频 | 人人插人人射 | 久久99精品热在线观看 | 男女激情片在线观看 | 97人人艹| 最新国产精品亚洲 | 欧美日韩免费在线观看视频 | 青青河边草免费观看 | 黄网站免费久久 | www看片网站| 狠狠色噜噜狠狠狠狠2021天天 | 欧美男男激情videos | 国产a精品 | 天操夜夜操 | 亚洲成人精品久久 | 丁香免费视频 | 黄色在线免费观看网址 | 天天综合网入口 | 亚洲精品国产品国语在线 | 五月婷婷综合久久 | 亚洲专区在线视频 | 色天天综合久久久久综合片 | 欧美国产亚洲精品久久久8v | 国产精品久久久一区二区 | 日本黄区免费视频观看 | 国产淫片免费看 | 久久视频免费在线观看 | 一本一道波多野毛片中文在线 | 天天骚夜夜操 | 国产一线在线 | 狠狠色丁香婷婷综合久久片 | 中文字幕免费在线看 | 深爱激情五月婷婷 | 欧美极度另类性三渗透 | 麻豆94tv免费版 | 亚洲一级在线观看 | 国产精品一区二区三区99 | 片网站 | 国产一区观看 | 在线观看视频中文字幕 | av电影一区二区三区 | 国产视频精品免费播放 | 国产99免费视频 | 国产 日韩 欧美 中文 在线播放 | 在线视频一区二区 | 亚洲91网站 | 久久午夜羞羞影院 | 色在线国产 | 久久精品老司机 | 973理论片235影院9 | 91视频在线看 | 日本在线观看中文字幕 | 婷婷射五月 | 久久精品观看 | 日本黄区免费视频观看 | 手机在线永久免费观看av片 | 国产一级片观看 | 韩国三级av在线 | 日韩av资源站 | 国产麻豆剧传媒免费观看 | 欧美综合国产 | 国产v在线播放 | 亚洲精品色 | 91香蕉视频黄 | 国产视频97| 久久久精品免费看 | 又黄又刺激 | 亚欧洲精品视频在线观看 | 欧美日韩中文国产一区发布 | 免费毛片一区二区三区久久久 | 欧美老人xxxx18 | 中文字幕久久精品 | 日韩丝袜在线观看 | 在线观看aaa| 亚洲国产中文字幕在线观看 | 麻豆久久久久 | 五月天激情综合网 | 在线免费黄色av | 丰满少妇在线观看资源站 | 人人干人人添 | 麻豆传媒视频在线播放 | 欧美大片mv免费 | 国产一级淫片在线观看 | 日韩精品欧美专区 | 亚洲激情网站免费观看 | 午夜影院一级片 | 99色在线观看 | 久久精品视频网站 | 一级一级一片免费 | 91福利社在线观看 | 日本精品小视频 | 中文字幕在线日亚洲9 | 亚洲黄色网络 | 四虎永久免费 | 国产午夜不卡 | 91精品啪 | 91丨九色丨丝袜 | 91久久久久久久 | 日韩激情在线视频 | 香蕉久久久久久久 | 国内揄拍国内精品 | 日本三级香港三级人妇99 | 人人超碰97 | 中文字幕乱码电影 | 国产欧美精品xxxx另类 | 国产精品久久久久久久久久 | 国产精品99在线播放 | 亚洲国产av精品毛片鲁大师 | 成人av免费在线 | 久久看片网 | 国产裸体视频网站 | 天天想夜夜操 | 亚洲国产成人精品在线观看 | 视频在线一区二区三区 | 伊人五月天.com | 午夜精品福利一区二区三区蜜桃 | 日韩在线播放视频 | 色噜噜在线观看 | 久久一区二区三区日韩 | 丁香激情综合久久伊人久久 | www五月天com| 国内精品视频在线 | 午夜三级毛片 | 日韩中文免费视频 | 亚洲成人av电影 | 黄色一级影院 | 视频一区二区免费 | 中文字幕一区二区在线观看 | 天天色天天操天天爽 | 最近中文字幕免费av | 久久乐九色婷婷综合色狠狠182 | 天天操网 | 国产91精品一区二区绿帽 | 精品国产乱码久久久久久天美 | 国产大陆亚洲精品国产 | 91夜夜夜| 视频福利在线观看 | 香蕉影视 | 久热av在线 | 亚洲撸撸 | 97热久久免费频精品99 | 亚洲精品乱码久久久久久按摩 | 网站在线观看日韩 | 久久久久免费精品国产 | 免费又黄又爽的视频 | 免费国产视频 | 国产精品密入口果冻 | 久久99网站 | 欧美一区二区三区不卡 | 黄色免费观看视频 | 国产精品高清一区二区三区 | 欧美性色19p | www黄在线 | 激情一区二区三区欧美 | 精品视频国产 | 国产成人亚洲在线观看 | 九九亚洲精品 | 99综合电影在线视频 | 久久久免费精品视频 | 在线观看成人网 | 97人人添人澡人人爽超碰动图 | 欧美少妇影院 | 嫩嫩影院理论片 | 国产一区二区不卡视频 | 色综合夜色一区 | 激情综合色综合久久综合 | www.天天射.com | 久久精久久精 | 五月天婷婷在线播放 | 国产在线一区二区三区播放 | 在线观看免费高清视频大全追剧 | 久久夜夜夜 | 日韩精品在线免费播放 | 91人人揉日日捏人人看 | 精品中文字幕在线播放 | 国产一级做a | a级片网站 | 久久久精品99| 国产精品99精品久久免费 | 久久人91精品久久久久久不卡 | 亚洲成人av电影在线 | www在线观看视频 | 免费性网站 | 欧美黑人xxxx猛性大交 | 狠狠躁夜夜a产精品视频 | 国内精品久久久久影院男同志 | 欧美一级黄色网 | 91色影院 | 精品国产伦一区二区三区观看方式 | 在线国产中文字幕 | 99r在线视频 | 91传媒在线观看 | 色91在线视频 | 国产精品欧美一区二区 | 色婷婷福利视频 | 国产福利一区二区三区视频 | 99免费在线观看视频 | 日韩高清免费观看 | av官网在线| 精品国产电影一区 | 免费一级日韩欧美性大片 | www.av在线播放 | 日本精品久久久久 | 午夜久久久久久久久 | 西西4444www大胆无视频 | 日韩国产精品久久久久久亚洲 | 国内精品99 | 国产成人精品不卡 | 九九热有精品 | 精品999在线观看 | 日日干日日 | 精品国产乱码久久久久久浪潮 | avsex| 国产一级大片免费看 | 亚洲精品久久久蜜臀下载官网 | 欧美 激情 国产 91 在线 | 日韩午夜电影 | 亚洲 欧美 变态 国产 另类 | 国产精品久久久久一区二区三区共 | 免费观看国产成人 | 亚洲精品乱码久久久一二三 | 久久久精品一区二区 | 九九九热精品 | 高清日韩一区二区 | 国外av在线| 波多野结衣久久资源 | 亚洲经典中文字幕 | 网站在线观看你们懂的 | 一级片观看 | 99中文视频在线 | 插插插色综合 | 精品国产一区二区三区久久影院 | 激情婷婷av | 亚洲色图 校园春色 | 国产视频欧美视频 | 日韩高清dvd | 欧美激情精品久久久久 | 天天操 夜夜操 | 国产精品电影一区 | 在线观看日韩av | 色综合久久久久综合体 | 欧美久久久久久久久中文字幕 | 国产精品网站 | 亚洲国产网站 | 在线观看一级 | 欧美福利片在线观看 | 日韩成人免费在线 | 欧美日韩国产在线 | 亚洲日本欧美在线 | 国产精品手机在线观看 | 激情伊人五月天 | 亚洲精品乱码久久 | 日韩av高清在线观看 | 日韩高清网站 | 久久免费视频5 | 色婷丁香 | 精品天堂av | 国产成人精品a | 国产专区第一页 | 狠狠躁夜夜a产精品视频 | 免费国产在线精品 | www.99在线观看 | av在线之家电影网站 | 最近2019好看的中文字幕免费 | av电影一区 | 91pony九色丨交换 | 久久免费视频一区 | 日韩精品国产一区 | 看全黄大色黄大片 | 久草视频在线播放 | 欧美日韩不卡在线观看 | 精品一二区 | 国产做aⅴ在线视频播放 | 免费看v片 | av短片在线观看 | 香蕉视频久久久 | 麻豆视频国产 | 亚洲人人av | 国产一区二区三区在线免费观看 | 久久最新 | 成人毛片a | 91精品中文字幕 | 手机成人免费视频 | 亚洲日日夜夜 | 中文不卡视频 | 999久久a精品合区久久久 | 亚洲高清在线观看视频 | 亚洲小视频在线 | 久久免费视频国产 | 国内精品久久天天躁人人爽 | 在线观看一 | 西西444www| 国产不卡免费 | 韩国在线一区 | 一区二区中文字幕在线观看 | 亚洲精品www. | 99re在线视频观看 | 在线观看91视频 | 日本最新中文字幕 | 久久久久久久久久久久久9999 | 日韩欧美视频免费在线观看 | 91免费在线看片 | 亚洲女欲精品久久久久久久18 | 91大神精品视频在线观看 | 99精品一区二区三区 | 99中文字幕视频 | 91久久精品一区二区二区 | 久久在线观看视频 | 日韩精品在线视频 | 久久国产精品久久精品国产演员表 | 久久视频在线观看中文字幕 | 久久99国产精品免费网站 | 91视频麻豆| 国产白浆在线观看 | 干综合网 | 久久精品亚洲 | 黄色在线免费观看网站 | 日本公乱妇视频 | 成人黄色电影在线播放 | 亚洲一级片av | 黄色在线观看www | 天堂va在线高清一区 | 日韩一级片网址 | 国产精品女人网站 | 91亚洲国产 | 色网站国产精品 | 婷婷丁香导航 | 日韩动态视频 | 久久www免费人成看片高清 | 久久精品国产一区二区三 | 欧美va天堂在线电影 | 国产精品专区h在线观看 | 激情五月婷婷综合网 | 2022中文字幕在线观看 | 日本久久中文字幕 | 日本黄色特级片 | 亚洲天堂网在线视频观看 | 国产精品岛国久久久久久久久红粉 | 亚洲精品av中文字幕在线在线 | 国产资源在线播放 | 99精品国产99久久久久久福利 | 久草视频免费看 | 午夜精品成人一区二区三区 | 久草精品视频在线看网站免费 | 久久av网 | 蜜臀久久99精品久久久无需会员 | 久久久亚洲精华液 | 亚洲国产精品女人久久久 | 亚洲午夜精品在线观看 | 天天草天天干 | 欧美9999 | 亚洲精品美女久久久 | 日韩精品一区二区三区丰满 | 狠狠操操操 | 狠狠色狠狠综合久久 | 青青草久草在线 | 欧美精品二| 久久久性 | 天天天天天天天天操 | 中文字幕在线看视频 | 黄色在线观看网站 | 婷婷色网| 亚洲欧美国产精品 | 91大神在线观看视频 | 日本三级香港三级人妇99 | 免费在线中文字幕 | 久久99国产精品自在自在app | 五月开心综合 | www.久久免费| 国产精品一区免费在线观看 | 久久伊人爱 | 亚洲视频 在线观看 | 亚洲国产视频直播 | 亚洲伊人成综合网 | 国产精品剧情在线亚洲 | 狠狠色丁香婷婷综合基地 | 日日碰狠狠添天天爽超碰97久久 | 久久久久97国产 | 日韩影视在线观看 | 天天天色综合 | 九九久久成人 | 欧美日韩国产页 | 午夜视频在线观看一区二区 | 欧美精品在线免费 | av免费网 | 日日夜夜狠狠干 | 人人搞人人干 | 国产精品99久久久久久武松影视 | 黄色成人影视 | 97超碰色偷偷 | 精品国产aⅴ麻豆 | 91亚洲成人 | 丁香婷婷激情网 | 欧美另类一二三四区 | 精品国产久 | 中文字幕在线观看你懂的 | 伊人亚洲综合 | 日日躁夜夜躁xxxxaaaa | 色婷婷激情综合 | 国产在线专区 | 精品福利片| 一区二区丝袜 | 日日干综合| 日韩视频一区二区三区在线播放免费观看 | 久草在线免 | 国产99精品在线观看 | 久久久香蕉视频 | 久久综合毛片 | 天天天天天天天操 | 成人黄大片视频在线观看 | 福利在线看片 | 久久一区二区三区日韩 | 在线观看成人av | 久久久久综合 | 欧美在线18 | 久久极品 | 亚洲午夜精品电影 | 中文字幕在线观看三区 | 波多野结衣在线播放视频 | 国产精品网在线观看 | 色综合天天射 | 伊人va| 日日夜夜添 | 999久久久国产精品 高清av免费观看 | 精品久久一区二区三区 |