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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

TreeMap源码分析——深入分析(基于JDK1.6)

發(fā)布時間:2023/12/2 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 TreeMap源码分析——深入分析(基于JDK1.6) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

? ? ?TreeMap有Values、EntrySet、KeySet、PrivateEntryIterator、EntryIterator、ValueIterator、KeyIterator、DescendingKeyIterator、NavigableSubMap、AscendingSubMap、DescendingSubMap、SubMap、Entry共十三個內(nèi)部類。Entry是在TreeMap中用于表示樹的節(jié)點(diǎn)的內(nèi)部類,已經(jīng)在《TreeMap源碼分析——基礎(chǔ)分析》中分析過。下面逐一介紹上面的內(nèi)部類以及TreeMap中提供的和內(nèi)部類相關(guān)的方法。

? ? ?先看Values。

1 // 從類的定義可以看出,Values是一個集合類 2 class Values extends AbstractCollection<V> { 3 // 提供集合類Values的迭代器 4 public Iterator<V> iterator() { 5 return new ValueIterator(getFirstEntry()); 6 } 7 // 返回TreeMap中保存的節(jié)點(diǎn)數(shù) 8 public int size() { 9 return TreeMap.this.size(); 10 } 11 // 判斷TreeMap中是否存在Value為o的節(jié)點(diǎn) 12 public boolean contains(Object o) { 13 return TreeMap.this.containsValue(o); 14 } 15 // 刪除一個對象 16 public boolean remove(Object o) { 17 // 遍歷TreeMap 18 for (Entry<K,V> e = getFirstEntry(); e != null; e = successor(e)) { 19 // 尋找值相等的節(jié)點(diǎn) 20 if (valEquals(e.getValue(), o)) { 21 // 刪除找到的節(jié)點(diǎn) 22 deleteEntry(e); 23 return true; 24 } 25 } 26 return false; 27 } 28 // 清空TreeMap 29 public void clear() { 30 TreeMap.this.clear(); 31 } 32 }

? ? ?Values類實(shí)際上是一個代理,多數(shù)方法都是調(diào)用TreeMap的方法。在Values的iterator()方法中返回了一個ValuesIterator對象,下面來看和迭代器相關(guān)的內(nèi)部類。PrivateEntryIterator是TreeMap中和迭代器相關(guān)的類的基礎(chǔ),以下是PrivateEntryIterator的內(nèi)容。

