日韩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 实现原理的全部內容,希望文章能夠幫你解決所遇到的問題。

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

在线综合 亚洲 欧美在线视频 | 综合色伊人 | 亚洲黄污| 2019中文字幕网站 | 日韩精品一区二区三区免费观看 | 天天操天天爽天天干 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 久久免费99 | 精品视频成人 | 九九精品在线观看 | 国产成人久久久77777 | 99精品国产一区二区三区不卡 | 天堂va欧美va亚洲va老司机 | 久久成电影 | 又黄又爽又无遮挡的视频 | 亚洲精品网页 | 亚洲资源在线观看 | 成人日批视频 | 色国产精品一区在线观看 | 婷婷五天天在线视频 | 国产黄色片一级三级 | 在线观看麻豆av | 中文字幕第 | 日韩在线一级 | 手机成人在线 | 成人aⅴ视频 | 国产成人一区三区 | 国产麻豆视频网站 | 在线免费观看黄色大片 | 精品视频在线免费 | 欧美国产高清 | 在线观看你懂的网站 | 精品亚洲网 | 国产精品婷婷 | 国产又粗又长又硬免费视频 | 国产一区二区网址 | 成人免费在线观看电影 | 亚洲婷婷在线 | 欧美无极色 | 久久9视频| 国产视频一区在线 | 国产精品a级 | 91视频链接 | 激情视频免费在线观看 | 午夜国产福利视频 | 99精品在线观看 | 亚洲国产一区av | 高清视频一区二区三区 | 超碰人人干人人 | 午夜久久影视 | 日日干 天天干 | 久草精品视频在线播放 | 国产手机av | 伊人国产女 | 欧洲一区二区三区精品 | 国产成人av | 永久中文字幕 | 福利一区二区 | av高清网站在线观看 | 天天操天天射天天爱 | 香蕉久久久久久av成人 | 91九色蝌蚪国产 | 久久久久久久久久国产精品 | 亚州精品天堂中文字幕 | 97精品一区| 成 人 黄 色视频免费播放 | 中文字幕精品一区久久久久 | 欧美日韩在线精品 | 99精品在线播放 | 国产精品一区二区三区在线看 | 国产精品久久二区 | 日韩精品一区二区三区免费观看 | 国内精品视频在线播放 | 国产亚洲成人网 | 99热精品国产一区二区在线观看 | 人人舔人人 | 欧美成人久久 | 性色xxxxhd| 中文字幕永久免费 | 午夜免费福利视频 | 亚洲人成在线电影 | 欧美精品久久久久久久亚洲调教 | 国产一区二区网址 | 91精品啪在线观看国产线免费 | 中文字幕在线观看一区 | 欧美一区二区三区激情视频 | 91.麻豆视频 | 国产在线欧美 | 日本一区二区免费在线观看 | 四虎成人精品永久免费av | 免费看网站在线 | 99精品视频在线观看视频 | 中文视频一区二区 | 91福利试看 | 国产精品久久久久四虎 | 亚洲最新在线 | 色综合天天干 | 一区二区三区免费在线 | 91精选在线| 日本丰满少妇免费一区 | 亚洲激情| 91精品导航 | 久久a免费视频 | 中文字幕资源网 国产 | 99re在线视频观看 | 国产精品高清一区二区三区 | 日韩免费一区二区三区 | 99riav1国产精品视频 | 日本精油按摩3 | 91一区二区三区久久久久国产乱 | 玖玖精品视频 | 黄色大片日本免费大片 | 婷婷5月色 | www.午夜色.com | 麻豆视频免费入口 | 综合婷婷丁香 | 少妇高潮流白浆在线观看 | 久久久免费看片 | 亚洲一区二区三区四区在线视频 | 99中文在线 | 久精品视频在线 | 成人cosplay福利网站 | 狠狠操操网 | 精品av在线播放 | 在线观看第一页 | 国产小视频网站 | 亚洲国产一区二区精品专区 | 久久国产精品免费视频 | 婷婷在线不卡 | 久久久久久久久久久黄色 | 国产精品 中文在线 | 日韩午夜网站 | 在线中文字幕一区二区 | 欧美少妇影院 | 日本不卡123 | 开心激情婷婷 | 日本激情视频中文字幕 | 国产高清精品在线观看 | 人人爱人人舔 | 亚洲综合视频在线观看 | 九九在线视频免费观看 | 不卡的av电影 | 国产精品一区二区三区免费视频 | 天天干夜夜夜操天 | 久久综合操 | 亚洲国产av精品毛片鲁大师 | 国产最新网站 | 国产精品久久一区二区三区不卡 | 久久女教师 | 永久免费毛片在线观看 | 婷婷精品国产欧美精品亚洲人人爽 | 中文字幕视频网站 | 伊人中文字幕在线 | 天天操夜夜摸 | www.69xx | 亚洲国产三级 | 亚洲婷婷在线视频 | 国产在线久草 | 国产成视频在线观看 | 婷婷日日 | 久久免费电影 | 久久久久久久久久久久国产精品 | 精品视频专区 | 狠狠操导航| 欧美午夜理伦三级在线观看 | 亚洲美女精品区人人人人 | 国产亚洲精品久久久久久电影 | 免费日韩高清 | 婷婷av资源| 久久综合干 | 久精品视频免费观看2 | 色综合天天综合 | av一区二区三区在线 | 中文字幕精品在线 | 一区二区精品在线 | 欧美日韩国产精品一区二区亚洲 | 正在播放国产精品 | 探花系列在线 | 精品欧美一区二区三区久久久 | 天天综合人人 | 日韩高清在线一区二区三区 | 亚洲成人精品在线观看 | 99精品色| 国产精品视频大全 | www.久草视频 | 一二三区在线 | 日日日干 | 欧美国产91 | 成人免费共享视频 | 在线不卡视频 | 久久小视频 | 免费精品在线观看 | 亚洲精品456在线播放乱码 | 欧美a级成人淫片免费看 | 97碰视频| 亚洲美女免费精品视频在线观看 | 激情狠狠干 | 综合久久久久久久 | 亚洲天堂在线观看完整版 | 亚洲精品在线视频 | 国产一级片免费播放 | 欧美日韩一级视频 | 免费色黄 | 国产精品一区二区白浆 | 久久久免费看片 | 国产美女被啪进深处喷白浆视频 | 亚洲综合色av | 伊人伊成久久人综合网站 | 欧美黄色特级片 | 精品在线观看国产 | 丁香六月婷婷开心婷婷网 | 中文字幕日本在线观看 | 国产91免费看 | 国产伦理一区二区 | 国产一级黄 | 国产伦精品一区二区三区免费 | 天天操天天摸天天爽 | 99色免费 | 欧美在线视频免费 | 久久久久国产精品一区 | 天堂在线免费视频 | 制服丝袜亚洲 | 免费a级毛片在线看 | 欧美另类xxxx | 91在线小视频 | 国产精品久久久久久久久久ktv | 精品久久久久久国产偷窥 | 黄色成人av | 国产黄色精品在线观看 | 日韩欧美99 | 久久久久久久久久福利 | 色久五月| 国产伦精品一区二区三区照片91 | 激情婷婷在线观看 | 国产成人精品一区二区在线观看 | 一区二区三区四区不卡 | 天天干夜夜干 | 人人藻人人澡人人爽 | 97热视频| 欧美另类交在线观看 | 国产精品毛片一区二区 | 夜夜骑天天操 | 激情伊人五月天 | 亚洲日日夜夜 | 中文字幕av在线电影 | 在线观看av的网站 | 狠狠躁夜夜躁人人爽视频 | 91日韩精品视频 | 国产精品永久免费在线 | 欧美日韩高清一区二区三区 | 精品亚洲免费视频 | 在线视频 成人 | 国产一二区免费视频 | 在线精品一区二区 | 国产精品免费麻豆入口 | 正在播放 国产精品 | 国产精品一区专区欧美日韩 | 91精品国产综合久久婷婷香蕉 | 久草在线最新视频 | 九九热免费在线视频 | 一区精品久久 | 性色av一区二区三区在线观看 | 精品国产色| 中文欧美字幕免费 | 超碰九九| 992tv在线观看网站 | 日韩av高清 | 99精品视频网站 | 日韩久久激情 | 中文久草 | 91一区二区三区久久久久国产乱 | 最近免费中文字幕大全高清10 | 日本精品中文字幕在线观看 | 国产精品18久久久久久久久 | 久久免费高清 | 久久久久国产成人免费精品免费 | 成人免费在线观看电影 | 久久久国产一区二区 | 久久精彩免费视频 | 国产在线国偷精品产拍免费yy | 激情网五月婷婷 | 五月婷婷中文 | 中文资源在线官网 | 视频国产精品 | 欧美一级片免费 | 国产一区二区三区在线免费观看 | 三级动图| 国内精品久久久久久久97牛牛 | 国产999视频在线观看 | 人人爽久久久噜噜噜电影 | 国产精品毛片久久久 | 久久精品小视频 | 色网站免费在线观看 | 麻豆视频在线免费 | h视频在线看 | 国产精品久久久久免费a∨ 欧美一级性生活片 | 一级电影免费在线观看 | 国产不卡在线视频 | 国语精品免费视频 | 国产精品亚洲人在线观看 | 日批视频在线播放 | 欧美另类重口 | 日韩有码欧美 | 日韩欧美xxx | 免费看国产a | 91精品一 | 91粉色视频| 五月婷婷在线综合 | 久久99精品一区二区三区三区 | 亚洲成熟女人毛片在线 | 国产婷婷vvvv激情久 | 国精产品999国精产品视频 | 久久精品国产亚洲aⅴ | 91精品亚洲影视在线观看 | 久久艹艹 | 成人啪啪18免费游戏链接 | 黄色片网站 | 国产精品白虎 | 狠狠狠色丁香综合久久天下网 | 亚洲国产一区av | 米奇四色影视 | 91中文字幕在线 | 亚洲成a人片在线观看网站口工 | 国产第一福利 | 亚洲欧美精品一区 | 日韩欧美在线综合网 | 国产手机在线播放 | av免费在线免费观看 | 国产精品成人一区二区 | 国产欧美精品一区二区三区四区 | 亚洲免费精品视频 | 夜添久久精品亚洲国产精品 | 99综合电影在线视频 | 日日爽| 999成人国产 | 国产视频一区精品 | 美女精品国产 | 久久99国产综合精品免费 | 日本黄色免费在线观看 | 97福利| 国产成人精品av久久 | 国产小视频在线免费观看视频 | 香蕉视频一级 | 日本精品久久久久影院 | 久久9视频 | 狠狠色丁香婷婷综合视频 | 99久久这里只有精品 | 亚洲 中文 欧美 日韩vr 在线 | 久草影视在线观看 | 久久av一区二区三区亚洲 | 久青草视频在线观看 | 天天操天天能 | 在线观看亚洲精品视频 | 韩国av免费观看 | 久久精品久久久久电影 | 久草在线99 | 国产免费小视频 | 不卡国产视频 | 黄色软件在线看 | 91人人澡人人爽人人精品 | 午夜一级免费电影 | 热久久这里只有精品 | 91系列在线 | 在线视频电影 | 精品美女在线视频 | sm免费xx网站 | 美女免费视频一区 | 久草在线 | 免费视频成人 | 欧美日韩不卡在线观看 | 日本久久久久 | 亚洲精品大片www | 在线黄色免费 | 亚洲国产97在线精品一区 | 国产中文在线视频 | 91精品免费在线观看 | 在线免费视频你懂的 | 性色视频在线 | 在线91av| 国产高清精品在线观看 | 天天操婷婷 | 欧美一级日韩免费不卡 | 国产免费小视频 | 99这里只有久久精品视频 | 91chinese在线| 免费在线黄 | 欧美一区二区三区在线观看 | 亚洲午夜精品一区 | 国产123区在线观看 国产精品麻豆91 | 97人人添人澡人人爽超碰动图 | 天天射综合网站 | 久久久久| 成人午夜电影免费在线观看 | 91在线中文| 久久婷婷视频 | 欧美日韩一区二区在线观看 | 国产欧美精品在线观看 | 久久 在线 | 在线播放日韩av | 久久这里精品视频 | 色综合小说 | 午夜精品久久久久久久99水蜜桃 | av免费在线免费观看 | 亚洲砖区区免费 | 久久成人精品电影 | 亚洲午夜小视频 | 精品色999 | 国产精品乱码久久久久 | 黄色网址国产 | 九九热免费精品视频 | 国产精品video爽爽爽爽 | 国产福利不卡视频 | 国产美女视频 | 去看片| 最近中文字幕大全中文字幕免费 | 日韩网站在线免费观看 | 日本性高潮视频 | 免费视频xnxx com | 超碰人人在线观看 | 精品免费视频123区 午夜久久成人 | 在线观看欧美成人 | 激情婷婷| 久久99爱视频 | 欧美日韩在线播放一区 | 超碰97免费观看 | 精品国产成人av | 国产18精品乱码免费看 | 日韩精品一区二区三区三炮视频 | 国产精品黑丝在线观看 | 国产一区二区午夜 | 国产精品成人aaaaa网站 | 天堂在线一区二区三区 | 日日操夜夜操狠狠操 | 日本丶国产丶欧美色综合 | 亚洲精品在线免费播放 | 99精品在这里 | 91欧美日韩国产 | 最新免费中文字幕 | avove黑丝 | 天天av资源 | 国产福利91精品一区二区三区 | 国产精品一区二区三区电影 | 91大神精品视频在线观看 | 麻豆传媒在线免费看 | 999在线精品 | 国产精品久久中文字幕 | 久久视频精品在线观看 | 国产精品一区二区久久 | 狠狠干成人综合网 | 成人免费看视频 | 韩国精品一区二区三区六区色诱 | 成人a级网站 | 国产乱对白刺激视频在线观看女王 | 超碰av在线免费观看 | 91精品国产亚洲 | a视频免费在线观看 | 欧美激情精品久久久久久免费 | 97国产小视频| 久久九九影院 | 国产 欧美 日产久久 | 国产97免费 | 91秒拍国产福利一区 | 久久久久一区二区三区 | 天堂va欧美va亚洲va老司机 | 91成年人视频| 婷婷av电影| 亚洲欧洲av| 超碰人人av | 国产精品麻豆果冻传媒在线播放 | 亚洲草视频| 国产午夜剧场 | 综合色婷婷 | 久久精品免视看 | 五月婷婷六月丁香 | 欧美精品久久久久a | 久久久久久久久影视 | 九九热在线视频免费观看 | 亚洲成人精品av | 韩日成人av | 日本在线观看一区二区 | 久久久91精品国产 | 午夜少妇av | 亚洲第一av在线播放 | 激情欧美国产 | 又大又硬又黄又爽视频在线观看 | 久久6精品 | 成人h动漫在线看 | 91大神免费在线观看 | 久久久久99精品国产片 | 超碰在线观看97 | 欧美国产日韩在线视频 | 99re6热在线精品视频 | 久操97| av不卡免费在线观看 | 中文电影网 | 欧美日韩高清一区二区 | 久久人人爽爽 | 草莓视频在线观看免费观看 | 久久论理 | 亚洲综合视频在线播放 | 成人在线免费小视频 | 久久一级片 | 久久免费观看少妇a级毛片 久久久久成人免费 | 亚洲午夜av | av电影中文 | 日韩精品一区二区三区在线播放 | 亚洲成人网av | 国产一区高清在线观看 | 激情网站免费观看 | 五月花丁香婷婷 | 精品国产理论片 | 麻豆传媒电影在线观看 | 美女性爽视频国产免费app | 香蕉精品在线观看 | 国产午夜三级一区二区三桃花影视 | 少妇高潮流白浆在线观看 | 97人人模人人爽人人喊网 | 91久久久久久国产精品 | 天天操天天添 | 中文字幕在线成人 | 国产高清免费观看 | 91免费在线播放 | 日韩欧美高清一区二区 | 精品亚洲va在线va天堂资源站 | www.久久精品视频 | 国产精品美女久久久久久 | 亚洲精品18p | 欧美日韩一区二区三区在线免费观看 | 欧美乱码精品一区 | 国产在线视频不卡 | 久久久久久影视 | 国产在线观看h | 亚洲 中文字幕av | 国产精品理论视频 | 成人免费在线视频 | 在线中文字幕一区二区 | 97在线精品国自产拍中文 | 国产成人av电影在线观看 | 国产成人精品一区二区三区福利 | 亚洲精品mv在线观看 | 91九色老| 国产一级片网站 | 国产精品高清一区二区三区 | 国产精品专区在线 | 日韩视频在线观看视频 | 99riav1国产精品视频 | 麻豆成人精品视频 | 国产乱老熟视频网88av | 久久黄视频 | 国产午夜在线观看 | 国产99久久久国产精品成人免费 | 国产精品美女网站 | 欧美日韩在线观看视频 | 国产69精品久久久久99尤 | 久久av高清 | 91精品久久久久久综合五月天 | 日韩成人免费在线观看 | 一本一道久久a久久精品蜜桃 | 亚洲国产精品久久 | 国产精品女人久久久久久 | 久久看片网| 丰满少妇麻豆av | 日韩影片在线观看 | 国产又黄又爽又猛视频日本 | 伊人久操 | 精品视频999| 国产一区自拍视频 | 成年人在线免费看视频 | 超碰人人91 | 97视频免费在线看 | 成人免费在线电影 | 亚洲国内在线 | 欧美精品亚洲精品日韩精品 | www.午夜视频| 激情综合网在线观看 | 日韩av在线小说 | 国产精品igao视频网网址 | 九九导航 | 波多野结衣久久精品 | 欧美极度另类 | 国产成在线观看免费视频 | 日韩av一区二区三区在线观看 | 日本黄色免费在线观看 | 国产精品永久免费 | 日韩理论在线 | 久久伊人色综合 | 色婷婷激婷婷情综天天 | 日韩二区三区在线观看 | 久久亚洲私人国产精品 | 国产麻豆果冻传媒在线观看 | 国产一级视频在线观看 | 久久乱码卡一卡2卡三卡四 五月婷婷久 | 国产精品你懂的在线观看 | 日韩免费在线一区 | 久久成人毛片 | 中文字幕一区二区三区在线视频 | 99久久99久久精品 | 国产亚洲人 | 日韩在线观看中文 | 亚洲aaa级 | 日韩免费观看一区二区三区 | 欧美日韩xxx | 日韩最新在线视频 | 区一区二区三区中文字幕 | 国产精品日韩久久久久 | 黄a在线 | 成人久久18免费 | 久久精品福利视频 | 五月婷婷色丁香 | 在线观看精品视频 | 久久久久这里只有精品 | 日韩欧美区 | 在线国产能看的 | 久久久免费高清视频 | 免费在线精品视频 | 在线观看亚洲视频 | 日韩综合在线观看 | 亚洲视频axxx | 免费看久久久 | 91亚洲精品国产 | 欧美日韩精品在线观看视频 | 麻豆 91 在线| 久久久久国产精品午夜一区 | 97av视频 | 国内精品久久久久影院日本资源 | 日韩精品在线免费观看 | 国产福利小视频在线 | 天天摸日日摸人人看 | 成人在线观看免费 | 国产精品美女久久久久久久 | 欧美激情在线看 | 亚洲狠狠婷婷综合久久久 | 四虎国产精品免费观看视频优播 | 水蜜桃亚洲一二三四在线 | 久久久久久高潮国产精品视 | 久久精品aaa | 婷婷色中文字幕 | 国产黄免费看 | 手机看片福利 | 久久国产精品二国产精品中国洋人 | 丁香婷婷在线 | 黄色三级网站在线观看 | 国产成人黄色 | 久久视精品 | 免费高清在线观看成人 | 一区二区三区在线播放 | 成人高清在线观看 | 日韩成人免费在线观看 | 婷婷丁香九月 | 成人免费视频观看 | 少妇bbbb揉bbbb日本 | 久久看毛片 | 久久久久激情 | 国产九九在线 | 美女视频黄是免费的 | 激情导航 | 国产婷婷精品 | 久久影视一区二区 | 欧美日韩不卡在线观看 | 女人18片毛片90分钟 | 成年人电影免费在线观看 | 日本成人免费在线观看 | 干 操 插| 国产成在线观看免费视频 | www五月婷婷 | 91av小视频 | 国产亚洲精品日韩在线tv黄 | 俺要去色综合狠狠 | 看污网站 | 成人精品99 | 人人插人人艹 | 91亚洲精品久久久 | 国产精品99久久久久的智能播放 | 黄色亚洲 | 中文字幕在线视频第一页 | 日本中文字幕在线播放 | 在线观看一级视频 | 国产精品麻豆欧美日韩ww | 91在线观看高清 | 成人黄色大片 | 国产91精品久久久久 | 亚洲国产欧美在线看片xxoo | 日本中文字幕在线电影 | 丁香五香天综合情 | www.色午夜 | 欧美精品在线观看免费 | 久久精品www人人爽人人 | 啪啪肉肉污av国网站 | 九九色视频| 最近日韩免费视频 | 综合在线观看色 | 日韩欧美视频一区二区 | 免费a视频在线观看 | 亚洲激情婷婷 | av中文字幕在线电影 | 四虎永久国产精品 | 久久久91精品国产一区二区精品 | 免费观看9x视频网站在线观看 | 日韩国产精品久久久久久亚洲 | 在线观看成人一级片 | 亚洲激情五月 | 免费观看91 | 欧美男同网站 | 天堂av在线 | 亚洲国产精品推荐 | 精品免费| 久久天堂精品视频 | 国产精品综合久久久 | 操操日日 | 欧美日韩网址 | 天天操天天操天天操 | 久久精品99国产精品亚洲最刺激 | 亚洲国产色一区 | 欧美日韩在线看 | 狠狠狠狠狠干 | 日韩精品一区二区三区第95 | 免费看的黄网站软件 | 超碰在线观看97 | 欧美视频一区二 | 黄色毛片在线 | 在线视频免费观看 | 99 色| 国精产品999国精产品视频 | 人人爱人人做人人爽 | 天堂中文在线视频 | 搡bbbb搡bbb视频| 在线视频日韩精品 | 国产伦精品一区二区三区高清 | 97电影院在线观看 | 黄色精品网站 | 免费黄色特级片 | 超级碰99 | 中文字幕一区二区三 | 国产日产在线观看 | 五月天色综合 | 99久久99久久精品 | 97电影院网 | 色六月婷婷 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 青草草在线 | 亚洲国产日韩一区 | 日本精a在线观看 | 人人插超碰 | 欧美日韩一区二区在线观看 | 亚洲最大的av网站 | 天天人人 | 综合天堂av久久久久久久 | 国产午夜精品在线 | 国产成人精品在线观看 | 国产一级做a爱片久久毛片a | 天天亚洲综合 | 久青草电影 | 中文字幕在线观看你懂的 | 亚洲欧美婷婷六月色综合 | 天天碰天天操 | 麻豆av电影 | 精品视频97| 久久久国产成人 | 色婷婷综合久久久久中文字幕1 | 波多野结衣视频网址 | 国产色 在线 | 激情视频一区二区 | 9ⅰ精品久久久久久久久中文字幕 | 亚洲激情影院 | 狠狠狠狠狠狠狠干 | 狠狠色狠狠色综合系列 | 日韩免费看的电影 | 精品综合久久久 | 久久国产亚洲精品 | 欧美精品乱码久久久久 | 天天干天天操天天干 | 人人草人人草 | 在线观看小视频 | 国产99久久久国产精品免费看 | 97超级碰碰碰碰久久久久 | 国产成人av一区二区三区在线观看 | 激情久久伊人 | av看片网| 超碰人人草人人 | 国产精品久久免费看 | 天天色天天操天天爽 | 国产精品专区一 | 国产精品1区2区3区 久久免费视频7 | 国产精品嫩草55av | 天天操天天射天天 | 国产精品久久在线观看 | 亚洲一级黄色片 | 一级电影免费在线观看 | 在线观看国产麻豆 | 成人黄大片视频在线观看 | 人人爽人人爽人人爽 | av怡红院| 国产精品爽爽久久久久久蜜臀 | 亚洲永久精品视频 | 久久dvd| 66av99精品福利视频在线 | 亚洲国产精品久久久久婷婷884 | 成人三级视频 | 精品国产精品一区二区夜夜嗨 | 色全色在线资源网 | 日韩久久精品一区二区三区 | 99爱精品视频 | 久久av中文字幕片 | www.少妇| 精品国精品自拍自在线 | 久久九九网站 | 奇米网777 | 91香蕉嫩草 | 在线a视频免费观看 | 久久国产精品免费 | 在线观看你懂的网站 | 日本不卡一区二区三区在线观看 | 国产精品96久久久久久吹潮 | a级片网站| 草久视频在线观看 | 天天色天天 | 天天综合成人网 | 国产亚洲精品久久久网站好莱 | 久久综合色影院 | 亚洲欧美国产精品 | 日韩av在线不卡 | 久久久999| 久久久影院一区二区三区 | 精品久久久久久国产 | 亚洲精品在线免费播放 | 97视频在线观看免费 | 中文字幕在线观看完整版 | 欧美韩国日本在线观看 | 国产黄在线播放 | av永久网址 | 亚洲精品国产综合久久 | 久久久国产精品电影 | 日韩激情在线 | 欧美极度另类性三渗透 | 又黄又爽又刺激视频 | 正在播放 国产精品 | 美女视频免费一区二区 | 午夜国产一区二区三区四区 | 欧美视频99| 91麻豆产精品久久久久久 | www欧美日韩 | 国产 在线 高清 精品 | 免费看黄色毛片 | 久久免费视频这里只有精品 | 免费亚洲精品 | 99热这里只有精品在线观看 | 97国产超碰在线 | 97色在线观看免费视频 | 国产最新在线 | 久久超碰97 | 国产香蕉97碰碰久久人人 | 丁香婷婷基地 | 亚洲精品午夜一区人人爽 | 久久激情电影 | 国产xxxx做受性欧美88 | 色狠狠一区二区 | 91在线区 | 久久亚洲影院 | 国产麻豆精品传媒av国产下载 | 日韩免费观看视频 | 日日爱网站 | 日韩欧美99 | 国产精品成人国产乱一区 | 国产精品久久在线 | 日韩一二区在线 | 最近的中文字幕大全免费版 | 国产福利在线免费 | 97超碰福利久久精品 | 国产精品每日更新 | 亚洲无吗av | 99在线视频网站 | 亚洲精品久久视频 | 蜜臀久久99精品久久久久久网站 | 欧美热久久 | 中文日韩在线视频 | 天天干com| 成年人网站免费观看 | 不卡av电影在线 | 免费在线色视频 | 久久婷婷一区二区三区 | 久久国产影视 | 国产精品久久电影网 | 免费在线观看不卡av | 五月婷婷色综合 | 国产一区在线不卡 | 国产精品99久久久精品 | 日韩精品资源 | 日韩欧美精品一区二区三区经典 | 夜夜夜影院 | 久久经典视频 | 97免费在线观看 | a色视频 | 国产精品一区二区视频 | av三区在线 | 欧美另类激情 | av理论电影 | 91精品人成在线观看 | 500部大龄熟乱视频 欧美日本三级 | 国产黄色精品视频 | 不卡av在线播放 | 久草在线电影网 | 日韩高清在线不卡 | 久草在线视频首页 | 丁香午夜 | 丁香六月综合网 | 免费黄色a网站 | 18国产精品白浆在线观看免费 | 欧美巨大荫蒂茸毛毛人妖 | 最新av在线网址 | 色资源二区在线视频 | 久草在线视频精品 | 六月色婷 | 日韩免费看 | 久久综合狠狠综合 | 亚洲人久久久 | 91人人视频在线观看 | 丁香婷婷电影 | 亚洲日本黄色 | 欧美一级电影在线观看 | 午夜.dj高清免费观看视频 | 免费看国产一级片 | 蜜臀av在线一区二区三区 | 免费在线观看成人小视频 | a黄色片在线观看 | 国产高清免费观看 | 亚洲欧美日韩一区二区三区在线观看 | 欧美一级裸体视频 | 中文字幕一区二区三区乱码在线 | 在线观看亚洲电影 | 欧美福利在线播放 | 在线电影 你懂得 | 最近免费中文字幕大全高清10 | 国产午夜精品久久 | 亚洲高清视频在线观看免费 | 黄色在线免费观看网址 | 丰满少妇在线观看资源站 | 在线播放av网址 | 国内三级在线 | 波多野结衣精品 | 热久久国产| 在线观看日本韩国电影 | 久久久亚洲国产精品麻豆综合天堂 | 99视频一区 | 人人爽人人爽人人爽人人爽 | 成片免费 | 日韩在线观看电影 | 久久国产色 | 亚洲精品视频免费看 | 亚洲精品字幕在线观看 | 日韩av男人的天堂 | 国产精品久久人 | 国产精品www | 国产又粗又长的视频 | 在线蜜桃视频 | 国产成人无码AⅤ片在线观 日韩av不卡在线 | 国产精品第二页 | 亚洲欧美视频在线观看 | 四虎国产精品成人免费影视 | 99久久精品日本一区二区免费 | 最近更新好看的中文字幕 | 在线国产能看的 | 人人澡人人爽欧一区 | 99免在线观看免费视频高清 | 一区二区三区在线电影 | 激情图片qvod| 午夜美女网站 | 超碰999| 久久免费视频7 | 91亚洲视频在线观看 | 9色在线视频 | 欧美日韩国产一区 | 黄色毛片视频 | av免费观看网址 | 久久久久久久久影院 | 亚洲综合涩| 国产欧美精品xxxx另类 | 四虎永久免费 | 人人爱人人舔 | 亚洲天堂精品视频在线观看 | 在线观看mv的中文字幕网站 | www.国产精品 | 国产精久久久久久妇女av | 久久久官网 | 日韩网站免费观看 | 国产精品99久久久久的智能播放 | www.伊人色.com | 国产精品久久久久三级 | 精品无人国产偷自产在线 | 久久国产经典视频 | 丁香六月婷婷开心 | 日日日干| 免费进去里的视频 | 国产高清av免费在线观看 | 一区在线播放 | 国产99久久| 亚洲综合一区二区精品导航 | 国产精品99久久久精品 | 丁香视频 |