1 abstract class PrivateEntryIterator<T> implements Iterator<T> { 2 // 指向next的引用 3 Entry<K,V> next; 4 // 保留對上一次返回節(jié)點(diǎn)的引用 5 Entry<K,V> lastReturned; 6 int expectedModCount; 7 // 構(gòu)造方法,lastReturned置空,next指向傳入的節(jié)點(diǎn) 8 PrivateEntryIterator(Entry<K,V> first) { 9 expectedModCount = modCount; 10 lastReturned = null; 11 next = first; 12 } 13 // 判斷是否還有下一個節(jié)點(diǎn) 14 public final boolean hasNext() { 15 return next != null; 16 } 17 // 返回下一個節(jié)點(diǎn) 18 final Entry<K,V> nextEntry() { 19 Entry<K,V> e = next; 20 if (e == null) 21 throw new NoSuchElementException(); 22 if (modCount != expectedModCount) 23 throw new ConcurrentModificationException(); 24 // next移動到它的繼承者 25 next = successor(e); 26 // 記錄被返回的節(jié)點(diǎn) 27 lastReturned = e; 28 // 返回原先記錄的next節(jié)點(diǎn) 29 return e; 30 } 31 // 前一個節(jié)點(diǎn) 32 final Entry<K,V> prevEntry() { 33 Entry<K,V> e = next; 34 if (e == null) 35 throw new NoSuchElementException(); 36 if (modCount != expectedModCount) 37 throw new ConcurrentModificationException(); 38 // 獲取指定節(jié)點(diǎn)的“前任”(按遍歷次序的前一個節(jié)點(diǎn)) 39 next = predecessor(e); 40 // 記錄被返回的節(jié)點(diǎn) 41 lastReturned = e; 42 return e; 43 } 44 // 移除最近一次被返回的節(jié)點(diǎn) 45 public void remove() { 46 if (lastReturned == null) 47 throw new IllegalStateException(); 48 if (modCount != expectedModCount) 49 throw new ConcurrentModificationException(); 50 // deleted entries are replaced by their successors 51 if (lastReturned.left != null && lastReturned.right != null) 52 /* 如果被刪除節(jié)點(diǎn)有兩個孩子,刪除節(jié)點(diǎn)e的時候e的引用會被修改為指向原節(jié)點(diǎn)的繼承者,所以這里先保留next對lastReturned的引用,這樣在刪除節(jié)點(diǎn)后就能獲取到繼承者的引用,繼而繼續(xù)遍歷樹 */ 53 next = lastReturned; 54 // 刪除節(jié)點(diǎn) 55 deleteEntry(lastReturned); 56 expectedModCount = modCount; 57 lastReturned = null; 58 } 59 }

? ? ?PrivateEntryIterator類的prevEntry()方法用到了predecessor(Entry<K,V> t)方法,下面對這個方法進(jìn)行介紹。

? ? ?predecessor(Entry<K,V> t)方法返回傳入節(jié)點(diǎn)的“前一個”節(jié)點(diǎn),至于前一個節(jié)點(diǎn)是哪個節(jié)點(diǎn),這和樹的遍歷次序相關(guān)。根據(jù)successor(Entry<K,V> t)和predecessor(Entry<K,V> t)方法可以推出TreeMap中樹的遍歷次序是中根遍歷(左孩子-根-右孩子)。

1 static <K,V> Entry<K,V> predecessor(Entry<K,V> t) { 2 if (t == null) 3 return null; 4 else if (t.left != null) { 5 // 獲得左孩子 6 Entry<K,V> p = t.left; 7 // 對左孩子進(jìn)行遍歷,獲取左孩子最右的子孫 8 while (p.right != null) 9 p = p.right; 10 return p; 11 } else { 12 // 獲取t的父節(jié)點(diǎn) 13 Entry<K,V> p = t.parent; 14 Entry<K,V> ch = t; 15 // 沿著右孩子向上查找繼承者,直到根節(jié)點(diǎn)或找到節(jié)點(diǎn)ch是其父節(jié)點(diǎn)的右孩子的節(jié)點(diǎn) 16 while (p != null && ch == p.left) { 17 ch = p; 18 p = p.parent; 19 } 20 return p; 21 } 22 }

? ? ?下面是TreeMap中其它和迭代器相關(guān)的內(nèi)部類。

1 // EntryIterator就是樹節(jié)點(diǎn)的迭代器,和PrivateEntryIterator完全一樣,因?yàn)樘峁┑姆椒ǘ贾苯拥恼{(diào)用而來父類的方法。 2 final class EntryIterator extends PrivateEntryIterator<Map.Entry<K,V>> { 3 EntryIterator(Entry<K,V> first) { 4 super(first); 5 } 6 public Map.Entry<K,V> next() { 7 return nextEntry(); 8 } 9 } 10 /** Value的迭代器 */ 11 final class ValueIterator extends PrivateEntryIterator<V> { 12 ValueIterator(Entry<K,V> first) { 13 super(first); 14 } 15 // next()方法返回的是節(jié)點(diǎn)的value值 16 public V next() { 17 return nextEntry().value; 18 } 19 } 20 /** Key迭代器 */ 21 final class KeyIterator extends PrivateEntryIterator<K> { 22 KeyIterator(Entry<K,V> first) { 23 super(first); 24 } 25 // next()方法返回的是節(jié)點(diǎn)的key 26 public K next() { 27 return nextEntry().key; 28 } 29 } 30 /** 逆序的Key迭代器 */ 31 final class DescendingKeyIterator extends PrivateEntryIterator<K> { 32 DescendingKeyIterator(Entry<K,V> first) { 33 super(first); 34 } 35 // next()方法返回的是節(jié)點(diǎn)的“前任”(按照遍歷次序的前一個節(jié)點(diǎn))的key 36 public K next() { 37 return prevEntry().key; 38 } 39 }

? ? ?除了迭代器相關(guān)的內(nèi)部類,TreeMap還有兩個和Set相關(guān)的內(nèi)部類,分別是EntrySet和KeySet。兩個類分別表示節(jié)點(diǎn)的集合和鍵的集合。下面具體看這兩個類的實(shí)現(xiàn)。

1 // 繼承自AbstractSet說明是一個Set 2 class EntrySet extends AbstractSet<Map.Entry<K,V>> { 3 // iterator()方法返回的是上面介紹過的EntryIterator對象 4 public Iterator<Map.Entry<K,V>> iterator() { 5 return new EntryIterator(getFirstEntry()); 6 } 7 // 判斷是否包含某個節(jié)點(diǎn)的方法 8 public boolean contains(Object o) { 9 if (!(o instanceof Map.Entry)) 10 return false; 11 Map.Entry<K,V> entry = (Map.Entry<K,V>) o; 12 V value = entry.getValue(); 13 Entry<K,V> p = getEntry(entry.getKey()); 14 // 判斷是否包含某個對象的標(biāo)準(zhǔn)是存在節(jié)點(diǎn)的key的與傳入對象的key值,且該節(jié)點(diǎn)的value也與存入對象的value值相等 15 return p != null && valEquals(p.getValue(), value); 16 } 17 // 刪除一個對象 18 public boolean remove(Object o) { 19 if (!(o instanceof Map.Entry)) 20 return false; 21 Map.Entry<K,V> entry = (Map.Entry<K,V>) o; 22 V value = entry.getValue(); 23 Entry<K,V> p = getEntry(entry.getKey()); 24 // 如果存在該對象,則進(jìn)行刪除操作并返回true 25 if (p != null && valEquals(p.getValue(), value)) { 26 deleteEntry(p); 27 return true; 28 } 29 // 不存在直接返回false 30 return false; 31 } 32 // size()返回的是TreeMap中包含的節(jié)點(diǎn)的數(shù)量 33 public int size() { 34 return TreeMap.this.size(); 35 } 36 // clear()方法實(shí)際調(diào)用了TreeMap的clear()方法,和size()方法都是代理方法 37 public void clear() { 38 TreeMap.this.clear(); 39 } 40 } 1 // KeySet同樣繼承自AbstractSet。KeySet實(shí)現(xiàn)了NavigableSet接口,意味著是“可導(dǎo)航”的Set,包含更多的獲取指定節(jié)點(diǎn)的方法 2 static final class KeySet<E> extends AbstractSet<E> implements NavigableSet<E> { 3 private final NavigableMap<E, Object> m; 4 // 構(gòu)造方法 5 KeySet(NavigableMap<E,Object> map) { m = map; } 6 // 7 public Iterator<E> iterator() { 8 if (m instanceof TreeMap) 9 return ((TreeMap<E,Object>)m).keyIterator(); 10 else 11 // 這里涉及到的NavigableSubMap將在后面介紹 12 return (Iterator<E>)(((TreeMap.NavigableSubMap)m).keyIterator()); 13 } 14 15 public Iterator<E> descendingIterator() { 16 if (m instanceof TreeMap) 17 return ((TreeMap<E,Object>)m).descendingKeyIterator(); 18 else 19 return (Iterator<E>)(((TreeMap.NavigableSubMap)m).descendingKeyIterator()); 20 } 21 // size()方法返回的是通過構(gòu)造方法傳入的map的大小 22 public int size() { return m.size(); } 23 // isEmpty()判斷是否為空也是判斷的傳入的map是否為空 24 public boolean isEmpty() { return m.isEmpty(); } 25 // contains(Object o)方法判斷傳入map中是否包含這個key 26 public boolean contains(Object o) { return m.containsKey(o); } 27 public void clear() { m.clear(); } 28 // 因?yàn)閭魅氲膍ap是NavigableMap,所以下面這幾個方法都是代理方法,調(diào)用map中相應(yīng)的方法 29 public E lower(E e) { return m.lowerKey(e); } 30 public E floor(E e) { return m.floorKey(e); } 31 public E ceiling(E e) { return m.ceilingKey(e); } 32 public E higher(E e) { return m.higherKey(e); } 33 public E first() { return m.firstKey(); } 34 public E last() { return m.lastKey(); } 35 // 獲取傳入map的比較器 36 public Comparator<? super E> comparator() { return m.comparator(); } 37 // 獲取map中第一個節(jié)點(diǎn)的key 38 public E pollFirst() { 39 Map.Entry<E,Object> e = m.pollFirstEntry(); 40 return e == null? null : e.getKey(); 41 } 42 // 獲取map中最后一個節(jié)點(diǎn)的key 43 public E pollLast() { 44 Map.Entry<E,Object> e = m.pollLastEntry(); 45 return e == null? null : e.getKey(); 46 } 47 // 刪除一個對象,實(shí)際上是刪除map中以這個對象為key的一個節(jié)點(diǎn) 48 public boolean remove(Object o) { 49 int oldSize = size(); 50 m.remove(o); 51 return size() != oldSize; 52 } 53 // 下面的方法都是通過NavigableMap和TreeSet實(shí)現(xiàn)的,NavigableMap將在下文介紹,TreeSet將另開博文介紹 54 public NavigableSet<E> subSet(E fromElement, boolean fromInclusive, 55 E toElement, boolean toInclusive) { 56 return new TreeSet<E>(m.subMap(fromElement, fromInclusive, 57 toElement, toInclusive)); 58 } 59 public NavigableSet<E> headSet(E toElement, boolean inclusive) { 60 return new TreeSet<E>(m.headMap(toElement, inclusive)); 61 } 62 public NavigableSet<E> tailSet(E fromElement, boolean inclusive) { 63 return new TreeSet<E>(m.tailMap(fromElement, inclusive)); 64 } 65 public SortedSet<E> subSet(E fromElement, E toElement) { 66 return subSet(fromElement, true, toElement, false); 67 } 68 public SortedSet<E> headSet(E toElement) { 69 return headSet(toElement, false); 70 } 71 public SortedSet<E> tailSet(E fromElement) { 72 return tailSet(fromElement, true); 73 } 74 public NavigableSet<E> descendingSet() { 75 return new TreeSet(m.descendingMap()); 76 } 77 }

? ? ?介紹完了兩個和Set相關(guān)的內(nèi)部類,現(xiàn)在還剩下四個和SubMap相關(guān)的內(nèi)部類:NavigableSubMap、AscendingSubMap、DescendingSubMap、SubMap。

? ? ?首先看NavigableSubMap,它足足有400多行代碼,相當(dāng)?shù)亩?#xff0c;需要耐心啊。

很長很暈,慎入 1 // NavigableSubMap是一個抽象類,繼承了AbstractMap,實(shí)現(xiàn)了NavigableMap接口 2 static abstract class NavigableSubMap<K,V> extends AbstractMap<K,V> 3 implements NavigableMap<K,V>, java.io.Serializable { 4 // 存儲內(nèi)容的Map 5 final TreeMap<K,V> m; 6 // lowKey、highKey 7 final K lo, hi; 8 // 標(biāo)識map的邊界是否是map的第一個節(jié)點(diǎn)和最后一個節(jié)點(diǎn) 9 final boolean fromStart, toEnd; 10 // 是否包含最低lo、最高位置hi 11 final boolean loInclusive, hiInclusive; 12 // 通過上面的三組變量可以組成兩個三元組表示一個集合的兩個端點(diǎn) 13 // 構(gòu)造方法 14 NavigableSubMap(TreeMap<K,V> m, 15 boolean fromStart, K lo, boolean loInclusive, 16 boolean toEnd, K hi, boolean hiInclusive) { 17 if (!fromStart && !toEnd) { 18 // lo>hi拋出異常 19 if (m.compare(lo, hi) > 0) 20 throw new IllegalArgumentException("fromKey > toKey"); 21 } else { 22 if (!fromStart) // type check 23 m.compare(lo, lo); 24 if (!toEnd) 25 m.compare(hi, hi); 26 } 27 28 this.m = m; 29 this.fromStart = fromStart; 30 this.lo = lo; 31 this.loInclusive = loInclusive; 32 this.toEnd = toEnd; 33 this.hi = hi; 34 this.hiInclusive = hiInclusive; 35 } 36 37 // tooLow 判斷傳入的key是否太小 38 final boolean tooLow(Object key) { 39 // 如果fromStart為false,需要判斷最低邊界 40 if (!fromStart) { 41 int c = m.compare(key, lo); 42 // 如果key<lo或者相等但是map的邊界不包含lo,那么key越界了,即小于最小值 43 if (c < 0 || (c == 0 && !loInclusive)) 44 return true; 45 } 46 // 默認(rèn)返回false 47 return false; 48 } 49 // 與上面的tooLow類似 50 final boolean tooHigh(Object key) { 51 if (!toEnd) { 52 int c = m.compare(key, hi); 53 if (c > 0 || (c == 0 && !hiInclusive)) 54 return true; 55 } 56 return false; 57 } 58 // 判斷是否在范圍內(nèi),即滿足最低最高限制,結(jié)合tooLow和tooHigh即可 59 final boolean inRange(Object key) { 60 return !tooLow(key) && !tooHigh(key); 61 } 62 // 是否在封閉的區(qū)間內(nèi) 63 final boolean inClosedRange(Object key) { 64 return (fromStart || m.compare(key, lo) >= 0) 65 && (toEnd || m.compare(hi, key) >= 0); 66 } 67 // 判斷是否是在一個區(qū)間內(nèi) 68 final boolean inRange(Object key, boolean inclusive) { 69 return inclusive ? inRange(key) : inClosedRange(key); 70 } 71 // 獲取絕對的最低的節(jié)點(diǎn) 72 final TreeMap.Entry<K,V> absLowest() { 73 /* 如果fromStart為true,獲取第一個節(jié)點(diǎn),否則根據(jù)loInclusive是否為true,即是否包含lo來決定獲取Ceiling節(jié)點(diǎn)或Higher節(jié)點(diǎn);getCeilingEntry意為獲取指定key的節(jié)點(diǎn)或者比指定key大的最小節(jié)點(diǎn),如果不存在則返回null;getHigherEntry意為獲取比指定key大的最小節(jié)點(diǎn),如果不存在,返回null */ 74 TreeMap.Entry<K,V> e = 75 (fromStart ? m.getFirstEntry() : 76 (loInclusive ? m.getCeilingEntry(lo) : 77 m.getHigherEntry(lo))); 78 // 判斷得到的節(jié)點(diǎn)是否為空或者key過大 79 return (e == null || tooHigh(e.key)) ? null : e; 80 } 81 // 與absLowest類似 82 final TreeMap.Entry<K,V> absHighest() { 83 TreeMap.Entry<K,V> e = 84 (toEnd ? m.getLastEntry() : 85 (hiInclusive ? m.getFloorEntry(hi) : 86 m.getLowerEntry(hi))); 87 return (e == null || tooLow(e.key)) ? null : e; 88 } 89 // 尋找大于等于key的最小的節(jié)點(diǎn) 90 final TreeMap.Entry<K,V> absCeiling(K key) { 91 // 如果key太小,返回絕對的最小的節(jié)點(diǎn) 92 if (tooLow(key)) 93 return absLowest(); 94 // 獲取允許的key的極限節(jié)點(diǎn)(滿足要求的最小的節(jié)點(diǎn)) 95 TreeMap.Entry<K,V> e = m.getCeilingEntry(key); 96 return (e == null || tooHigh(e.key)) ? null : e; 97 } 98 // 和absCeiling類似,只是獲取的不包含相等的情況,而是尋找大于key的最小節(jié)點(diǎn) 99 final TreeMap.Entry<K,V> absHigher(K key) { 100 if (tooLow(key)) 101 return absLowest(); 102 TreeMap.Entry<K,V> e = m.getHigherEntry(key); 103 return (e == null || tooHigh(e.key)) ? null : e; 104 } 105 // 獲取絕對的小于等于key的節(jié)點(diǎn) 106 final TreeMap.Entry<K,V> absFloor(K key) { 107 // 指定的key超出了hi,直接返回絕對的允許的最大的節(jié)點(diǎn) 108 if (tooHigh(key)) 109 return absHighest(); 110 /* getFloorEntry 獲取的是指定key的節(jié)點(diǎn),如果不存在這樣的節(jié)點(diǎn),就去獲取比指定key小的最大的節(jié)點(diǎn),如果這樣的節(jié)點(diǎn)也不存在,返回null*/ 111 TreeMap.Entry<K,V> e = m.getFloorEntry(key); 112 return (e == null || tooLow(e.key)) ? null : e; 113 } 114 // 與上面的absFloor類似,只是不包含等于的情況 115 final TreeMap.Entry<K,V> absLower(K key) { 116 if (tooHigh(key)) 117 return absHighest(); 118 TreeMap.Entry<K,V> e = m.getLowerEntry(key); 119 return (e == null || tooLow(e.key)) ? null : e; 120 } 121 122 // 返回比最大的節(jié)點(diǎn)“還要大”的節(jié)點(diǎn)(Fence是柵欄、圍欄的意思) 123 final TreeMap.Entry<K,V> absHighFence() { 124 /* 如果toEnd是true,那么“圍在”它外面的是null,如果是false,根據(jù)hi是否被包含返回getHigherEntry或getCeilingEntry,這兩個方法意思在上面的方法中說明過了 */ 125 return (toEnd ? null : (hiInclusive ? 126 m.getHigherEntry(hi) : 127 m.getCeilingEntry(hi))); 128 } 129 130 // 與absHighFence類似 131 final TreeMap.Entry<K,V> absLowFence() { 132 return (fromStart ? null : (loInclusive ? 133 m.getLowerEntry(lo) : 134 m.getFloorEntry(lo))); 135 } 136 137 abstract TreeMap.Entry<K,V> subLowest(); 138 abstract TreeMap.Entry<K,V> subHighest(); 139 abstract TreeMap.Entry<K,V> subCeiling(K key); 140 abstract TreeMap.Entry<K,V> subHigher(K key); 141 abstract TreeMap.Entry<K,V> subFloor(K key); 142 abstract TreeMap.Entry<K,V> subLower(K key); 143 abstract Iterator<K> keyIterator(); 144 abstract Iterator<K> descendingKeyIterator(); 145 146 // 如果fromStart、toEnd都是true,那么判斷空、獲取大小都是直接通過m,不然就必須使用entrySet()先獲取節(jié)點(diǎn)集 147 public boolean isEmpty() { 148 return (fromStart && toEnd) ? m.isEmpty() : entrySet().isEmpty(); 149 } 150 151 public int size() { 152 return (fromStart && toEnd) ? m.size() : entrySet().size(); 153 } 154 // 判斷是否存在key先判斷范圍,在通過TreeMap的containKey方法來判斷 155 public final boolean containsKey(Object key) { 156 return inRange(key) && m.containsKey(key); 157 } 158 // 添加節(jié)點(diǎn) 159 public final V put(K key, V value) { 160 // 判斷要添加的key是否在范圍內(nèi) 161 if (!inRange(key)) 162 throw new IllegalArgumentException("key out of range"); 163 return m.put(key, value); 164 } 165 public final V get(Object key) { 166 return !inRange(key)? null : m.get(key); 167 } 168 public final V remove(Object key) { 169 return !inRange(key)? null : m.remove(key); 170 } 171 public final Map.Entry<K,V> ceilingEntry(K key) { 172 /* exportEntry(TreeMap.Entry<K,V> e)方法返回的是Map.Entry<K,V>對象,它的Key 和Value和傳入的節(jié)點(diǎn)的Key 和Value相同 */ 173 return exportEntry(subCeiling(key)); 174 } 175 public final K ceilingKey(K key) { 176 // keyOrNull根據(jù)傳入的節(jié)點(diǎn)是否為null返回null或節(jié)點(diǎn)的key(相當(dāng)于提供了一個null安全的獲取key的方法) 177 return keyOrNull(subCeiling(key)); 178 } 179 public final Map.Entry<K,V> higherEntry(K key) { 180 return exportEntry(subHigher(key)); 181 } 182 public final K higherKey(K key) { 183 return keyOrNull(subHigher(key)); 184 } 185 public final Map.Entry<K,V> floorEntry(K key) { 186 return exportEntry(subFloor(key)); 187 } 188 public final K floorKey(K key) { 189 return keyOrNull(subFloor(key)); 190 } 191 public final Map.Entry<K,V> lowerEntry(K key) { 192 return exportEntry(subLower(key)); 193 } 194 public final K lowerKey(K key) { 195 return keyOrNull(subLower(key)); 196 } 197 public final K firstKey() { 198 return key(subLowest()); 199 } 200 public final K lastKey() { 201 return key(subHighest()); 202 } 203 public final Map.Entry<K,V> firstEntry() { 204 return exportEntry(subLowest()); 205 } 206 public final Map.Entry<K,V> lastEntry() { 207 return exportEntry(subHighest()); 208 } 209 // 返回并刪除第一個節(jié)點(diǎn) 210 public final Map.Entry<K,V> pollFirstEntry() { 211 TreeMap.Entry<K,V> e = subLowest(); 212 Map.Entry<K,V> result = exportEntry(e); 213 if (e != null) 214 m.deleteEntry(e); 215 return result; 216 } 217 // 返回并刪除最后一個節(jié)點(diǎn) 218 public final Map.Entry<K,V> pollLastEntry() { 219 TreeMap.Entry<K,V> e = subHighest(); 220 Map.Entry<K,V> result = exportEntry(e); 221 if (e != null) 222 m.deleteEntry(e); 223 return result; 224 } 225 226 // 這些都是視圖 227 transient NavigableMap<K,V> descendingMapView = null; 228 transient EntrySetView entrySetView = null; 229 transient KeySet<K> navigableKeySetView = null; 230 // 返回TreeMap的KeySet 231 public final NavigableSet<K> navigableKeySet() { 232 KeySet<K> nksv = navigableKeySetView; 233 return (nksv != null) ? nksv : 234 (navigableKeySetView = new TreeMap.KeySet(this)); 235 } 236 public final Set<K> keySet() { 237 return navigableKeySet(); 238 } 239 // 逆序的KeySet 240 public NavigableSet<K> descendingKeySet() { 241 return descendingMap().navigableKeySet(); 242 } 243 // 返回一個子Map 244 public final SortedMap<K,V> subMap(K fromKey, K toKey) { 245 return subMap(fromKey, true, toKey, false); 246 } 247 // 下面這幾個方法會在后面給出分析 248 public final SortedMap<K,V> headMap(K toKey) { 249 return headMap(toKey, false); 250 } 251 public final SortedMap<K,V> tailMap(K fromKey) { 252 return tailMap(fromKey, true); 253 } 254 255 // 視圖類 256 abstract class EntrySetView extends AbstractSet<Map.Entry<K,V>> { 257 private transient int size = -1, sizeModCount; 258 // 返回子Map的大小 259 public int size() { 260 // 如果fromStart和toEnd都是true,返回的是m的size 261 if (fromStart && toEnd) 262 return m.size(); 263 // size=-1或標(biāo)記size不同,重新計算一次size 264 if (size == -1 || sizeModCount != m.modCount) { 265 sizeModCount = m.modCount; 266 size = 0; 267 Iterator i = iterator(); 268 while (i.hasNext()) { 269 size++; 270 i.next(); 271 } 272 } 273 return size; 274 } 275 // 判斷EntrySet是否為空 276 public boolean isEmpty() { 277 TreeMap.Entry<K,V> n = absLowest(); 278 return n == null || tooHigh(n.key); 279 } 280 // 判斷是否包含某個對象 281 public boolean contains(Object o) { 282 if (!(o instanceof Map.Entry)) 283 return false; 284 Map.Entry<K,V> entry = (Map.Entry<K,V>) o; 285 K key = entry.getKey(); 286 // key不在范圍內(nèi),返回false 287 if (!inRange(key)) 288 return false; 289 // 判斷是否有鍵和值如傳入節(jié)點(diǎn)的鍵和值相等的節(jié)點(diǎn) 290 TreeMap.Entry node = m.getEntry(key); 291 return node != null && 292 valEquals(node.getValue(), entry.getValue()); 293 } 294 // 移除一個節(jié)點(diǎn) 295 public boolean remove(Object o) { 296 if (!(o instanceof Map.Entry)) 297 return false; 298 Map.Entry<K,V> entry = (Map.Entry<K,V>) o; 299 K key = entry.getKey(); 300 if (!inRange(key)) 301 return false; 302 TreeMap.Entry<K,V> node = m.getEntry(key); 303 // 找到節(jié)點(diǎn)并移除,返回true 304 if (node!=null && valEquals(node.getValue(),entry.getValue())){ 305 m.deleteEntry(node); 306 return true; 307 } 308 return false; 309 } 310 } 311 312 //子類迭代器 313 abstract class SubMapIterator<T> implements Iterator<T> { 314 // 上一次被返回的節(jié)點(diǎn) 315 TreeMap.Entry<K,V> lastReturned; 316 // 下一個節(jié)點(diǎn) 317 TreeMap.Entry<K,V> next; 318 // “柵欄”key(如果是向大的方向遍歷,不能訪問key大于等于fenceKey的節(jié)點(diǎn);如果是向小的方向遍歷,不能訪問key小于等于fenceKey的節(jié)點(diǎn)) 319 final K fenceKey; 320 int expectedModCount; 321 // 構(gòu)造方法 322 SubMapIterator(TreeMap.Entry<K,V> first, 323 TreeMap.Entry<K,V> fence) { 324 expectedModCount = m.modCount; 325 lastReturned = null; 326 next = first; 327 fenceKey = fence == null ? null : fence.key; 328 } 329 // 判斷是否還有下一個節(jié)點(diǎn) 330 public final boolean hasNext() { 331 // 與普通的hasNext的判斷不同的是這里必須判斷next的key是否超出了fenceKey 332 return next != null && next.key != fenceKey; 333 } 334 // 獲得下一個節(jié)點(diǎn)的方法,比較容易理解 335 final TreeMap.Entry<K,V> nextEntry() { 336 TreeMap.Entry<K,V> e = next; 337 if (e == null || e.key == fenceKey) 338 throw new NoSuchElementException(); 339 if (m.modCount != expectedModCount) 340 throw new ConcurrentModificationException(); 341 next = successor(e); 342 lastReturned = e; 343 return e; 344 } 345 // 另一種遍歷方法,向前遍歷 346 final TreeMap.Entry<K,V> prevEntry() { 347 TreeMap.Entry<K,V> e = next; 348 if (e == null || e.key == fenceKey) 349 throw new NoSuchElementException(); 350 if (m.modCount != expectedModCount) 351 throw new ConcurrentModificationException(); 352 next = predecessor(e); 353 lastReturned = e; 354 return e; 355 } 356 // 刪除節(jié)點(diǎn)后可以繼續(xù)遍歷剩余的節(jié)點(diǎn),因?yàn)閯h除前用next保留了lastReturned節(jié)點(diǎn),而這個節(jié)點(diǎn)在刪除操作的過程中被替換成了它的繼承者 357 final void removeAscending() { 358 if (lastReturned == null) 359 throw new IllegalStateException(); 360 if (m.modCount != expectedModCount) 361 throw new ConcurrentModificationException(); 362 if (lastReturned.left != null && lastReturned.right != null) 363 // next指向lastReturned所指向的節(jié)點(diǎn),這個節(jié)點(diǎn)的內(nèi)容在刪除lastReturned的時候被改變了 364 next = lastReturned; 365 m.deleteEntry(lastReturned); 366 lastReturned = null; 367 expectedModCount = m.modCount; 368 } 369 // 刪除之后next指向的節(jié)點(diǎn)其實(shí)被刪除了,不能繼續(xù)迭代訪問 370 final void removeDescending() { 371 if (lastReturned == null) 372 throw new IllegalStateException(); 373 if (m.modCount != expectedModCount) 374 throw new ConcurrentModificationException(); 375 m.deleteEntry(lastReturned); 376 lastReturned = null; 377 expectedModCount = m.modCount; 378 } 379 380 } 381 //下面的幾個內(nèi)部類很簡單,都是對SubMapIterator的調(diào)用或間接調(diào)用,不再解釋 382 final class SubMapEntryIterator extends SubMapIterator<Map.Entry<K,V>> { 383 SubMapEntryIterator(TreeMap.Entry<K,V> first, 384 TreeMap.Entry<K,V> fence) { 385 super(first, fence); 386 } 387 public Map.Entry<K,V> next() { 388 return nextEntry(); 389 } 390 public void remove() { 391 removeAscending(); 392 } 393 } 394 395 final class SubMapKeyIterator extends SubMapIterator<K> { 396 SubMapKeyIterator(TreeMap.Entry<K,V> first, 397 TreeMap.Entry<K,V> fence) { 398 super(first, fence); 399 } 400 public K next() { 401 return nextEntry().key; 402 } 403 public void remove() { 404 removeAscending(); 405 } 406 } 407 408 final class DescendingSubMapEntryIterator extends SubMapIterator<Map.Entry<K,V>> { 409 DescendingSubMapEntryIterator(TreeMap.Entry<K,V> last, 410 TreeMap.Entry<K,V> fence) { 411 super(last, fence); 412 } 413 414 public Map.Entry<K,V> next() { 415 return prevEntry(); 416 } 417 public void remove() { 418 removeDescending(); 419 } 420 } 421 422 final class DescendingSubMapKeyIterator extends SubMapIterator<K> { 423 DescendingSubMapKeyIterator(TreeMap.Entry<K,V> last, 424 TreeMap.Entry<K,V> fence) { 425 super(last, fence); 426 } 427 public K next() { 428 return prevEntry().key; 429 } 430 public void remove() { 431 removeDescending(); 432 } 433 } 434 }

? ? ?NavigableSubMap類算是看了一遍,很復(fù)雜,自身是個內(nèi)部類,它里面還包含了好幾個類。理解它的代碼需要部分TreeMap中的其他代碼的深入理解,如涉及到的deleteEntry等方法(見《TreeMap源碼分析——基礎(chǔ)分析》)。

? ? ?下面看TreeMap的其他內(nèi)部類,它們是NavigableSubMap的子類。

? ? ?AscendingSubMap

1 // AscendingSubMap繼承自NavigableSubMap 2 static final class AscendingSubMap<K,V> extends NavigableSubMap<K,V> { 3 private static final long serialVersionUID = 912986545866124060L; 4 // 構(gòu)造方法,直接調(diào)用父類構(gòu)造方法 5 AscendingSubMap(TreeMap<K,V> m, 6 boolean fromStart, K lo, boolean loInclusive, 7 boolean toEnd, K hi, boolean hiInclusive) { 8 super(m, fromStart, lo, loInclusive, toEnd, hi, hiInclusive); 9 } 10 // 獲得比較器 11 public Comparator<? super K> comparator() { 12 return m.comparator(); 13 } 14 // “截取”子Map 15 public NavigableMap<K,V> subMap(K fromKey, boolean fromInclusive, 16 K toKey, boolean toInclusive) { 17 // 截取之前判斷是否超出范圍 18 if (!inRange(fromKey, fromInclusive)) 19 throw new IllegalArgumentException("fromKey out of range"); 20 if (!inRange(toKey, toInclusive)) 21 throw new IllegalArgumentException("toKey out of range"); 22 return new AscendingSubMap(m, 23 false, fromKey, fromInclusive, 24 false, toKey, toInclusive); 25 } 26 // “截取”子Map,headMap通過構(gòu)造方法便可以實(shí)現(xiàn) 27 public NavigableMap<K,V> headMap(K toKey, boolean inclusive) { 28 if (!inRange(toKey, inclusive)) 29 throw new IllegalArgumentException("toKey out of range"); 30 return new AscendingSubMap(m, 31 fromStart, lo, loInclusive, 32 false, toKey, inclusive); 33 } 34 // 和headMap類似 35 public NavigableMap<K,V> tailMap(K fromKey, boolean inclusive){ 36 if (!inRange(fromKey, inclusive)) 37 throw new IllegalArgumentException("fromKey out of range"); 38 return new AscendingSubMap(m, 39 false, fromKey, inclusive, 40 toEnd, hi, hiInclusive); 41 } 42 // 這個方法涉及到DescendingSubMap類的構(gòu)造方法,在下面會介紹到 43 public NavigableMap<K,V> descendingMap() { 44 NavigableMap<K,V> mv = descendingMapView; 45 return (mv != null) ? mv : 46 (descendingMapView = 47 new DescendingSubMap(m, 48 fromStart, lo, loInclusive, 49 toEnd, hi, hiInclusive)); 50 } 51 // 下面兩個方法都是對上面提到過的構(gòu)造方法的調(diào)用 52 Iterator<K> keyIterator() { 53 return new SubMapKeyIterator(absLowest(), absHighFence()); 54 } 55 Iterator<K> descendingKeyIterator() { 56 return new DescendingSubMapKeyIterator(absHighest(), absLowFence()); 57 } 58 // AscendingEntrySetView是一個視圖類,重寫了父類的iterator()方法,調(diào)用SubMapEntryIterator構(gòu)造迭代器 59 final class AscendingEntrySetView extends EntrySetView { 60 public Iterator<Map.Entry<K,V>> iterator() { 61 return new SubMapEntryIterator(absLowest(), absHighFence()); 62 } 63 } 64 // 獲取節(jié)點(diǎn)集合的方法 65 public Set<Map.Entry<K,V>> entrySet() { 66 EntrySetView es = entrySetView; 67 return (es != null) ? es : new AscendingEntrySetView(); 68 } 69 // 父類中抽象方法的實(shí)現(xiàn),都很簡單 70 TreeMap.Entry<K,V> subLowest() { return absLowest(); } 71 TreeMap.Entry<K,V> subHighest() { return absHighest(); } 72 TreeMap.Entry<K,V> subCeiling(K key) { return absCeiling(key); } 73 TreeMap.Entry<K,V> subHigher(K key) { return absHigher(key); } 74 TreeMap.Entry<K,V> subFloor(K key) { return absFloor(key); } 75 TreeMap.Entry<K,V> subLower(K key) { return absLower(key); } 76 }

? ? ?DescendingSubMap

1 // DescendingSubMap也繼承自NavigableSubMap,和上面的AscendingSubMap對應(yīng) 2 static final class DescendingSubMap<K,V> extends NavigableSubMap<K,V> { 3 private static final long serialVersionUID = 912986545866120460L; 4 DescendingSubMap(TreeMap<K,V> m, 5 boolean fromStart, K lo, boolean loInclusive, 6 boolean toEnd, K hi, boolean hiInclusive) { 7 super(m, fromStart, lo, loInclusive, toEnd, hi, hiInclusive); 8 } 9 // 構(gòu)造一個“相反”的比較器 10 private final Comparator<? super K> reverseComparator = 11 Collections.reverseOrder(m.comparator); 12 // 獲取的比較器是“相反”的比較器,比較結(jié)果會對調(diào) 13 public Comparator<? super K> comparator() { 14 return reverseComparator; 15 } 16 // subMap方法和AscendingSubMap類中類似 17 public NavigableMap<K,V> subMap(K fromKey, boolean fromInclusive, 18 K toKey, boolean toInclusive) { 19 if (!inRange(fromKey, fromInclusive)) 20 throw new IllegalArgumentException("fromKey out of range"); 21 if (!inRange(toKey, toInclusive)) 22 throw new IllegalArgumentException("toKey out of range"); 23 return new DescendingSubMap(m, 24 false, toKey, toInclusive, 25 false, fromKey, fromInclusive); 26 } 27 // 與AscendingSubMap中其實(shí)是相反的 28 public NavigableMap<K,V> headMap(K toKey, boolean inclusive) { 29 if (!inRange(toKey, inclusive)) 30 throw new IllegalArgumentException("toKey out of range"); 31 // 因?yàn)镈escendingSubMap表示的是逆序的map,所以其實(shí)是通過獲取原序的尾部 32 return new DescendingSubMap(m, 33 false, toKey, inclusive, 34 toEnd, hi, hiInclusive); 35 } 36 // 與headMap對應(yīng),tailMap其實(shí)獲取的是原序中的頭部 37 public NavigableMap<K,V> tailMap(K fromKey, boolean inclusive){ 38 if (!inRange(fromKey, inclusive)) 39 throw new IllegalArgumentException("fromKey out of range"); 40 return new DescendingSubMap(m, 41 fromStart, lo, loInclusive, 42 false, fromKey, inclusive); 43 } 44 // 逆序的逆序其實(shí)是正序 45 public NavigableMap<K,V> descendingMap() { 46 NavigableMap<K,V> mv = descendingMapView; 47 return (mv != null) ? mv : 48 (descendingMapView = 49 new AscendingSubMap(m, 50 fromStart, lo, loInclusive, 51 toEnd, hi, hiInclusive)); 52 } 53 // 剩余內(nèi)容和AscendingSubMap很類似,就不說了 54 Iterator<K> keyIterator() { 55 return new DescendingSubMapKeyIterator(absHighest(), absLowFence()); 56 } 57 Iterator<K> descendingKeyIterator() { 58 return new SubMapKeyIterator(absLowest(), absHighFence()); 59 } 60 final class DescendingEntrySetView extends EntrySetView { 61 public Iterator<Map.Entry<K,V>> iterator() { 62 return new DescendingSubMapEntryIterator(absHighest(), absLowFence()); 63 } 64 } 65 public Set<Map.Entry<K,V>> entrySet() { 66 EntrySetView es = entrySetView; 67 return (es != null) ? es : new DescendingEntrySetView(); 68 } 69 TreeMap.Entry<K,V> subLowest() { return absHighest(); } 70 TreeMap.Entry<K,V> subHighest() { return absLowest(); } 71 TreeMap.Entry<K,V> subCeiling(K key) { return absFloor(key); } 72 TreeMap.Entry<K,V> subHigher(K key) { return absLower(key); } 73 TreeMap.Entry<K,V> subFloor(K key) { return absCeiling(key); } 74 TreeMap.Entry<K,V> subLower(K key) { return absHigher(key); } 75 }

? ? ?最后一個內(nèi)部類是SubMap,它比較特別。這個類存在僅僅為了序列化兼容之前的版本不支持NavigableMap TreeMap。它被翻譯成一個舊版本AscendingSubMap子映射到一個新版本。這個類是從來沒有以其他方式使用。

1 // SubMap 繼承自AbstractMap;這個類存在僅僅為了序列化兼容之前的版本不支持NavigableMap TreeMap。它被翻譯成一個舊版本AscendingSubMap子映射到一個新版本。這個類是從來沒有以其他方式使用。 2 private class SubMap extends AbstractMap<K,V> 3 implements SortedMap<K,V>, java.io.Serializable { 4 private static final long serialVersionUID = -6520786458950516097L; 5 // 標(biāo)識是否從map的開始到結(jié)尾都屬于子map 6 private boolean fromStart = false, toEnd = false; 7 // 開始位置和結(jié)束位置的key 8 private K fromKey, toKey; 9 private Object readResolve() { 10 return new AscendingSubMap(TreeMap.this, 11 fromStart, fromKey, true, 12 toEnd, toKey, false); 13 } 14 // 結(jié)合類定義和類的說明就明白為什么提供了這么多方法但是都不能用了 15 public Set<Map.Entry<K,V>> entrySet() { throw new InternalError(); } 16 public K lastKey() { throw new InternalError(); } 17 public K firstKey() { throw new InternalError(); } 18 public SortedMap<K,V> subMap(K fromKey, K toKey) { throw new InternalError(); } 19 public SortedMap<K,V> headMap(K toKey) { throw new InternalError(); } 20 public SortedMap<K,V> tailMap(K fromKey) { throw new InternalError(); } 21 public Comparator<? super K> comparator() { throw new InternalError(); } 22 }

? ? ?結(jié)合上面的內(nèi)部類分析和《TreeMap源碼分析——基礎(chǔ)分析》,對TreeMap的實(shí)現(xiàn)應(yīng)該有個大致輪廓。不過TreeMap的代碼很長很復(fù)雜,不自己看一遍分析一邊,很難想明白,很難理解進(jìn)去。

? ? ?自己也理解的不是很好,如果有牛人有對TreeMap的看法,望多指點(diǎn)。

?

?

?

?

?

轉(zhuǎn)載于:https://www.cnblogs.com/hzmark/archive/2013/01/05/TreeMap-Deep.html

總結(jié)

以上是生活随笔為你收集整理的TreeMap源码分析——深入分析(基于JDK1.6)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

久久成人午夜视频 | 国产精品美女久久久免费 | 久久久久亚洲国产 | 在线免费高清一区二区三区 | 成人黄色片在线播放 | 日韩天天综合 | 色狠狠综合天天综合综合 | 国产精品一区二区免费看 | 亚洲第一成网站 | 久久精品久久精品久久39 | 国产精品一区二区果冻传媒 | 色偷偷中文字幕 | 波多野结衣在线视频免费观看 | 日韩成人中文字幕 | sm免费xx网站 | 国产视频一级 | 亚洲精品久久久久久久蜜桃 | 成人片在线播放 | 婷婷av网 | 国产成人黄色在线 | 91精品视频网站 | 国产精品1024 | www.亚洲精品 | 日韩在线视频国产 | 午夜久久 | 韩日色视频| 久久情爱 | 成人av教育 | 在线视频电影 | 亚洲区另类春色综合小说 | 美女在线免费观看视频 | 13日本xxxxxⅹxxx20 | 国产又粗又猛又爽又黄的视频先 | 十八岁免进欧美 | 人人干在线观看 | 操操操日日日干干干 | 欧美日韩国产精品一区二区三区 | 中文字幕韩在线第一页 | 日韩视频精品在线 | 麻豆免费在线播放 | 日韩在线视频网 | 久久精品99国产国产精 | 国产正在播放 | 91久久爱热色涩涩 | 久久精品爱爱视频 | 成片人卡1卡2卡3手机免费看 | 操操碰 | 国产精品一级视频 | 亚洲国产视频网站 | 久久精品一二三区白丝高潮 | 亚洲精品久久久久999中文字幕 | 99色资源| 在线观看国产麻豆 | 成年人电影免费在线观看 | 久久精品一区二区三区视频 | 久久久久亚洲精品 | 日本三级吹潮在线 | 99热这里只有精品8 久久综合毛片 | 国产一区在线免费观看视频 | 亚洲日本一区二区在线 | 亚洲第一区在线观看 | 日韩在线第一 | 免费观看91 | 99久久激情视频 | 在线观看日韩免费视频 | 久久免费美女视频 | 欧美在线视频免费 | 男女视频久久久 | 欧美激情精品久久久久久 | 亚洲高清网站 | 国产一级做a | 99视频这里有精品 | 国产精品女 | 亚洲婷婷免费 | 久久99精品国产麻豆宅宅 | 国产精品九九久久99视频 | 久久精品国产亚洲a | 国产三级久久久 | 久久久免费国产 | 国产小视频国产精品 | 综合铜03| 国产精品色在线 | 天天操天天草 | 亚洲干视频在线观看 | 久草网站 | 在线国产91| 亚洲黄色在线观看 | 久久精品国产第一区二区三区 | 91九色视频在线 | 亚洲免费精品一区二区 | 激情视频免费在线 | 国产18精品乱码免费看 | 在线看v片 | 国产小视频在线 | 97超碰精品 | 精品福利在线观看 | 免费男女网站 | 亚洲性xxxx | 欧美综合国产 | 天天操天天射天天 | 日本久久电影 | 精品国产99国产精品 | 天天操狠狠操夜夜操 | 成人久久免费 | 免费视频 你懂的 | 日韩免费看 | 久久成人麻豆午夜电影 | 91福利视频久久久久 | 日韩欧美精品在线观看视频 | 精品1区二区 | 粉嫩一区二区三区粉嫩91 | 欧洲精品久久久久毛片完整版 | 久久看视频 | 国产亚洲视频系列 | 热re99久久精品国产66热 | 伊人热| 97超视频 | 91精品国产高清自在线观看 | 香蕉视频在线免费 | 久久久久久久久久免费 | 香蕉精品视频在线观看 | 97福利 | 日韩中文字幕免费在线播放 | 久久好看免费视频 | 国内精品久久久久久久97牛牛 | 99精品国产福利在线观看免费 | 在线va网站| 亚洲人人爱 | 日本精品一区二区三区在线观看 | 中文字幕有码在线播放 | 亚洲国产成人精品在线观看 | 国内久久视频 | 去看片| 日韩视频1区 | 成年人在线免费看视频 | 蜜桃视频日本 | 五月激情六月丁香 | 深爱激情综合网 | 国产a国产a国产a | 国产明星视频三级a三级点| 久久网站最新地址 | 亚洲一区尤物 | 久久久久久久久久网 | 国产精品去看片 | 亚洲日本中文字幕在线观看 | 色婷婷丁香 | 综合久久久久久 | av福利在线免费观看 | 精品国产免费av | 欧美成人日韩 | 99产精品成人啪免费网站 | 亚洲国产精品免费 | 婷婷午夜天 | 久久人人97超碰com | 精品久久久网 | 婷婷色中文 | 草久草久 | 99久久久久免费精品国产 | 日韩成人精品一区二区三区 | 911精品美国片911久久久 | av电影免费在线看 | 午夜 免费 | 国产成人精品一区二区在线观看 | av一本久道久久波多野结衣 | 欧美色婷 | 可以免费看av | 又色又爽的网站 | 亚洲蜜桃av | 国产精品一区二区三区四 | 色婷婷国产 | 性色视频在线 | av福利免费| 高清在线观看av | 成人毛片一区二区三区 | 99视频在线看 | 日韩成人免费在线观看 | 亚洲乱码国产乱码精品天美传媒 | 国产人成在线视频 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 黄色日本免费 | 国产精品女同一区二区三区久久夜 | 麻豆精品传媒视频 | 亚洲激情p | 日韩视频1| 国产精品久久电影观看 | 日日日日| 五月婷婷狠狠 | 91九色视频| 精品在线亚洲视频 | 日韩精品免费一区二区在线观看 | 99热在线这里只有精品 | 久草www| 天堂素人在线 | 国产成人免费观看 | 国产v视频 | 在线涩涩 | 国产精品高潮在线观看 | 91精品久久久久久综合乱菊 | 久久香蕉国产精品麻豆粉嫩av | 韩国精品一区二区三区六区色诱 | 中文国产在线观看 | 一 级 黄 色 片免费看的 | 99精品热视频 | 91精品在线麻豆 | 中文字幕在线影院 | 国内精品久久久久国产 | 97免费在线观看 | 日韩免费网站 | 午夜久久网 | 亚洲爱av| 天天鲁天天干天天射 | 久草在线视频首页 | 日韩欧美成人网 | 国产高清不卡 | 五月婷婷激情六月 | 欧美a在线看 | 激情婷婷在线 | 日韩18p| 少妇bbbb揉bbbb日本 | 亚洲人人爱 | 久久爱导航| 色播六月天 | 久久成人高清视频 | 美女视频黄是免费的 | 蜜桃视频色 | 91精品系列 | 91精品国产入口 | 成人一区二区三区在线观看 | 视频一区二区精品 | 天天操天天怕 | 丁香花在线观看免费完整版视频 | 一区在线播放 | 国产亚洲精品久久久久久网站 | 国产成人一区二区精品非洲 | 天天天色综合 | 天天操天天舔天天干 | 亚洲一区视频在线播放 | 国产一级黄色片免费看 | 日日夜操| www.夜夜| 欧美日韩精品二区第二页 | 日韩欧美不卡 | 日韩一级网站 | 久久久久久伊人 | 色狠狠综合天天综合综合 | 麻豆视频免费在线播放 | 中文字幕视频一区 | 婷婷久久综合九色综合 | 在线99热| 人人爽人人爽人人爽人人爽 | 亚洲日本成人网 | 成人一级黄色片 | 中文字幕在线人 | 国产一区免费看 | 日韩欧美视频一区二区 | 中文字幕在线免费 | 精品三级av | 在线视频手机国产 | 在线观看成人一级片 | 国产色a在线观看 | 91成人免费观看视频 | 色网av | 久久久人人人 | 五月天婷婷视频 | 91在线播 | 美女免费黄视频网站 | 亚洲高清在线视频 | 夜夜操天天干 | 欧美日韩视频免费看 | 国产五十路毛片 | 碰碰影院 | 色大片免费看 | av官网| 在线免费观看一区二区三区 | 麻豆成人精品视频 | 激情视频一区二区 | 蜜臀久久99精品久久久久久网站 | 尤物九九久久国产精品的分类 | 日韩精品资源 | 中文国产成人精品久久一 | 亚洲 欧美 综合 在线 精品 | 久久综合婷婷国产二区高清 | 色婷婷国产精品一区在线观看 | 成人黄色电影免费观看 | 欧美性色综合网 | 亚洲人在线视频 | 色婷婷免费视频 | 国产成人免费av电影 | 国产精品 欧美 日韩 | 欧美超碰在线 | 少妇bbw撒尿 | 麻豆91网站| 人人揉人人揉人人揉人人揉97 | 美州a亚洲一视本频v色道 | 久久久免费 | 免费久久网站 | 国产精品自产拍在线观看网站 | 青青网视频 | 国产精品毛片网 | 99视频一区二区 | 国产最新视频在线 | 国产精品理论视频 | 日日日操操 | 在线成人av | 亚洲色综合 | 黄色小说在线观看视频 | 午夜精品视频一区二区三区在线看 | 国产中文字幕视频 | 亚洲精品视频在线观看免费视频 | 欧美国产日韩在线观看 | 2023国产精品自产拍在线观看 | 成人蜜桃视频 | 国产精品网红直播 | 日韩黄色免费看 | 欧美日韩中文字幕综合视频 | 嫩小bbbb摸bbb摸bbb | 国产成人久久精品77777综合 | 92国产精品久久久久首页 | 久久人视频 | 99热亚洲精品| 啪啪小视频网站 | 国产亚洲视频在线 | 久久精品区| 激情自拍av| 激情影院在线 | 在线视频在线观看 | 国产精品中文久久久久久久 | 九精品| 亚洲综合成人婷婷小说 | 一区二区三区视频在线 | 亚洲午夜久久久久 | 免费色黄 | 久久精品国产亚洲精品2020 | 97成人啪啪网 | 视频在线99 | 人人干人人爽 | 综合视频在线 | 国产又粗又长的视频 | 亚洲欧洲精品视频 | 国产男女无遮挡猛进猛出在线观看 | 久久精品视频免费观看 | 不卡中文字幕av | 中国一级片在线 | 久草在线观看资源 | 天堂网在线视频 | 人人射人人爱 | 97在线影院 | 又黄又爽又刺激视频 | 在线看国产一区 | 免费网站在线观看成人 | 欧美日韩不卡在线视频 | www.天天成人国产电影 | 国产成人av免费在线观看 | 午夜视频播放 | 91精品国产91久久久久 | 视频在线观看日韩 | 成人在线观看网址 | 久久久久久久毛片 | 97超碰.com | 麻豆网站免费观看 | 97视频在线看 | 91中文字幕视频 | 欧美日韩精品影院 | 一区二三国产 | 69久久99精品久久久久婷婷 | 91精品国产一区二区在线观看 | 精品1区2区3区 | 日韩亚洲国产精品 | 97超碰免费在线 | 国产最新精品视频 | 欧美日韩亚洲国产一区 | 国产精品999久久久 久产久精国产品 | 国产日韩欧美在线影视 | 一级欧美黄| av黄色大片 | 日韩欧美在线一区二区 | 一区二区三区在线免费观看视频 | av在线免费网 | 国产一区二区三区高清播放 | 你操综合 | 亚洲无吗av| 亚洲精品国产精品久久99热 | 五月天激情在线 | 99色精品视频 | 91成人久久 | 国产中文 | zzijzzij亚洲日本少妇熟睡 | 91精品办公室少妇高潮对白 | 亚洲综合欧美精品电影 | 最近中文字幕免费av | 91在线免费观看国产 | 热99久久精品 | 色网址99 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 东方av在 | 国产一区网址 | 国产精品九九视频 | 日日夜夜人人天天 | 韩日av在线 | 欧美福利视频 | 91精品国产自产老师啪 | 久久a久久 | 狠狠干狠狠插 | 亚洲免费不卡 | 色噜噜在线观看 | 国产精品一区二区三区在线看 | 天天插综合 | 免费久久精品视频 | 99热在线国产| 中国一级片免费看 | 久久色在线观看 | 黄色午夜 | 四虎5151久久欧美毛片 | 国产精品手机在线观看 | 在线视频 区 | www操操操 | 色多多污污 | 日韩videos高潮hd| 欧美日韩高清免费 | 国产精品亚州 | 国产午夜在线观看视频 | 国产精品久久久久久一二三四五 | 亚洲a成人v | 日日精品 | 色噜噜日韩精品欧美一区二区 | 99精品视频精品精品视频 | 久久99久久99精品中文字幕 | 综合视频在线 | 久久成年人 | 天天色天天射综合网 | 深夜免费福利在线 | 欧美日本高清视频 | av免费在线观看网站 | 午夜视频在线网站 | 国产亚洲亚洲 | 又爽又黄在线观看 | 国产精品网站 | aaa免费毛片 | 99久久婷婷国产 | 99久久精品无免国产免费 | 在线观看视频在线 | 久久综合色综合88 | 亚洲精品视频网 | 最新亚洲视频 | 国产99精品 | 欧美另类亚洲 | 久久免费的精品国产v∧ | 最新成人在线 | 二区三区在线视频 | 久久久久高清毛片一级 | 日韩精品高清视频 | 亚洲国产精品成人女人久久 | 97理论片| 国产又粗又猛又色又黄视频 | 91看片网址 | 狠狠精品 | 九九亚洲视频 | 最新中文字幕在线播放 | 日韩成人av在线 | 高潮毛片无遮挡高清免费 | 97狠狠操 | 手机看片1042| 日韩av专区 | 国产中文在线播放 | 美女视频免费精品 | 91最新中文字幕 | 婷婷色综 | 亚洲精品视频网址 | 黄色在线看网站 | 国产视频日韩 | 天天色天天 | 成人黄色影片在线 | 天天综合网 天天综合色 | 久久精品99国产精品酒店日本 | 欧美激情亚洲综合 | 色婷婷视频在线 | 久久精品草 | 欧美一级片免费观看 | 欧美一区二区伦理片 | 欧美污污视频 | 中文字幕在线观看视频一区二区三区 | 久久综合影视 | 亚洲一区二区麻豆 | 精品视频中文字幕 | 天天天干天天天操 | 婷婷精品国产一区二区三区日韩 | 国产人成一区二区三区影院 | 日韩欧美综合 | 日韩在线| 亚洲夜夜网 | 成人免费观看网站 | 国产亚洲欧美精品久久久久久 | 九色91在线视频 | 亚洲久草在线视频 | av在线之家电影网站 | 欧美精品一区二区在线播放 | 日韩欧美一区二区三区视频 | 99久久影视 | 日韩色av色资源 | 月下香电影| 国产精久久久久久久 | 夜夜骑首页 | 五月综合久久 | a久久久久 | 成人免费视频观看 | 四虎影视www | 久久欧美精品 | 国产91亚洲精品 | 精品乱码一区二区三四区 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 成人久久久久久久久 | 午夜手机看片 | 国产精品丝袜在线 | 国产精品女主播一区二区三区 | 操高跟美女 | 亚洲一区二区三区在线看 | 六月丁香久久 | 成人黄色一级视频 | 天天综合久久 | 日韩精品在线一区 | www.黄色片网站 | 五月天久久狠狠 | 四虎精品成人免费网站 | 色综合色综合色综合 | 美女网站色 | 又黄又爽的免费高潮视频 | 操操日日 | 久插视频 | 久久96国产精品久久99软件 | 五月激情丁香图片 | 在线国产高清 | 91社区国产高清 | 福利一区视频 | 国产分类视频 | 91看片在线看片 | 国产精品久久99精品毛片三a | 毛片网站观看 | 国产视频不卡一区 | 久久少妇免费视频 | 成人福利在线观看 | 国产成人在线免费观看 | 久久久久久国产精品免费 | 91传媒视频在线观看 | av片一区二区 | 日韩久久午夜一级啪啪 | 日韩在线一级 | 日韩理论视频 | 在线精品亚洲一区二区 | 亚洲精品成人 | 久久国产精品一国产精品 | 成人黄色小说在线观看 | 欧美一级特黄aaaaaa大片在线观看 | 四虎永久免费在线观看 | 久久精品久久99 | 久草视频中文在线 | 91大神免费在线观看 | 一区二区三区在线不卡 | 91秒拍国产福利一区 | 日本成人中文字幕在线观看 | 国产成人一区二区精品非洲 | 丁香5月婷婷| 91av99| av网站免费在线 | 欧美日韩中文字幕在线视频 | 国产精品久久久久永久免费观看 | 欧美一区日韩一区 | 91九色成人| 97成人精品视频在线播放 | 国产成人精品久久亚洲高清不卡 | 国产一区二区高清 | 精品亚洲在线 | 97电影院在线观看 | 97人人澡人人爽人人模亚洲 | 狠狠色丁香久久婷婷综合丁香 | 亚洲狠狠丁香婷婷综合久久久 | 成人一级免费视频 | 国产亚洲精品女人久久久久久 | 国产精品2019| 成年人精品 | 久久精品国产免费观看 | 日韩理论电影在线观看 | 久久大视频 | 久久手机免费观看 | 国产美女网站在线观看 | 91在线产啪 | 成人91在线 | 91麻豆免费版 | 国产亚洲精品女人久久久久久 | 日韩黄色在线电影 | 国产无遮挡又黄又爽在线观看 | 久久久久99精品国产片 | 不卡电影一区二区三区 | 一区二区三区在线观看 | 亚洲黄色软件 | 99精彩视频| 丁五月婷婷 | 久久久久久欧美二区电影网 | 特级毛片aaa | 成年人电影免费在线观看 | 国产精品99精品久久免费 | 麻豆视频免费 | 日韩网站在线 | 国产日产精品一区二区三区四区的观看方式 | 99超碰在线观看 | 色在线高清 | 亚洲精品午夜aaa久久久 | 欧美另类xxx | 亚洲精品www| 成年人在线观看网站 | 奇米影视777四色米奇影院 | 激情综合一区 | 在线观看资源 | 91精品视频播放 | 中文字幕在线观看一区二区三区 | 麻豆系列在线观看 | 激情丁香综合五月 | 国产色在线观看 | 国产一级片视频 | 丁香五婷 | 国产精品乱码久久久 | 亚洲日本va午夜在线影院 | 国产精品久久久久久久av电影 | 97精品视频在线 | 日韩av成人在线观看 | 欧美黑人xxxx猛性大交 | 国产精品久久久久久久久久ktv | 视频精品一区二区三区 | 亚洲视频axxx | 五月天亚洲激情 | 九色91av| 国产乱码精品一区二区三区介绍 | 国产精品国产亚洲精品看不卡 | 亚洲首页 | 国产中文在线播放 | 91丨九色丨国产在线 | 亚洲黄色免费网站 | 免费av免费观看 | 狠狠操欧美 | av中文字幕网址 | 国产成人精品久久久久 | 免费成人短视频 | 天天av综合网 | av成人资源| 午夜国产福利在线 | 激情五月婷婷综合网 | 欧美性黄网官网 | 国产福利一区二区三区视频 | 免费观看黄色12片一级视频 | 久久综合婷婷国产二区高清 | 福利网址在线观看 | 亚洲国产精品久久久久久 | 伊人色综合网 | 国产精品久久99综合免费观看尤物 | 国产精品免费看久久久8精臀av | 亚洲成a人片在线观看中文 中文字幕在线视频第一页 狠狠色丁香婷婷综合 | 久久综合加勒比 | 天天操天天干天天操天天干 | 国产久草在线观看 | 国产精品久久久久久久久免费 | 亚洲久草在线 | 国产小视频在线免费观看视频 | 日本99热 | bbbbb女女女女女bbbbb国产 | 激情五月开心 | 黄色三级在线观看 | 国产精品一区二区三区在线播放 | 精品久久久久久亚洲综合网 | 在线黄色国产 | 免费看久久久 | 国产 欧美 日产久久 | 深夜国产在线 | 欧美成人区 | 97超碰超碰久久福利超碰 | aav在线| 国产精久久久久久妇女av | 国产一级h| 国产亚洲精品美女 | 国产一级黄色片免费看 | 婷久久 | 久久综合精品一区 | 国产成人福利在线观看 | 日韩一区二区三区在线观看 | 亚洲干视频在线观看 | 国产精品成人久久久 | 天天天天天天干 | 欧美大片在线观看一区 | 成人在线视频论坛 | 中文字幕色在线视频 | 久久久三级视频 | 久久免费精品国产 | 亚洲精品在线看 | 亚洲黄色软件 | 久久视频精品在线观看 | 欧美日韩免费在线视频 | 超碰大片 | 91最新网址 | 国产xx在线| 一区二区视 | 日本精品在线视频 | 免费观看一级特黄欧美大片 | 欧美a级一区二区 | 国产一级精品视频 | 天天色天天操天天爽 | 黄毛片在线观看 | 日韩精品专区在线影院重磅 | 五月天久久综合网 | 成人免费视频播放 | 久久在视频| 亚洲精品视频免费在线 | 国产亚洲人| www国产精品com | 不卡的av电影在线观看 | 久久精品老司机 | 亚洲h在线播放在线观看h | 久久精品视频国产 | 欧美精品被 | 久久噜噜少妇网站 | 免费看片成年人 | 制服丝袜天堂 | 在线观看亚洲国产精品 | 久久综合狠狠综合 | 婷婷爱五月天 | 亚洲成av | 91精品一区在线观看 | 日本黄色免费播放 | 伊人久久精品久久亚洲一区 | 黄色毛片大全 | 亚洲一级国产 | 精品av在线播放 | 一色屋精品视频在线观看 | 一区在线观看 | 精品国自产在线观看 | 插婷婷 | 免费网站在线观看成人 | 国产高清免费av | 日韩精品网址 | 国产精品毛片一区二区三区 | 午夜免费在线观看 | 亚州av一区 | 欧美另类xxx | 国产精品 亚洲精品 | 精品成人网 | 日韩精品不卡在线观看 | 91最新视频 | 精品久久久久久亚洲综合网 | 中文字幕一区二区三区久久蜜桃 | 国产一级免费在线观看 | av三级在线播放 | 国产在线97 | 99精品久久99久久久久 | 久久天天躁狠狠躁亚洲综合公司 | 91av在线免费看 | 在线视频 国产 日韩 | 国产高清无线码2021 | 欧美激情精品 | 国产69精品久久久久9999apgf | 西西444www大胆高清视频 | 亚洲理论片 | 免费看污的网站 | 黄色福利网 | 中文字幕在线免费观看 | av中文字幕日韩 | 国产99在线播放 | 日日干天天插 | 91黄色视屏| 久久精品国产精品亚洲精品 | 精品九九久久 | 91免费高清 | 成年人免费在线观看网站 | 日韩三级视频在线观看 | 国产一级做a| 久久午夜电影 | 97日日碰人人模人人澡分享吧 | 又黄又爽又湿又无遮挡的在线视频 | 国产精品久久一卡二卡 | 最近中文字幕免费视频 | 久久久久久久久久久久久国产精品 | 香蕉视频在线视频 | aaa亚洲精品一二三区 | 超碰97国产精品人人cao | 国产视频久久久 | 黄色a三级 | 色综合网| 91精品久久久久久粉嫩 | 天天干天天插伊人网 | 日韩专区一区二区 | 国产午夜精品一区二区三区四区 | 网站在线观看日韩 | 91精品天码美女少妇 | 久草网在线观看 | 日韩精品久久久久久 | 亚洲激情 在线 | 在线视频 一区二区 | 狠狠黄 | 激情综合亚洲 | 久久天堂亚洲 | 久久综合久久综合久久综合 | 国产中出在线观看 | 黄色一级在线免费观看 | 日韩精品2区 | 狠狠网站 | av一级免费 | 午夜av片| 日本精品视频在线 | 亚洲黄色在线看 | 在线三级中文 | 狠狠干夜夜操天天爽 | 天天射天天爱天天干 | 日韩精品中文字幕有码 | 91在线精品一区二区 | 国产伦精品一区二区三区在线 | 免费色视频网站 | 波多野结衣久久资源 | 国产69久久久欧美一级 | 成人91在线 | 精品国产一二三 | 久草在线免费看视频 | 国产福利精品一区二区 | 欧美日韩一区二区三区视频 | 日韩精品第1页 | 亚洲在线视频播放 | 国产一区视频导航 | 久久9999久久免费精品国产 | 91av在线电影 | 一级特黄aaa大片在线观看 | 狠狠干婷婷色 | 久草国产在线 | 国产精品99久久久久的智能播放 | 在线欧美小视频 | 国产成人福利在线 | 欧美日韩不卡在线视频 | 亚洲一区二区三区毛片 | 色91在线 | 久久毛片网 | 又黄又刺激视频 | 99av在线视频| 欧美成人中文字幕 | 日韩一区精品 | 中文在线a√在线 | 国产男女无遮挡猛进猛出在线观看 | 日韩精品一区不卡 | 天天干夜夜操视频 | 韩国精品在线观看 | 高清不卡一区二区三区 | 免费的黄色的网站 | 国产麻豆电影在线观看 | 午夜精品一区二区三区在线观看 | 国产在线观看a | 免费在线观看成人 | 久久久精品国产一区二区 | 国产精品大尺度 | 国产aa精品 | 成人黄色电影免费观看 | 日韩一区二区在线免费观看 | 精品毛片在线 | av电影在线免费 | 欧美另类色图 | 欧美成人基地 | 国产99久久九九精品免费 | 久久久美女| 91大神精品视频在线观看 | 美女视频一区二区 | 欧美一区二区在线免费看 | 成人午夜影视 | 日韩欧美视频一区 | 在线亚洲人成电影网站色www | 亚洲国产精品久久久 | 91在线文字幕 | 在线视频1卡二卡三卡 | 麻豆视频在线免费观看 | 天天操天天草 | 久草网免费 | 婷婷综合成人 | 福利网址在线观看 | 久久久91精品国产一区二区精品 | 久久99精品久久久久久秒播蜜臀 | www国产精品com | 日韩免费高清 | 色婷婷亚洲精品 | 免费看国产曰批40分钟 | 亚洲在线视频播放 | 久久亚洲影院 | 亚洲免费公开视频 | av在线播放亚洲 | 欧美色图30p | 日韩精品免费一区二区在线观看 | 日韩av有码在线 | 国产99视频在线观看 | 九色精品在线 | 欧洲色综合 | 欧美日韩高清在线 | 天天射天天色天天干 | 国产日韩在线视频 | 国产69精品久久久久久久久久 | 亚洲永久国产精品 | 久久成人麻豆午夜电影 | 欧美男男激情videos | 18pao国产成视频永久免费 | 综合在线亚洲 | 超碰人人在线 | 国产第一页在线观看 | 色视频在线观看免费 | 少妇超碰在线 | 久久不卡国产精品一区二区 | 国产精品99久久久久久人免费 | 国产在线观看高清视频 | 国产高清精| 在线观看黄色国产 | 欧美精品乱码久久久久 | 日韩精品不卡在线观看 | 日日夜夜精品视频天天综合网 | 91在线影院| 天堂网av在线 | 亚洲国产三级 | 91免费的视频在线播放 | 激情av一区二区 | 成人免费视频观看 | 国产91精品在线观看 | 亚洲精品乱码久久久久久高潮 | 国产一级二级在线播放 | 国产精品久久久久永久免费观看 | www色综合 | 91成版人在线观看入口 | 夜夜操天天摸 | 国产小视频在线免费观看视频 | 亚洲天天在线 | 91热| 99精品国产兔费观看久久99 | 日本精品一区二区三区在线观看 | 成人a v视频 | 亚洲一级电影视频 | 精品久操 | 中文资源在线官网 | 久久精品一区二 | 久草视频国产 | 亚洲精品视频二区 | 久久99网 | 五月婷婷六月丁香在线观看 | 色婷婷综合五月 | 中文字幕一区二区三区久久蜜桃 | 视频国产精品 | 国产精品一区二区三区视频免费 | 九九九九精品九九九九 | 深夜福利视频在线观看 | 人人干狠狠操 | 91精品区| 最近更新好看的中文字幕 | 日韩一区二区三区在线观看 | 成人国产网址 | 国产精品不卡一区 | 久久综合九色 | 国内精品久久天天躁人人爽 | 久久免费视频一区 | 四月婷婷在线观看 | 久久精品这里热有精品 | 一区二区三区四区在线免费观看 | 欧美精品少妇xxxxx喷水 | 中文字幕a∨在线乱码免费看 | 国产剧情一区二区在线观看 | 日韩经典一区二区三区 | 夜夜躁日日躁狠狠久久88av | av中文字幕在线看 | 日韩av片免费在线观看 | 国产在线看 | 制服丝袜亚洲 | 五月婷婷在线观看视频 | 国产91精品一区二区 | 国产一级视频 | 国产精品专区h在线观看 | 午夜久久 | 中文字幕在线日本 | 欧美视频在线二区 | 中文字幕乱在线伦视频中文字幕乱码在线 | 日本三级在线观看中文字 | www国产精品com | 色婷婷在线播放 | 久久精品国产精品亚洲精品 | 欧美在线视频第一页 | 一区二区三区国产欧美 | 中文字幕在线影院 | 激情欧美丁香 | 最近日韩中文字幕中文 | 狠狠操天天干 | 国产高清av在线播放 | 在线观看的av | 天天艹日日干 | 黄色影院在线免费观看 | 九九涩涩av台湾日本热热 | 国产99久久久欧美黑人 | 欧美经典久久 | 精品欧美乱码久久久久久 | 91一区啪爱嗯打偷拍欧美 | 精品二区久久 | 国产精品v欧美精品v日韩 | 日韩中文在线视频 | 在线国产不卡 | 色综合久久久久网 | 亚洲精品视频免费在线 |