国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

入門JDK集合之HashMap解析

 更新時(shí)間:2021年06月11日 15:10:23   作者:興趣使然的草帽路飛  
HashMap---基于哈希表的 Map 接口的實(shí)現(xiàn)。此實(shí)現(xiàn)提供所有可選的映射操作,并允許使用 null 值和 null 鍵。(除了非同步和允許使用 null 之外,HashMap 類與 Hashtable 大致相同

0.前言

HashMap簡述:

  • HashMap 基于哈希表的 Map 接口實(shí)現(xiàn),是以 key-value 存儲(chǔ)形式存在,即主要用來存放鍵值對。HashMap 的實(shí)現(xiàn)不是同步的,這意味著它不是線程安全的。它的 key、value 都可以為 null,此外,HashMap 中的映射不是有序的。
  • jdk1.8 之前 HashMap 由 數(shù)組 + 鏈表 組成,數(shù)組是 HashMap 的主體,鏈表則是主要為了解決哈希沖突(兩個(gè)對象調(diào)用的 hashCode 方法計(jì)算的哈希值經(jīng)哈希函數(shù)算出來的地址被別的元素占用)而存在的(“拉鏈法”解決沖突)。jdk1.8 以后在解決哈希沖突時(shí)有了較大的變化,當(dāng)鏈表長度大于閾值(或者紅黑樹的邊界值,默認(rèn)為 8 )并且當(dāng)前數(shù)組的長度大于 64 時(shí),此時(shí)此索引位置上的所有數(shù)據(jù)改為使用紅黑樹存儲(chǔ)。

HashMap擴(kuò)容機(jī)制簡述:

HashMap == 數(shù)組+散鏈表+紅黑樹

  • HashMap 默認(rèn)初始桶位數(shù)16,如果某個(gè)桶中的鏈表長度大于8,則先進(jìn)行判斷:
  • 如果桶位數(shù)小于64,則先進(jìn)行擴(kuò)容(2倍),擴(kuò)容之后重新計(jì)算哈希值,這樣桶中的鏈表長度就變短了(之所以鏈表長度變短與桶的定位方式有關(guān),請接著往下看)。
  • 如果桶位數(shù)大于64,且某個(gè)桶中的鏈表長度大于8,則對鏈表進(jìn)行樹化(紅黑樹,即自平衡的二叉樹)
  • 如果紅黑樹的節(jié)點(diǎn)數(shù)小于6,樹也會(huì)重新變會(huì)鏈表。

所以得出樹化條件:鏈表閾值大于8,且桶位數(shù)大于64(數(shù)組長度),才進(jìn)行樹化。

元素放入桶(數(shù)組)中,定位桶的方式:通過數(shù)組下標(biāo) i 定位,添加元素時(shí),目標(biāo)桶位置 i 的計(jì)算公式,i = hash & (cap - 1),cap為容量。

為什么優(yōu)先擴(kuò)容桶位數(shù)(數(shù)組長度),而不是直接樹化?

  • 這樣做的目的是因?yàn)?,?dāng)桶位數(shù)(數(shù)組長度)比較小時(shí),應(yīng)盡量避開紅黑樹結(jié)構(gòu),這種情況下變?yōu)榧t黑樹結(jié)構(gòu),反而會(huì)降低效率。因?yàn)榧t黑樹需要逬行左旋,右旋,變色這些操作來保持平衡。同時(shí)數(shù)組長度小于64時(shí),搜索時(shí)間相對要快些。所以結(jié)上所述為了提高性能和減少搜索時(shí)間,底層閾值大于8并且數(shù)組長度大于64時(shí),鏈表才轉(zhuǎn)換為紅黑樹,具體可以參考下文要講述的 treeifyBin() 方法。
  • 而當(dāng)閾值大于 8 并且數(shù)組長度大于 64 時(shí),雖然增了紅黑樹作為底層數(shù)據(jù)結(jié)構(gòu),結(jié)構(gòu)變得復(fù)雜了,但是,長度較長的鏈表轉(zhuǎn)換為紅黑樹時(shí),效率也變高了。

HashMap 特點(diǎn):

  • 存儲(chǔ)無序;
  • 鍵和值位置都可以是 null,但是鍵位置只能存在一個(gè) null;
  • 鍵位置是唯一的,是由底層的數(shù)據(jù)結(jié)構(gòu)控制的;jdk1.8 前數(shù)據(jù)結(jié)構(gòu)是鏈表+數(shù)組,jdk1.8 之后是鏈表+數(shù)組+紅黑樹;
  • 閾值(邊界值)> 8 并且桶位數(shù)(數(shù)組長度)大于 64,才將鏈表轉(zhuǎn)換為紅黑樹,變?yōu)榧t黑樹的目的是為了高效的查詢;

1.HashMap存儲(chǔ)數(shù)據(jù)的過程

注意:相對于直接去讀HashMap源碼來說,先debug一下其執(zhí)行數(shù)據(jù)存儲(chǔ)的流程,更方便大家理解!

測試代碼:

@Test
public void test01() {
    HashMap<String, Integer> hashMap = new HashMap();
    hashMap.put("a", 3);
    hashMap.put("b", 4);
    hashMap.put("c", 5);
    hashMap.put("a", 88888);// 修改
    System.out.println(hashMap);
}

輸出結(jié)果:

{a=88888, b=456, c=789}

執(zhí)行流程分析:

1.首先,HashMap<String, Integer> hashMap = new HashMap();當(dāng)創(chuàng)建 HashMap 集合對象的時(shí)候,HashMap 的構(gòu)造方法并沒有創(chuàng)建數(shù)組,而是在第一次調(diào)用 put 方法時(shí)創(chuàng)建一個(gè)長度是16 的數(shù)組(即,16個(gè)桶) ,Node[] table (jdk1.8 之前是 Entry[] table)用來存儲(chǔ)鍵值對數(shù)據(jù)。

2.當(dāng)向哈希表中存儲(chǔ)put("a", 3)的數(shù)據(jù)時(shí),根據(jù)"a"字符串調(diào)用 String 類中重寫之后的 hashCode() 方法計(jì)算出哈希值,然后結(jié)合數(shù)組長度(桶數(shù)量)采用某種算法計(jì)算出向 Node 數(shù)組中存儲(chǔ)數(shù)據(jù)的空間索引值(比如table[i],這里的i就是該Node數(shù)組的空間索引)。如果計(jì)算出的索引空間沒有數(shù)據(jù)(即,這個(gè)桶是空的),則直接將<"a", 3>存儲(chǔ)到數(shù)組中。

舉例:如果計(jì)算出的索引是 3,則存儲(chǔ)到如下桶位:

在這里插入圖片描述

3.當(dāng)向哈希表中存儲(chǔ)數(shù)據(jù)<"b", 4>時(shí),假設(shè)算出的 hashCode() 方法結(jié)合數(shù)祖長度計(jì)算出的索引值也是3,那么此時(shí)數(shù)組空間不是 null(即,這個(gè)桶目前不為空),此時(shí)底層會(huì)比較 "a""b" 的 hash 值是否一致,如果不一致,則在空間上劃出一個(gè)結(jié)點(diǎn)來存儲(chǔ)鍵值對數(shù)據(jù)對 <"b", 4>,這種方式稱為拉鏈法。

4.當(dāng)向哈希表中存儲(chǔ)數(shù)據(jù)<"a", 88888>時(shí),那么首先根據(jù) "a"調(diào)用 hashCode() 方法結(jié)合數(shù)組長度計(jì)算出索引肯定是 3,此時(shí)比較后存儲(chǔ)的數(shù)據(jù)"a"和已經(jīng)存在的數(shù)據(jù)的 hash 值是否相等,如果 hash 值相等,此時(shí)發(fā)生哈希碰撞。那么底層會(huì)調(diào)用 "a"所屬類 String 中的 equals() 方法比較兩個(gè)內(nèi)容是否相等:

相等:將后添加的數(shù)據(jù)的 value 覆蓋之前的 value。

不相等:繼續(xù)向下和其他的數(shù)據(jù)的 key 進(jìn)行比較,如果都不相等,則劃出一個(gè)結(jié)點(diǎn)存儲(chǔ)數(shù)據(jù),如果結(jié)點(diǎn)長度即鏈表長度大于閾值 8 并且數(shù)組長度大于 64 則將鏈表變?yōu)榧t黑樹。


在這里插入圖片描述

5.在不斷的添加數(shù)據(jù)的過程中,會(huì)涉及到擴(kuò)容問題,當(dāng)超出閾值(且要存放的位置非空)時(shí),擴(kuò)容。默認(rèn)的擴(kuò)容方式:擴(kuò)容為原來容量的 2 倍,并將原有的數(shù)據(jù)復(fù)制過來。

6.綜上描述,當(dāng)位于一個(gè)表中的元素較多,即 hash 值相等但是內(nèi)容不相等的元素較多時(shí),通過 key 值依次查找的效率較低。而 jdk1.8 中,哈希表存儲(chǔ)采用數(shù)組+鏈表+紅黑樹實(shí)現(xiàn),當(dāng)鏈表長度(閾值)超過8且當(dāng)前數(shù)組的長度大于64時(shí),將鏈表轉(zhuǎn)換為紅黑樹,這樣大大減少了查找時(shí)間。

簡單的來說,哈希表是由數(shù)組+鏈表+紅黑樹(JDK1.8增加了紅黑樹部分)實(shí)現(xiàn)的。如下圖所示:


在這里插入圖片描述

7.jdk1.8 中引入紅黑樹的進(jìn)一步原因:

  1. jdk1.8 以前 HashMap 的實(shí)現(xiàn)是數(shù)組+鏈表,即使哈希函數(shù)取得再好,也很難達(dá)到元素百分百均勻分布。當(dāng) HashMap 中有大量的元素都存放到同一個(gè)桶中時(shí),這個(gè)桶下有一條長長的鏈表,這個(gè)時(shí)候 HashMap 就相當(dāng)于一個(gè)單鏈表,假如單鏈表有n個(gè)元素,遍歷的時(shí)間復(fù)雜度就是O(n),完全失去了它的優(yōu)勢。
  2. 針對這種情況,jdk1.8 中引入了紅黑樹(查找時(shí)間復(fù)雜度為 O(logn))來優(yōu)化這個(gè)問題。當(dāng)鏈表長度很小的時(shí)候,即使遍歷,速度也非???,但是當(dāng)鏈表長度不斷變長,肯定會(huì)對查詢性能有一定的影響,所以才需要轉(zhuǎn)成樹。

8.總結(jié)

在這里插入圖片描述

說明:

  • size 表示 HashMap 中鍵值對的實(shí)時(shí)數(shù)量(即,所存儲(chǔ)元素的數(shù)量),注意這個(gè)不等于數(shù)組的長度。
  • threshold(臨界值)= capacity(容量)* loadFactor(負(fù)載因子)。這個(gè)值是當(dāng)前已占用數(shù)組長度的最大值。size 超過這個(gè)值就重新 resize(擴(kuò)容),擴(kuò)容后的 HashMap 容量是之前容量的2倍。

2.HashMap相關(guān)面試題

具體原理我們下文會(huì)具體分析,這里先大概了解下面試的時(shí)候會(huì)問什么,帶著問題去讀源碼,便于理解!

1.shMap 中 hash 函數(shù)是怎么實(shí)現(xiàn)的?還有哪些hash函數(shù)的實(shí)現(xiàn)方式?

答:

  1. 對 key 的 hashCode 做 hash 操作,如果key為null則直接賦哈希值為0,否則,無符號右移 16 位然后做異或位運(yùn)算,如,代碼所示:(key == null) ? 0 : (h = key.hashCode()) ^ (h >>> 16);
  2. 除上面的方法外,還有平方取中法,偽隨機(jī)數(shù)法 和 取余數(shù)法。這三種效率都比較低,而無符號右移 16 位異或運(yùn)算效率是最高的。

2.當(dāng)兩個(gè)對象的 hashCode 相等時(shí)會(huì)怎么樣?

答:會(huì)產(chǎn)生哈希碰撞。若 key 值內(nèi)容相同則替換舊的 value,不然連接到鏈表后面,鏈表長度超過閾值 8 就轉(zhuǎn)換為紅黑樹存儲(chǔ)。

3.什么是哈希碰撞,如何解決哈希碰撞?

答:只要兩個(gè)元素的 key 計(jì)算的哈希碼值相同就會(huì)發(fā)生哈希碰撞。jdk8 之前使用鏈表解決哈希碰撞。jdk8之后使用鏈表 + 紅黑樹解決哈希碰撞。

4.如果兩個(gè)鍵的 hashCode 相同,如何存儲(chǔ)鍵值對?

答:通過 equals 比較內(nèi)容是否相同。

  1. 相同:則新的 value 覆蓋之前的 value。
  2. 不相同:遍歷該桶位的鏈表(或者樹):
    1. 如果找到相同key,則覆蓋該key對應(yīng)的value;
    2. 如果找不到,則將新的鍵值對添加到鏈表(或者樹)中;

3.HashMap繼承體系

在這里插入圖片描述
從繼承體系可以看出:

  • HashMap 實(shí)現(xiàn)了Cloneable接口,可以被克隆。
  • HashMap 實(shí)現(xiàn)了Serializable接口,屬于標(biāo)記性接口,HashMap 對象可以被序列化和反序列化。
  • HashMap 繼承了AbstractMap,父類提供了 Map 實(shí)現(xiàn)接口,具有Map的所有功能,以最大限度地減少實(shí)現(xiàn)此接口所需的工作。

知識(shí)擴(kuò)展:

通過上述繼承關(guān)系我們發(fā)現(xiàn)一個(gè)很奇怪的現(xiàn)象,就是 HashMap 已經(jīng)繼承了AbstractMap 而 AbstractMap 類實(shí)現(xiàn)了Map 接口,那為什么 HashMap 還要在實(shí)現(xiàn) Map 接口呢?同樣在 ArrayList 中 LinkedLis 中都是這種結(jié)構(gòu)。

據(jù) Java 集合框架的創(chuàng)始人 Josh Bloch 描述,這樣的寫法是一個(gè)失誤。在 Java 集合框架中,類似這樣的寫法很多,最幵始寫 Java 集合框架的時(shí)候,他認(rèn)為這樣寫,在某些地方可能是有價(jià)值的,直到他意識(shí)到錯(cuò)了。顯然的,jdk 的維護(hù)者,后來不認(rèn)為這個(gè)小小的失誤值得去修改,所以就這樣保留下來了。

存儲(chǔ)結(jié)構(gòu)(再過一遍)


在這里插入圖片描述

在Java中,HashMap的實(shí)現(xiàn)采用了(數(shù)組 + 鏈表 + 紅黑樹)的復(fù)雜結(jié)構(gòu),數(shù)組的一個(gè)元素又稱作桶。

在添加元素時(shí),會(huì)根據(jù)hash值算出元素在數(shù)組中的位置,如果該位置沒有元素,則直接把元素放置在此處,如果該位置有元素了,則把元素以鏈表的形式放置在鏈表的尾部

當(dāng)一個(gè)鏈表的元素個(gè)數(shù)達(dá)到一定的數(shù)量(且數(shù)組的長度達(dá)到一定的長度)后,則把鏈表轉(zhuǎn)化為紅黑樹,從而提高效率

數(shù)組的查詢效率為O(1),鏈表的查詢效率是O(k),紅黑樹的查詢效率是O(log k),k為桶中的元素個(gè)數(shù),所以當(dāng)元素?cái)?shù)量非常多的時(shí)候,轉(zhuǎn)化為紅黑樹能極大地提高效率。

4.HashMap基本屬性與常量

/*
 * 序列化版本號
 */
private static final long serialVersionUID = 362498820763181265L;
/**
 * HashMap的初始化容量(必須是 2 的 n 次冪)默認(rèn)的初始容量為16
 */
static final int DEFAULT_INITIAL_CAPACITY = 1 << 4;
/**
 * 最大的容量為2的30次方
 */
static final int MAXIMUM_CAPACITY = 1 << 30;
/**
 * 默認(rèn)的裝載因子
 */
static final float DEFAULT_LOAD_FACTOR = 0.75f;
/**
 * 樹化閾值,當(dāng)一個(gè)桶中的元素個(gè)數(shù)大于等于8時(shí)進(jìn)行樹化
 */
static final int TREEIFY_THRESHOLD = 8;
/**
 * 樹降級為鏈表的閾值,當(dāng)一個(gè)桶中的元素個(gè)數(shù)小于等于6時(shí)把樹轉(zhuǎn)化為鏈表
 */
static final int UNTREEIFY_THRESHOLD = 6;
/**
 * 當(dāng)桶的個(gè)數(shù)達(dá)到64的時(shí)候才進(jìn)行樹化
 */
static final int MIN_TREEIFY_CAPACITY = 64;
/**
 * Node數(shù)組,又叫作桶(bucket)
 */
transient Node<K,V>[] table;
/**
 * 作為entrySet()的緩存
 */
transient Set<Map.Entry<K,V>> entrySet;
/**
 * 元素的數(shù)量
 */
transient int size;
/**
 * 修改次數(shù),用于在迭代的時(shí)候執(zhí)行快速失敗策略
 */
transient int modCount;
/**
 * 當(dāng)桶的使用數(shù)量達(dá)到多少時(shí)進(jìn)行擴(kuò)容,threshold = capacity * loadFactor
 */
int threshold;
/**
 * 裝載因子
 */
final float loadFactor;

(1)容量:容量為數(shù)組的長度,亦即桶的個(gè)數(shù),默認(rèn)為16 ,最大為2的30次方,當(dāng)容量達(dá)到64時(shí)才可以樹化。

(2)裝載因子:裝載因子用來計(jì)算容量達(dá)到多少時(shí)才進(jìn)行擴(kuò)容,默認(rèn)裝載因子為0.75。

(3)樹化:樹化,當(dāng)容量達(dá)到64且鏈表的長度達(dá)到8時(shí)進(jìn)行樹化,當(dāng)鏈表的長度小于6時(shí)反樹化。

4.1 DEFAULT_INITIAL_CAPACITY

集合的初始化容量(必須是 2 的 n 次冪):

// 默認(rèn)的初始容量是16	1 << 4 相當(dāng)于 1*2的4次方
static final int DEFAULT_INITIAL_CAPACITY = 1 << 4;

面試問題:為什么必須是 2 的 n 次冪?如果輸入值不是 2 的冪比如 10 會(huì)怎么樣?

HashMap 構(gòu)造方法可以指定集合的初始化容量大小,如:

// 構(gòu)造一個(gè)帶指定初始容量和默認(rèn)負(fù)載因子(0.75)的空 HashMap。
HashMap(int initialCapacity)

根據(jù)上述講解我們已經(jīng)知道,當(dāng)向 HashMap 中添加一個(gè)元素的時(shí)候,需要根據(jù) key 的 hash 值,去確定其在數(shù)組中的具體位置。HashMap 為了存取高效,減少碰撞,就是要盡量把數(shù)據(jù)分配均勻,每個(gè)鏈表長度大致相同,這個(gè)實(shí)現(xiàn)的關(guān)鍵就在把數(shù)據(jù)存到哪個(gè)鏈表中的算法。

這個(gè)算法實(shí)際就是取模,hash % length,而計(jì)算機(jī)中直接求余效率不如位移運(yùn)算。所以源碼中做了優(yōu)化,使用 hash & (length - 1),而實(shí)際上 hash % length 等于 hash & ( length - 1) 的前提是 length 是 2 的 n 次冪。(這段話是摘抄傳智播客鎖哥的,這個(gè)解釋確實(shí)很完美!)

例如,數(shù)組長度為 8 的時(shí)候,3 & (8 - 1) = 3,2 & (8 - 1) = 2,桶的位置是(數(shù)組索引)3和2,不同位置上,不碰撞。

再來看一個(gè)數(shù)組長度(桶位數(shù))不是2的n次冪的情況:

在這里插入圖片描述

從上圖可以看出,當(dāng)數(shù)組長度為9(非2 的n次冪)的時(shí)候,不同的哈希值hash, hash & (length - 1)所得到的數(shù)組下標(biāo)相等(很容易出現(xiàn)哈希碰撞)。

小結(jié)一下HashMap數(shù)組容量使用2的n次冪的原因:(面試也會(huì)問)

在這里插入圖片描述


問題:如果創(chuàng)建HashMap對象時(shí),輸入的數(shù)組長度length是10,而不是2的n次冪會(huì)怎么樣呢?

HashMap<String, Integer> hashMap = new HashMap(10);

HashMap雙參構(gòu)造函數(shù)會(huì)通過tableSizeFor(initialCapacity)方法,得到一個(gè)最接近length且大于length的2的n次冪數(shù)(比如最接近10且大于10的2的n次冪數(shù)是16)

這一塊兒比較難理解,下文講構(gòu)造方法的時(shí)候還會(huì)再舉例一個(gè)例子:

static final int tableSizeFor(int cap) {
  int n = cap - 1;
  n |= n >>> 1;
  n |= n >>> 2;
  n |= n >>> 4;
  n |= n >>> 8;
  n |= n >>> 16;
  return (n < 0) ? 1 : (n >= MAXIMUM_CAPACITY) ? MAXIMUM_CAPACITY : n + 1;
}

說明:

當(dāng)在實(shí)例化 HashMap 實(shí)例時(shí),如果給定了 initialCapacity,由于 HashMap 的 capacity 必須是 2 的冪,因此這個(gè)方法tableSizeFor(initialCapacity);用于找到大于等于 initialCapacity 的最小的 2 的冪。

分析:

int n = cap - 1;為什么要減去1呢?

防止 cap 已經(jīng)是 2 的冪。如果 cap 已經(jīng)是 2 的冪,又沒有這個(gè)減 1 操作,則執(zhí)行完后面的幾條無符號操作之后,返回的 capacity 將是這個(gè) cap 的 2 倍(后面還會(huì)再舉個(gè)例子講這個(gè))。

最后為什么有個(gè) n + 1 的操作呢?

如果 n 這時(shí)為 0 了(經(jīng)過了cap - 1后),則經(jīng)過后面的幾次無符號右移依然是 0,返回0是肯定不行的,所以最后返回n+1最終得到的 capacity 是1。

注意:容量最大也就是 32bit 的正數(shù),因此最后 n |= n >>> 16;最多也就 32 個(gè) 1(但是這已經(jīng)是負(fù)數(shù)了,在執(zhí)行 tableSizeFor 之前,對 initialCapacity 做了判斷,如果大于MAXIMUM_CAPACITY(2 ^ 30),則取 MAXIMUM_CAPACITY。如果等于MAXIMUM_CAPACITY,會(huì)執(zhí)行位移操作。所以這里面的位移操作之后,最大 30 個(gè) 1,不會(huì)大于等于 MAXIMUM_CAPACITY。30 個(gè) 1,加 1 后得 2 ^ 30)。

完整例子:

在這里插入圖片描述

所以由結(jié)果可得,當(dāng)執(zhí)行完tableSizeFor(initialCapacity);方法后,得到的新capacity是最接近initialCapacity且大于initialCapacity的2的n次冪的數(shù)。

4.2 DEFAULT_LOAD_FACTOR

默認(rèn)的負(fù)載因子(默認(rèn)值 0.75)

static final float DEFAULT_LOAD_FACTOR = 0.75f;

4.3 MAXIMUM_CAPACITY

集合最大容量

static final int MAXIMUM_CAPACITY = 1 << 30; // 2的30次冪

4.4 TREEIFY_THRESHOLD

當(dāng)鏈表的值超過8則會(huì)轉(zhuǎn)為紅黑樹(jdk1.8新增)

// 當(dāng)桶(bucket)上的結(jié)點(diǎn)數(shù)大于這個(gè)值時(shí)會(huì)轉(zhuǎn)為紅黑樹
static final int TREEIFY_THRESHOLD = 8;

面試問題:為什么 Map 桶中結(jié)點(diǎn)個(gè)數(shù)超過 8 才轉(zhuǎn)為紅黑樹?

8這個(gè)閾值定義在HashMap中,針對這個(gè)成員變量,在源碼的注釋中只說明了 8 是 bin( bucket 桶)從鏈表轉(zhuǎn)成樹的閾值,但是并沒有說明為什么是 8。

在 HashMap 中有一段注釋說明:

Because TreeNodes are about twice the size of regular nodes, we use them only when bins
contain enough nodes to warrant use (see TREEIFY_THRESHOLD). And when they become too
small (due to removal or resizing) they are converted back to plain bins.  In usages with
well-distributed user hashCodes, tree bins are rarely used.  Ideally, under random hashCodes, 
the frequency of nodes in bins follows a Poisson distribution 
(http://en.wikipedia.org/wiki/Poisson_distribution) 
with a parameter of about 0.5 on average for the default resizing
threshold of 0.75, although with a large variance because of resizing granularity. Ignoring variance, 
the expected occurrences of list size k are (exp(-0.5) * pow(0.5, k) / factorial(k)). The first values are:
翻譯:因?yàn)闃浣Y(jié)點(diǎn)的大小大約是普通結(jié)點(diǎn)的兩倍,所以我們只在箱子包含足夠的結(jié)點(diǎn)時(shí)才使用樹結(jié)點(diǎn)(參見TREEIFY_THRESHOLD)。
當(dāng)它們變得太?。ㄓ捎趧h除或調(diào)整大?。r(shí),就會(huì)被轉(zhuǎn)換回普通的桶。在使用分布良好的用戶 hashCode 時(shí),很少使用樹箱。
理想情況下,在隨機(jī)哈希碼下,箱子中結(jié)點(diǎn)的頻率服從泊松分布。
默認(rèn)調(diào)整閾值為0.75,平均參數(shù)約為0.5,盡管由于調(diào)整粒度的差異很大。忽略方差,列表大小k的預(yù)朗出現(xiàn)次數(shù)是(exp(-0.5)*pow(0.5, k) / factorial(k)
第一個(gè)值是:
0:    0.60653066
1:    0.30326533
2:    0.07581633
3:    0.01263606
4:    0.00157952
5:    0.00015795
6:    0.00001316
7:    0.00000094
8:    0.00000006
more: less than 1 in ten million

TreeNodes(樹) 占用空間是普通 Nodes(鏈表) 的兩倍,所以只有當(dāng) bin(bucket 桶) 包含足夠多的結(jié)點(diǎn)時(shí)才會(huì)轉(zhuǎn)成 TreeNodes,而是否足夠多就是由 TREEIFY_THRESH〇LD 的值決定的。當(dāng) bin(bucket 桶) 中結(jié)點(diǎn)數(shù)變少時(shí),又會(huì)轉(zhuǎn)成普通的 bin(bucket 桶)。并且我們查看源碼的時(shí)候發(fā)現(xiàn),鏈表長度達(dá)到 8 就轉(zhuǎn)成紅黑樹,當(dāng)長度降到 6 就轉(zhuǎn)成普通 bin(bucket 桶)。

這樣就解釋了為什么不是一開始就將其轉(zhuǎn)換為 TreeNodes,而是需要一定結(jié)點(diǎn)數(shù)之后才轉(zhuǎn)為 TreeNodes,說白了就是權(quán)衡空間和時(shí)間。

這段內(nèi)容還說到:當(dāng) hashCode 離散性很好的時(shí)候,樹型 bin 用到的概率非常小,因?yàn)閿?shù)據(jù)均勻分布在每個(gè) bin 中,幾乎不會(huì)有 bin 中鏈表長度會(huì)達(dá)到閾值。但是在隨機(jī) hashCode 下,離散性可能會(huì)變差,然而 jdk 又不能阻止用戶實(shí)現(xiàn)這種不好的 hash 算法,因此就可能導(dǎo)致不均勻的數(shù)據(jù)分布。不理想情況下隨機(jī) hashCode 算法下所有 bin 中結(jié)點(diǎn)的分布頻率會(huì)遵循泊松分布,我們可以看到,一個(gè) bin 中鏈表長度達(dá)到 8 個(gè)元素的槪率為 0.00000006,幾乎是不可能事件。所以,之所以選擇 8,不是隨便決定的,而是裉據(jù)概率統(tǒng)計(jì)決定的。甶此可見,發(fā)展將近30年的 Java 每一項(xiàng)改動(dòng)和優(yōu)化都是非常嚴(yán)謹(jǐn)和科學(xué)的。

面試答案:hashCode 算法下所有 桶 中結(jié)點(diǎn)的分布頻率會(huì)遵循泊松分布,這時(shí)一個(gè)桶中鏈表長度超過 8 個(gè)元素的槪率非常小,權(quán)衡空間和時(shí)間復(fù)雜度,所以選擇 8 這個(gè)數(shù)宇。

擴(kuò)展補(bǔ)充:

Poisson 分布(泊松分布),是一種統(tǒng)計(jì)與概率學(xué)里常見到的離散[概率分布]。泊松分布的概率函數(shù)為:

公式

泊松分布的參數(shù) A 是單位時(shí)間(或單位面積)內(nèi)隨機(jī)事件的平均發(fā)生次數(shù)。泊松分布適合于描述單位時(shí)間內(nèi)隨機(jī)事件發(fā)生的次數(shù)。

以下是我在研究這個(gè)問題時(shí),在一些資料上面翻看的解釋,供大家參考:

紅黑樹的平均查找長度是 log(n),如果長度為 8,平均查找長度為 log(8) = 3,鏈表的平均查找長度為 n/2,當(dāng)長度為 8 時(shí),平均查找長虔為 8/2 = 4,這才有轉(zhuǎn)換成樹的必要;鏈表長度如果是小于等于 6, 6/2 = 3,而 log(6) = 2.6,雖然速度也很快的,但是轉(zhuǎn)化為樹結(jié)構(gòu)和生成樹的時(shí)間并不會(huì)太短。

4.5 UNTREEIFY_THRESHOLD

當(dāng)鏈表的值小于 6 則會(huì)從紅黑樹轉(zhuǎn)回鏈表

// 當(dāng)桶(bucket)上的結(jié)點(diǎn)數(shù)小于這個(gè)值,樹轉(zhuǎn)為鏈表 
static final int UNTREEIFY_THRESHOLD = 6;

4.6 MIN_TREEIFY_CAPACITY

當(dāng) Map 里面的數(shù)量超過這個(gè)值時(shí),表中的桶才能進(jìn)行樹形化,否則桶內(nèi)元素太多時(shí)會(huì)擴(kuò)容,而不是樹形化為了避免進(jìn)行擴(kuò)容、樹形化選擇的沖突,這個(gè)值不能小于4*TREEIFY_THRESHOLD(8)

// 桶中結(jié)構(gòu)轉(zhuǎn)化為紅黑樹對應(yīng)的數(shù)組長度最小的值 
static final int MIN_TREEIFY_CAPACITY = 64;

4.7 table(重點(diǎn))

table 用來初始化(必須是二的n次冪)

// 存儲(chǔ)元素的數(shù)組 
transient Node<K,V>[] table;

在 jdk1.8 中我們了解到 HashMap 是由數(shù)組加鏈表加紅黑樹來組成的結(jié)構(gòu),其中 table 就是 HashMap 中的數(shù)組,jdk8 之前數(shù)組類型是 Entry<K,V> 類型。從 jdk1.8 之后是 Node<K,V> 類型。只是換了個(gè)名字,都實(shí)現(xiàn)了一樣的接口:Map.Entry<K,V>。負(fù)責(zé)存儲(chǔ)鍵值對數(shù)據(jù)的。

4.8 entrySet

用來存放緩存

// 存放具體元素的集合
transient Set<Map.Entry<K,V>> entrySet;

4.9 size(重點(diǎn))

HashMap 中存放元素的個(gè)數(shù)

// 存放元素的個(gè)數(shù),注意這個(gè)不等于數(shù)組的長度
 transient int size;

size 為 HashMap 中 K-V 的實(shí)時(shí)數(shù)量,不是數(shù)組 table 的長度。

4.10 modCount

用來記錄 HashMap 的修改次數(shù)

// 每次擴(kuò)容和更改 map 結(jié)構(gòu)的計(jì)數(shù)器
 transient int modCount;  

4.11 threshold(重點(diǎn))

用來調(diào)整大小下一個(gè)容量的值計(jì)算方式為(容量*負(fù)載因子)

// 臨界值 當(dāng)實(shí)際大?。ㄈ萘?負(fù)載因子)超過臨界值時(shí),會(huì)進(jìn)行擴(kuò)容
int threshold;

4.12 loadFactor(重點(diǎn))

哈希表的負(fù)載因子

// 負(fù)載因子
final float loadFactor;// 0.75f

說明:

loadFactor 是用來衡量 HashMap 滿的程度,表示HashMap的疏密程度,影響 hash 操作到同一個(gè)數(shù)組位置的概率,計(jì)算 HashMap 的實(shí)時(shí)負(fù)載因子的方法為:size/capacity,而不是占用桶的數(shù)量去除以 capacity。capacity 是桶的數(shù)量,也就是 table 的長度 length。loadFactor 太大導(dǎo)致查找元素效率低,太小導(dǎo)致數(shù)組的利用率低,存放的數(shù)據(jù)會(huì)很分散。loadFactor 的默認(rèn)值為 0.75f 是官方給出的一個(gè)比較好的臨界值。當(dāng) HashMap 里面容納的元素已經(jīng)達(dá)到 HashMap 數(shù)組長度的 75% 時(shí),表示 HashMap 太擠了,需要擴(kuò)容,而擴(kuò)容這個(gè)過程涉及到 rehash、復(fù)制數(shù)據(jù)等操作,非常消耗性能。所以開發(fā)中盡量減少擴(kuò)容的次數(shù),可以通過創(chuàng)建 HashMap 集合對象時(shí)指定初始容量來盡量避免。在 HashMap 的構(gòu)造器中可以定制 loadFactor。

// 構(gòu)造方法,構(gòu)造一個(gè)帶指定初始容量和負(fù)載因子的空HashMap
HashMap(int initialCapacity, float loadFactor);

為什么負(fù)載因子loadFactor 設(shè)置為0.75,初始化臨界值threshold是12?

loadFactor 越趨近于1,那么 數(shù)組中存放的數(shù)據(jù)(entry)也就越多,也就越密,也就是會(huì)讓鏈表的長度增加,loadFactor 越小,也就是趨近于0,數(shù)組中存放的數(shù)據(jù)(entry)也就越少,也就越稀疏。

數(shù)據(jù)

如果希望鏈表盡可能少些,要提前擴(kuò)容。有的數(shù)組空間有可能一直沒有存儲(chǔ)數(shù)據(jù),負(fù)載因子盡可能小一些。

舉例:

例如:負(fù)載因子是0.4。 那么16*0.4--->6 如果數(shù)組中滿6個(gè)空間就擴(kuò)容會(huì)造成數(shù)組利用率太低了。
負(fù)載因子是0.9。 那么16*0.9--->14 那么這樣就會(huì)導(dǎo)致鏈表有點(diǎn)多了,導(dǎo)致查找元素效率低。

所以既兼顧數(shù)組利用率又考慮鏈表不要太多,經(jīng)過大量測試 0.75 是最佳方案。

threshold 計(jì)算公式:capacity(數(shù)組長度默認(rèn)16) * loadFactor(負(fù)載因子默認(rèn)0.75)==12。

這個(gè)值是當(dāng)前已占用數(shù)組長度的最大值。當(dāng) Size >= threshold(12) 的時(shí)候,那么就要考慮對數(shù)組的 resize(擴(kuò)容),也就是說,這個(gè)的意思就是 衡量數(shù)組是否需要擴(kuò)增的一個(gè)標(biāo)準(zhǔn)。 擴(kuò)容后的 HashMap 容量是之前容量的兩倍。

5.內(nèi)部類

5.1Node內(nèi)部類

Node是一個(gè)典型的單鏈表節(jié)點(diǎn),其中,hash用來存儲(chǔ)key計(jì)算得來的hash值。

static class Node<K,V> implements Map.Entry<K,V> {
    final int hash;// hash用來存儲(chǔ)key計(jì)算得來的hash值
    final K key;// 鍵
    V value;// 值
    Node<K,V> next;// 下一個(gè)node節(jié)點(diǎn)
    Node(int hash, K key, V value, Node<K,V> next) {
        this.hash = hash;
        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() {// 調(diào)用底層c++ 返回Key/Value的哈希碼值,如果此對象為null,則返回0
        return Objects.hashCode(key) ^ Objects.hashCode(value);// 將Key/Vaule
    }
    public final V setValue(V newValue) {
        V oldValue = value;
        value = newValue;
        return oldValue;
    }
    public final boolean equals(Object o) {
        if (o == this)
            return true;
        if (o instanceof Map.Entry) {
            Map.Entry<?,?> e = (Map.Entry<?,?>)o;
            if (Objects.equals(key, e.getKey()) &&
                Objects.equals(value, e.getValue()))
                return true;
        }
        return false;
    }
}

5.2TreeNode內(nèi)部類

TreeNode內(nèi)部類,它繼承自LinkedHashMap中的Entry類,關(guān)于LInkedHashMap.Entry這個(gè)類之后會(huì)單獨(dú)發(fā)文章論述,TreeNode是一個(gè)典型的樹型節(jié)點(diǎn),其中,prev是鏈表中的節(jié)點(diǎn),用于在刪除元素的時(shí)候可以快速找到它的前置節(jié)點(diǎn)。

// 位于HashMap中,文章接下來會(huì)逐步分析
static final class TreeNode<K,V> extends LinkedHashMap.Entry<K,V> {
    TreeNode<K,V> parent;  // red-black tree links
    TreeNode<K,V> left;
    TreeNode<K,V> right;
    TreeNode<K,V> prev;    // needed to unlink next upon deletion
    boolean red;
}
// 位于LinkedHashMap中,典型的雙向鏈表節(jié)點(diǎn),這個(gè)類之后會(huì)單獨(dú)發(fā)文章論述
static class Entry<K,V> extends HashMap.Node<K,V> {
    Entry<K,V> before, after;
    Entry(int hash, K key, V value, Node<K,V> next) {
        super(hash, key, value, next);
    }
}

6.HashMap構(gòu)造方法

HashMap 中重要的構(gòu)造方法,它們分別如下:

6.1 HashMap()

構(gòu)造一個(gè)空的HashMap,默認(rèn)初始容量(16)和默認(rèn)負(fù)載因子(0.75)。

public HashMap() {
   // 將默認(rèn)的負(fù)載因子0.75賦值給loadFactor,并沒有創(chuàng)建數(shù)組
   this.loadFactor = DEFAULT_LOAD_FACTOR; 
}

6.2 HashMap(int initialCapacity)

構(gòu)造一個(gè)具有指定的初始容量和默認(rèn)負(fù)載因子(0.75)HashMap 。

// 指定“容量大小”的構(gòu)造函數(shù)
public HashMap(int initialCapacity) {
    this(initialCapacity, DEFAULT_LOAD_FACTOR);
}

6.3 HashMap(int initialCapacity,float loadFactor)構(gòu)造方法

構(gòu)造一個(gè)具有指定的初始容量和負(fù)載因子的 HashMap。

/*
	 指定“容量大小”和“負(fù)載因子”的構(gòu)造函數(shù)
	 initialCapacity:指定的容量
	 loadFactor:指定的負(fù)載因子
*/
public HashMap(int initialCapacity, float loadFactor) {
    	// 判斷初始化容量initialCapacity是否小于0
        if (initialCapacity < 0)
            // 如果小于0,則拋出非法的參數(shù)異常IllegalArgumentException
            throw new IllegalArgumentException("Illegal initial capacity: " + initialCapacity);
    	// 判斷初始化容量initialCapacity是否大于集合的最大容量MAXIMUM_CAPACITY
        if (initialCapacity > MAXIMUM_CAPACITY)
            // 如果超過MAXIMUM_CAPACITY,會(huì)將MAXIMUM_CAPACITY賦值給initialCapacity
            initialCapacity = MAXIMUM_CAPACITY;
    	// 判斷負(fù)載因子loadFactor是否小于等于0或者是否是一個(gè)非數(shù)值
        if (loadFactor <= 0 || Float.isNaN(loadFactor))
            // 如果滿足上述其中之一,則拋出非法的參數(shù)異常IllegalArgumentException
            throw new IllegalArgumentException("Illegal load factor: " + loadFactor);
     	// 將指定的負(fù)載因子賦值給HashMap成員變量的負(fù)載因子loadFactor
        this.loadFactor = loadFactor;// 一般不建議修改默認(rèn)的負(fù)載因子
        this.threshold = tableSizeFor(initialCapacity);
    }
	// 最后調(diào)用了tableSizeFor,來看一下方法實(shí)現(xiàn):
     /*
     	返回比指定cap容量大的最小2的n次冪數(shù):
     	前面第一遍講述的應(yīng)該有些小伙伴難以理解,這里我在舉例解析一下:
     	-------------------------------------------------------
     	首先假定傳入的cap = 10
     	則,n = 10 -1 => 9
     	n |= n >>> 1 就等同于 n = (n | n >>> 1),所以:
     	(位運(yùn)算不懂的可以去看我的《Java基礎(chǔ)提高之位運(yùn)算》這篇文章)
     	9 => 0b1001    9 >>> 1 => 0b0100 
     	n |= n >>> 1;  ===>  0b1001 | 0b0100 => 0b1101
     	n |= n >>> 2;  ===>  0b1101 | 0b0011 => 0b1111
        n |= n >>> 4;  ===>  0b1111 | 0b0000 => 0b1111
        n |= n >>> 8;  ===>  0b1111 | 0b0000 => 0b1111
        n |= n >>> 16; ===>  0b1111 | 0b0000 => 0b1111
        得到:
        0b1111 => 15
        返回:
        return 15 + 1 => 16
        -------------------------------------------------------
        如果cap 不減去1,即直接使n等于cap的話,int n = cap;
        我們繼續(xù)用上邊返回的cap => 16 傳入tableSizeFor(int cap):
        cap = 16
        n = 16
        16 => 0b10000  16 >>> 1 => 0b01000
        n |= n >>> 1;  ===>  0b10000 | 0b01000 => 0b11000
        n |= n >>> 2;  ===>  0b11000 | 0b00110 => 0b11110
        n |= n >>> 4;  ===>  0b11110 | 0b00001 => 0b11111
        n |= n >>> 8;  ===>  0b11111 | 0b00000 => 0b11111
        n |= n >>> 16; ===>  0b11111 | 0b00000 => 0b11111
        得到:
        0b11111 => 31
        返回 return 31 +1 => 32
        而實(shí)際情況是應(yīng)該傳入cap = 16 , n = cap -1 = 15
        15 => 0b1111 
        n |= n >>> 1;
        n |= n >>> 2;
        n |= n >>> 4;
        n |= n >>> 8;
        n |= n >>> 16;
        經(jīng)過上面運(yùn)算后得到:還是15
        返回結(jié)果:
        return 15 + 1 = 16
        所以我們得出結(jié)果:
        防止 cap 已經(jīng)是 2 的冪數(shù)情況下。沒有這個(gè)減 1 操作,
        則執(zhí)行完幾條無符號位移或位運(yùn)算操作之后,返回的cap(32)將是實(shí)際所需cap(16)的 2倍。
     */
    static final int tableSizeFor(int cap) {
        int n = cap - 1;
        n |= n >>> 1;
        n |= n >>> 2;
        n |= n >>> 4;
        n |= n >>> 8;
        n |= n >>> 16;
        return (n < 0) ? 1 : (n >= MAXIMUM_CAPACITY) ? MAXIMUM_CAPACITY : n + 1;
    }

說明:

對于this.threshold = tableSizeFor(initialCapacity); 疑問?

**tableSizeFor(initialCapacity)**判斷指定的初始化容量是否是2的n次冪,如果不是那么會(huì)變?yōu)楸戎付ǔ跏蓟萘看蟮淖钚〉?的n次冪。

但是注意,在tableSizeFor方法體內(nèi)部將計(jì)算后的數(shù)據(jù)返回給調(diào)用這里了,并且直接賦值給threshold邊界值了。有些人會(huì)覺得這里是一個(gè)bug,應(yīng)該這樣書寫:

this.threshold = tableSizeFor(initialCapacity) * this.loadFactor;

這樣才符合threshold的意思(當(dāng)HashMap的size到達(dá)threshold這個(gè)閾值時(shí)會(huì)擴(kuò)容)

但是請注意,在jdk8以后的構(gòu)造方法中,并沒有對table這個(gè)成員變量進(jìn)行初始化,table的初始化被推遲到了put方法中,在put方法中會(huì)對threshold重新計(jì)算。

6.4 HashMap(Map<? extends K, ? extends V> m)

包含另一個(gè) “Map” 的構(gòu)造函數(shù)

// 構(gòu)造一個(gè)映射關(guān)系與指定 Map 相同的新 HashMap。
public HashMap(Map<? extends K, ? extends V> m) {
    	// 負(fù)載因子loadFactor變?yōu)槟J(rèn)的負(fù)載因子0.75
         this.loadFactor = DEFAULT_LOAD_FACTOR;
         putMapEntries(m, false);
 }

最后調(diào)用了 putMapEntries(),來看一下方法實(shí)現(xiàn):

final void putMapEntries(Map<? extends K, ? extends V> m, boolean evict) {
    //獲取參數(shù)集合的長度
    int s = m.size();
    if (s > 0) {//判斷參數(shù)集合的長度是否大于0
        if (table == null) { // 判斷table是否已經(jīng)初始化
                // 未初始化,s為m的實(shí)際元素個(gè)數(shù)
                float ft = ((float)s / loadFactor) + 1.0F;// 得到新的擴(kuò)容閾值
                int t = ((ft < (float)MAXIMUM_CAPACITY) ? (int)ft : MAXIMUM_CAPACITY);// 新的擴(kuò)容閾值float自動(dòng)向下轉(zhuǎn)型為int
                // 計(jì)算得到的t大于閾值,則初始化閾值,將其變?yōu)榉弦蟮?的n次冪數(shù)
                if (t > threshold)
                    threshold = tableSizeFor(t);
        }
        // 如果table已初始化過了,并且m元素個(gè)數(shù)大于閾值,進(jìn)行擴(kuò)容處理
        else if (s > threshold)
            resize();
        // 將m中的所有元素添加至HashMap中
        for (Map.Entry<? extends K, ? extends V> e : m.entrySet()) {
            K key = e.getKey();
            V value = e.getValue();
            // 得到的key 和 value 放入 hashmap
            putVal(hash(key), key, value, false, evict);
        }
    }
}

(小結(jié)):

面試問題:float ft = ((float)s / loadFactor) + 1.0F; 這一行代碼中為什么要加 1.0F ?

(float)s/loadFactor 的結(jié)果是小數(shù),加 1.0F 與 (int)ft 相當(dāng)于是對小數(shù)做一個(gè)向上取整以盡可能的保證更大容量,更大的容量能夠減少 resize 的調(diào)用次數(shù)(為了效率,應(yīng)當(dāng)盡量減少擴(kuò)容的次數(shù))。所以 + 1.0F 是為了獲取更大的容量。

例如:原來集合的元素個(gè)數(shù)是 6 個(gè),那么 6/0.75 是8,由于8是 2 的n次冪,那么

if (t > threshold) threshold = tableSizeFor(t);執(zhí)行過后,新的數(shù)組大小就是 8 了。然后原來數(shù)組的數(shù)據(jù)就會(huì)存儲(chǔ)到長度是 8 的新的數(shù)組中了,這樣會(huì)導(dǎo)致在存儲(chǔ)元素的時(shí)候,容量不夠,還得繼續(xù)擴(kuò)容,那么性能降低了,而如果 +1 呢,數(shù)組長度直接變?yōu)?6了,這樣可以減少數(shù)組的擴(kuò)容。

7.HashMap的成員方法

7.1 put(K key, V value)方法

put方法是比較復(fù)雜的,實(shí)現(xiàn)步驟大致如下:

1.先通過 hash 值計(jì)算出 key 映射到哪個(gè)桶;

2.如果桶上沒有碰撞沖突,則直接插入;

3.如果出現(xiàn)碰撞沖突了,則需要處理沖突:

a 如果該桶使用紅黑樹處理沖突,則調(diào)用紅黑樹的方法插入數(shù)據(jù);

b 否則采用傳統(tǒng)的鏈?zhǔn)椒椒ú迦?。如果鏈的長度達(dá)到臨界值,則把鏈轉(zhuǎn)變?yōu)榧t黑樹;

4.如果桶中存在重復(fù)的鍵,則為該鍵替換新值 value;

5.如果 size 大于閾值 threshold,則進(jìn)行擴(kuò)容;

具體的方法如下:

public V put(K key, V value) {
    // 調(diào)用hash(key)計(jì)算出key的hash值
    return putVal(hash(key), key, value, false, true);
}

說明:

  1. HashMap 只提供了 put 用于添加元素,putVal 方法只是給 put 方法調(diào)用的一個(gè)方法,并沒有提供給用戶使用。 所以我們重點(diǎn)看 putVal 方法。
  2. 我們可以看到在 putVal 方法中 key 在這里執(zhí)行了一下 hash 方法,來看一下 hash 方法是如何實(shí)現(xiàn)的。
static final int hash(Object key) {
int h;
// 如果key為null,則hash值為0,
// 否則調(diào)用key的hashCode()方法計(jì)算出key的哈希值然后賦值給h,
// 后與h無符號右移16位后的二進(jìn)制進(jìn)行按位異或得到最后的hash值,
// 這樣做是為了使計(jì)算出的hash更分散
// 為什么要更分散呢?因?yàn)樵椒稚?,某個(gè)桶的鏈表長度就越短,之后生成的紅黑樹越少,效率越高
return (key == null) ? 0 : (h = key.hashCode()) ^ (h >>> 16);
}

從上面可以得知 HashMap 是支持 key 為空的,而 HashTable 是直接用 Key 來獲取hashCode 所以 key 為空會(huì)拋異常。

解讀上述 hash 方法:

我們先研究下 key 的哈希值是如何計(jì)算出來的。key 的哈希值是通過上述方法計(jì)算出來的。

這個(gè)哈希方法首先計(jì)算出 key 的 hashCode 賦值給 h,然后與 h 無符號右移 16 位后的二進(jìn)制進(jìn)行按位異或得到最后的 hash 值。

在 putVal 函數(shù)中使用到了上述 hash 函數(shù)計(jì)算的哈希值:

final V putVal(int hash, K key, V value, boolean onlyIfAbsent, boolean evict) {
	...
	if ((p = tab[i = (n - 1) & hash]) == null) // 這里的n表示數(shù)組長度16 ,公式
    // (length - 1) & hash = 桶位下標(biāo) 當(dāng)數(shù)組長度為2的n次冪數(shù)時(shí),
    // 該公式相當(dāng)于:hash % length 哈希值對數(shù)組長度取余
    // 例如:hash % 32 = hash & (32-1)
	...
}

計(jì)算過程如下所示:

說明

  1. key.hashCode();返回散列值也就是 hashcode,假設(shè)隨便生成的一個(gè)值。
  2. n 表示數(shù)組初始化的長度是 16。
  3. &(按位與運(yùn)算):運(yùn)算規(guī)則:相同的二進(jìn)制數(shù)位上,都是 1 的時(shí)候,結(jié)果為 1,否則為0。
  4. ^(按位異或運(yùn)算):運(yùn)算規(guī)則:相同的二進(jìn)制數(shù)位上,數(shù)字相同,結(jié)果為 0,不同為 1。

最后獲得0101==> 下標(biāo)為5的捅。

簡單來說就是:

高 16bit 不變,低 16bit 和高 16bit 做了一個(gè)異或(得到的 hashCode 轉(zhuǎn)化為 32 位二進(jìn)制,前 16 位和后 16 位低 16bit 和高 16bit 做了一個(gè)異或)。

問題:為什么要這樣操作呢?

如果當(dāng) n 即數(shù)組長度很小,假設(shè)是 16 的話,那么 n - 1 即為 1111 ,這樣的值和 hashCode 直接做按位與操作,實(shí)際上只使用了哈希值的后 4 位。如果當(dāng)哈希值的高位變化很大,低位變化很小,這樣就很容易造成哈希沖突了,所以這里把高低位都利用起來,從而解決了這個(gè)問題

在這里插入圖片描述

下面,我們來看看 putVal 方法,看看它到底做了什么。

主要參數(shù):

  • hash:key 的 hash 值
  • key:原始
  • keyvalue:要存放的值
  • onlyIfAbsent:如果
  • true :代表不更改現(xiàn)有的值
  • evict:如果為
  • false:表示
  • table:為創(chuàng)建狀態(tài)

putVal 方法源代碼如下所示:

public V put(K key, V value) {
	return putVal(hash(key), key, value, false, true);
}
static final int hash(Object key) {
    int h;// 如果key是null 則hash值為0,否則調(diào)用key的hashCode()方法,并讓高16位參與整個(gè)hash異或,如果數(shù)組長度比較小的情況下,讓高16位也參與尋址,
    // 尋址公式:(length - 1) & hash 
    // 這樣可以使計(jì)算出的結(jié)果更分散,不容易產(chǎn)生哈希沖突
    return (key == null) ? 0 : (h = key.hashCode()) ^ (h >>> 16);
}
final V putVal(int hash, K key, V value, boolean onlyIfAbsent, boolean evict) {
    Node<K,V>[] tab; Node<K,V> p; int n, i;
    /*
    	1)transient Node<K,V>[] table; 表示存儲(chǔ)Map集合中元素的數(shù)組。
    	2)(tab = table) == null 表示將空的table賦值給tab,然后判斷tab是否等于null,第一次肯定是null。
    	3)(n = tab.length) == 0 表示將數(shù)組的長度0賦值給n,然后判斷n是否等于0,n等于0,由于if判斷使用雙或,滿足一個(gè)即可,則執(zhí)行代碼 n = (tab = resize()).length; 進(jìn)行數(shù)組初始化,并將初始化好的數(shù)組長度賦值給n。
    	4)執(zhí)行完n = (tab = resize()).length,數(shù)組tab每個(gè)空間都是null。
    */
    if ((tab = table) == null || (n = tab.length) == 0)
        n = (tab = resize()).length;
    /*
    	1)i = (n - 1) & hash 表示計(jì)算數(shù)組的索引賦值給i,即確定元素存放在哪個(gè)桶中。
    	2)p = tab[i = (n - 1) & hash]表示獲取計(jì)算出的位置的數(shù)據(jù)賦值給結(jié)點(diǎn)p。
    	3) (p = tab[i = (n - 1) & hash]) == null 判斷結(jié)點(diǎn)位置是否等于null,如果為null,則執(zhí)行代碼:tab[i] = newNode(hash, key, value, null);根據(jù)鍵值對創(chuàng)建新的結(jié)點(diǎn)放入該位置的桶中。
        小結(jié):如果當(dāng)前桶沒有哈希碰撞沖突,則直接把鍵值對插入空間位置。
    */ 
    if ((p = tab[i = (n - 1) & hash]) == null)
        // 創(chuàng)建一個(gè)新的結(jié)點(diǎn)存入到桶中
        tab[i] = newNode(hash, key, value, null);
    else {
         // 執(zhí)行else說明tab[i]不等于null,表示這個(gè)位置已經(jīng)有值了
        Node<K,V> e; K k;
        /*
        	比較桶中第一個(gè)元素(數(shù)組中的結(jié)點(diǎn))的hash值和key是否相等
        	1)p.hash == hash :p.hash表示原來存在數(shù)據(jù)的hash值  hash表示后添加數(shù)據(jù)的hash值 比較兩個(gè)hash值是否相等。
                 說明:p表示tab[i],即 newNode(hash, key, value, null)方法返回的Node對象。
                    Node<K,V> newNode(int hash, K key, V value, Node<K,V> next) {
                        return new Node<>(hash, key, value, next);
                    }
                    而在Node類中具有成員變量hash用來記錄著之前數(shù)據(jù)的hash值的。
             2)(k = p.key) == key :p.key獲取原來數(shù)據(jù)的key賦值給k  key 表示后添加數(shù)據(jù)的key比較兩個(gè)key的地址值是否相等。
             3)key != null && key.equals(k):能夠執(zhí)行到這里說明兩個(gè)key的地址值不相等,那么先判斷后添加的key是否等于null,如果不等于null再調(diào)用equals方法判斷兩個(gè)key的內(nèi)容是否相等。
        */
        if (p.hash == hash &&
            ((k = p.key) == key || (key != null && key.equals(k))))
                /*
                	說明:兩個(gè)元素哈希值相等,并且key的值也相等,
                	將舊的元素整體對象賦值給e,用e來記錄
                */ 
                e = p;
        // hash值不相等或者key不相等;判斷p是否為紅黑樹結(jié)點(diǎn)
        else if (p instanceof TreeNode)
            // 放入樹中
            e = ((TreeNode<K,V>)p).putTreeVal(this, tab, hash, key, value);
        // 說明是鏈表結(jié)點(diǎn)
        else {
            /*
            	1)如果是鏈表的話需要遍歷到最后結(jié)點(diǎn)然后插入
            	2)采用循環(huán)遍歷的方式,判斷鏈表中是否有重復(fù)的key
            */
            for (int binCount = 0; ; ++binCount) {
                /*
                	1)e = p.next 獲取p的下一個(gè)元素賦值給e。
                	2)(e = p.next) == null 判斷p.next是否等于null,等于null,說明p沒有下一個(gè)元素,那么此時(shí)到達(dá)了鏈表的尾部,還沒有找到重復(fù)的key,則說明HashMap沒有包含該鍵,將該鍵值對插入鏈表中。
                */
                if ((e = p.next) == null) {
                    /*
                    	1)創(chuàng)建一個(gè)新的結(jié)點(diǎn)插入到尾部
                    	 p.next = newNode(hash, key, value, null);
                    	 Node<K,V> newNode(int hash, K key, V value, Node<K,V> next) {
                                return new Node<>(hash, key, value, next);
                         }
                         注意第四個(gè)參數(shù)next是null,因?yàn)楫?dāng)前元素插入到鏈表末尾了,那么下一個(gè)結(jié)點(diǎn)肯定是null。
                         2)這種添加方式也滿足鏈表數(shù)據(jù)結(jié)構(gòu)的特點(diǎn),每次向后添加新的元素。
                    */
                    p.next = newNode(hash, key, value, null);
                    /*
                    	1)結(jié)點(diǎn)添加完成之后判斷此時(shí)結(jié)點(diǎn)個(gè)數(shù)是否大于TREEIFY_THRESHOLD臨界值8,如果大于則將鏈表轉(zhuǎn)換為紅黑樹。
                    	2)int binCount = 0 :表示for循環(huán)的初始化值。從0開始計(jì)數(shù)。記錄著遍歷結(jié)點(diǎn)的個(gè)數(shù)。值是0表示第一個(gè)結(jié)點(diǎn),1表示第二個(gè)結(jié)點(diǎn)。。。。7表示第八個(gè)結(jié)點(diǎn),加上數(shù)組中的的一個(gè)元素,元素個(gè)數(shù)是9。
                    	TREEIFY_THRESHOLD - 1 --》8 - 1 ---》7
                    	如果binCount的值是7(加上數(shù)組中的的一個(gè)元素,元素個(gè)數(shù)是9)
                    	TREEIFY_THRESHOLD - 1也是7,此時(shí)轉(zhuǎn)換紅黑樹。
                    */
                    if (binCount >= TREEIFY_THRESHOLD - 1) // -1 for 1st
                        // 轉(zhuǎn)換為紅黑樹
                        treeifyBin(tab, hash);
                    // 跳出循環(huán)
                    break;
                }
                /*
                	執(zhí)行到這里說明e = p.next 不是null,不是最后一個(gè)元素。繼續(xù)判斷鏈表中結(jié)點(diǎn)的key值與插入的元素的key值是否相等。
                */
                if (e.hash == hash &&
                    ((k = e.key) == key || (key != null && key.equals(k))))
                    // 相等,跳出循環(huán)
                    /*
                		要添加的元素和鏈表中的存在的元素的key相等了,則跳出for循環(huán)。不用再繼續(xù)比較了
                		直接執(zhí)行下面的if語句去替換去 if (e != null) 
                	*/
                    break;
                /*
                	說明新添加的元素和當(dāng)前結(jié)點(diǎn)不相等,繼續(xù)查找下一個(gè)結(jié)點(diǎn)。
                	用于遍歷桶中的鏈表,與前面的e = p.next組合,可以遍歷鏈表
                */
                p = e;
            }
        }
        /*
        	表示在桶中找到key值、hash值與插入元素相等的結(jié)點(diǎn)
        	也就是說通過上面的操作找到了重復(fù)的鍵,所以這里就是把該鍵的值變?yōu)樾碌闹担⒎祷嘏f值
        	這里完成了put方法的修改功能
        */
        if (e != null) { 
            // 記錄e的value
            V oldValue = e.value;
            // onlyIfAbsent為false或者舊值為null
            if (!onlyIfAbsent || oldValue == null)
                // 用新值替換舊值
                // e.value 表示舊值  value表示新值 
                e.value = value;
            // 訪問后回調(diào)
            afterNodeAccess(e);
            // 返回舊值
            return oldValue;
        }
    }
    // 修改記錄次數(shù)
    ++modCount;
    // 判斷實(shí)際大小是否大于threshold閾值,如果超過則擴(kuò)容
    if (++size > threshold)
        resize();
    // 插入后回調(diào)
    afterNodeInsertion(evict);
    return null;
}

(1)計(jì)算key的hash值;

(2)如果桶(數(shù)組)數(shù)量為0,則初始化桶;

(3)如果key所在的桶沒有元素,則直接插入;

(4)如果key所在的桶中的第一個(gè)元素的key與待插入的key相同,說明找到了元素,轉(zhuǎn)后續(xù)流程(9)處理;

(5)如果第一個(gè)元素是樹節(jié)點(diǎn),則調(diào)用樹節(jié)點(diǎn)的putTreeVal()尋找元素或插入樹節(jié)點(diǎn);

(6)如果不是以上三種情況,則遍歷桶對應(yīng)的鏈表查找key是否存在于鏈表中;

(7)如果找到了對應(yīng)key的元素,則轉(zhuǎn)后續(xù)流程(9)處理;

(8)如果沒找到對應(yīng)key的元素,則在鏈表最后插入一個(gè)新節(jié)點(diǎn)并判斷是否需要樹化;

(9)如果找到了對應(yīng)key的元素,則判斷是否需要替換舊值,并直接返回舊值;

(10)如果插入了元素,則數(shù)量加1并判斷是否需要擴(kuò)容;

7.2 擴(kuò)容方法 resize()

擴(kuò)容機(jī)制:

1.什么時(shí)候才需要擴(kuò)容?

當(dāng) HashMap 中的元素個(gè)數(shù)超過數(shù)組大小(數(shù)組長度)*loadFactor(負(fù)載因子)時(shí),就會(huì)進(jìn)行數(shù)組擴(kuò)容,loadFactor 的默認(rèn)值是 0.75。

2.HashMap 的擴(kuò)容是什么?

進(jìn)行擴(kuò)容,會(huì)伴隨著一次重新 hash 分配,并且會(huì)遍歷 hash 表中所有的元素,是非常耗時(shí)的。在編寫程序中,要盡量避免 resize。

HashMap 在進(jìn)行擴(kuò)容時(shí),使用的 rehash 方式非常巧妙,因?yàn)槊看螖U(kuò)容都是翻倍,與原來計(jì)算的 (n - 1) & hash 的結(jié)果相比,只是多了一個(gè) bit 位,所以結(jié)點(diǎn)要么就在原來的位置,要么就被分配到 “原位置 + 舊容量” 這個(gè)位置。

例如我們從 16 擴(kuò)展為 32 時(shí),具體的變化如下所示:

擴(kuò)容

因此元素在重新計(jì)算 hash 之后,因?yàn)?n 變?yōu)?2 倍,那么 n - 1 的標(biāo)記范圍在高位多 1bit(紅色),因此新的 index 就會(huì)發(fā)生這樣的變化。

hash

說明:

5 是假設(shè)計(jì)算出來的原來的索引。這樣就驗(yàn)證了上述所描述的:擴(kuò)容之后所以結(jié)點(diǎn)要么就在原來的位置,要么就被分配到 “原位置 + 舊容量” 這個(gè)位置。

因此,我們在擴(kuò)充 HashMap 的時(shí)候,不需要重新計(jì)算 hash,只需要看看原來的 hash 值新增的那個(gè) bit 是 1 還是 0 就可以了,是 0 的話索引沒變,是 1 的話索引變成 “原位置 + 舊容量” ??梢钥纯聪聢D為 16 擴(kuò)充為 32 的 resize 示意圖:

擴(kuò)容

正是因?yàn)檫@樣巧妙的 rehash 方式,既省去了重新計(jì)算 hash 值的時(shí)間,而且同時(shí),由于新增的 1bit 是 0 還是 1 可以認(rèn)為是隨機(jī)的,在 resize 的過程中保證了 rehash 之后每個(gè)桶上的結(jié)點(diǎn)數(shù)一定小于等于原來桶上的結(jié)點(diǎn)數(shù),保證了 rehash 之后不會(huì)出現(xiàn)更嚴(yán)重的 hash 沖突,均勻的把之前的沖突的結(jié)點(diǎn)分散到新的桶中了。

源碼 resize 方法的解讀

下面是代碼的具體實(shí)現(xiàn):

/**
 * 為什么需要擴(kuò)容呢?
 * 為了解決哈希沖突導(dǎo)致的鏈化影響查詢效率問題,擴(kuò)容會(huì)緩解該問題
 */
final Node<K,V>[] resize() {
    // oldTab:表示擴(kuò)容前的哈希表數(shù)組
    Node<K,V>[] oldTab = table;
    // oldCap:表示擴(kuò)容之前table數(shù)組長度
    // 如果當(dāng)前哈希表數(shù)組等于null 長度返回0,否則返回當(dāng)前哈希表數(shù)組的長度
    int oldCap = (oldTab == null) ? 0 : oldTab.length;
    // oldThr:表示擴(kuò)容之前的閥值(觸發(fā)本次擴(kuò)容的閾值) 默認(rèn)是12(16*0.75)
    int oldThr = threshold;
    // newCap:擴(kuò)容之后的table散列表數(shù)組長度
    // newThr: 擴(kuò)容之后,下次再出發(fā)擴(kuò)容的條件(新的擴(kuò)容閾值)
    int newCap, newThr = 0;
    // 如果老的哈希表數(shù)組長度oldCap > 0
    // 如果該條件成立,說明hashMap 中的散列表數(shù)組已經(jīng)初始化過了,是一次正常擴(kuò)容
    // 開始計(jì)算擴(kuò)容后的大小
    if (oldCap > 0) {
        // 擴(kuò)容之前的table數(shù)組大小已經(jīng)達(dá)到 最大閾值后,則不再擴(kuò)容
        // 且設(shè)置擴(kuò)容條件為:int的最大值
        if (oldCap >= MAXIMUM_CAPACITY) {
            // 修改閾值為int的最大值
            threshold = Integer.MAX_VALUE;
            return oldTab;
        }
        // 擴(kuò)容之前的table數(shù)組大小沒超過最大值,則擴(kuò)充為原來的2倍
        // (newCap = oldCap << 1) < MAXIMUM_CAPACITY 擴(kuò)大到2倍之后容量要小于最大容量
        // oldCap >= DEFAULT_INITIAL_CAPACITY 原哈希表數(shù)組長度大于等于數(shù)組初始化長度16
        // 如果oldCap 小于默認(rèn)初始容量16,比如傳入的默認(rèn)容量為8,則不執(zhí)行下面代碼
        else if ((newCap = oldCap << 1) < MAXIMUM_CAPACITY &&
                 oldCap >= DEFAULT_INITIAL_CAPACITY)
            // 新的擴(kuò)容閾值擴(kuò)大一倍
            newThr = oldThr << 1; // double threshold
    }
    // 如果老的哈希表數(shù)組長度oldCap == 0
    // 說明hashMap中的散列表還沒有初始化,這時(shí)候是null
    // 如果老閾值oldThr大于0 直接賦值
    /*
    	以下三種情況會(huì)直接進(jìn)入該判斷:(即,這時(shí)候oldThr擴(kuò)容閾值已存在)
    	1.new HashMap(initCap,loadFactor);
    	2.new HashMap(initCap);
    	3.new HashMap(Map);// 這個(gè)傳入的map中已經(jīng)有數(shù)據(jù)
    */
    else if (oldThr > 0) // 老閾值賦值給新的數(shù)組長度
        newCap = oldThr;
    // 如果老的哈希表數(shù)組長度oldCap == 0
    // 說明hashMap中的散列表還沒有初始化,這時(shí)候是null
    // 此時(shí),老擴(kuò)容閾值oldThr == 0
    else { // 直接使用默認(rèn)值
        newCap = DEFAULT_INITIAL_CAPACITY;//16
        newThr = (int)(DEFAULT_LOAD_FACTOR * DEFAULT_INITIAL_CAPACITY);//12
    }
    // 如果執(zhí)行到這個(gè)位置新的擴(kuò)容閾值newThr還沒有得到賦值,則
    // 需要計(jì)算新的resize最大上限
    if (newThr == 0) {
        float ft = (float)newCap * loadFactor;
        newThr = (newCap < MAXIMUM_CAPACITY && ft < (float)MAXIMUM_CAPACITY ?
                  (int)ft : Integer.MAX_VALUE);
    }
    // 將新的閥值newThr賦值給threshold
    threshold = newThr;
    @SuppressWarnings({"rawtypes","unchecked"})
    // 創(chuàng)建新的散列表
    // newCap是新的數(shù)組長度---> 32
    Node<K,V>[] newTab = (Node<K,V>[])new Node[newCap];
    table = newTab;
    // 說明:hashMap本次擴(kuò)容之前,table不為null
    if (oldTab != null) {
        // 把每個(gè)bucket桶的數(shù)據(jù)都移動(dòng)到新的散列表中
        // 遍歷舊的哈希表的每個(gè)桶,重新計(jì)算桶里元素的新位置
        for (int j = 0; j < oldCap; ++j) {
            // 當(dāng)前node節(jié)點(diǎn)
            Node<K,V> e;
            // 說明:此時(shí)的當(dāng)前桶位中有數(shù)據(jù),但是數(shù)據(jù)具體是 
            // 1.單個(gè)數(shù)據(jù) 、 2.還是鏈表 、 3.還是紅黑樹 并不能確定
            if ((e = oldTab[j]) != null) {
                // 原來的數(shù)據(jù)賦值為null 便于GC回收
                oldTab[j] = null;
                // 第一種情況:判斷數(shù)組是否有下一個(gè)引用(是否是單個(gè)數(shù)據(jù))
                if (e.next == null)
                    // 沒有下一個(gè)引用,說明不是鏈表,
                    // 當(dāng)前桶上只有單個(gè)數(shù)據(jù)的鍵值對,
                    // 可以將數(shù)據(jù)直接放入新的散列表中
                    // e.hash & (newCap - 1) 尋址公式得到的索引結(jié)果有兩種:
                    // 1.和原來舊散列表中的索引位置相同,
                    // 2.原來舊散列表中的索引位置i + 舊容量oldCap
                    newTab[e.hash & (newCap - 1)] = e;
                //第二種情況:桶位已經(jīng)形成紅黑樹
                else if (e instanceof TreeNode)
                    // 說明是紅黑樹來處理沖突的,則調(diào)用相關(guān)方法把樹分開
                    // 紅黑樹這塊,我會(huì)單獨(dú)寫一篇博客給大家詳細(xì)分析一下
                    // 紅黑樹相關(guān)可以先跳過
                    ((TreeNode<K,V>)e).split(this, newTab, j, oldCap);
                // 第三種情況:桶位已經(jīng)形成鏈表
                else { // 采用鏈表處理沖突
                    // 低位鏈表:
                    // 擴(kuò)容之后數(shù)組的下標(biāo)位置,與當(dāng)前數(shù)組的下標(biāo)位置一致 時(shí)使用
                    Node<K,V> loHead = null, loTail = null;
                    // 高位鏈表:擴(kuò)容之后數(shù)組的下標(biāo)位置等于
                    // 當(dāng)前數(shù)組下標(biāo)位置 + 擴(kuò)容之前數(shù)組的長度oldCap 時(shí)使用
                    Node<K,V> hiHead = null, hiTail = null;
                    Node<K,V> next;
                    // 通過上述講解的原理來計(jì)算結(jié)點(diǎn)的新位置
                    do {
                        // 原索引
                        next = e.next;
                     	// 這里來判斷如果等于true 
                        // e這個(gè)結(jié)點(diǎn)在resize之后不需要移動(dòng)位置
                        // 舉例:
                        // 假如hash1     -> ...... 0 1111
                        // 假如oldCap=16 -> ...... 1 0000
                        // e.hash & oldCap 結(jié)果為0,則
                        // 擴(kuò)容之后數(shù)組的下標(biāo)位置j,與當(dāng)前數(shù)組的下標(biāo)位置一致
                        // 使用低位鏈表
                        if ((e.hash & oldCap) == 0) {
                            if (loTail == null)
                                loHead = e;
                            else
                                loTail.next = e;
                            loTail = e;
                        }
                        // 舉例:
                        // 假如hash2     -> ...... 1 1111
                        // 假如oldCap=16 -> ...... 1 0000
                        // e.hash & oldCap 結(jié)果不為0,則
                        // 擴(kuò)容之后數(shù)組的下標(biāo)位置為:
                        // 當(dāng)前數(shù)組下標(biāo)位置j + 擴(kuò)容之前數(shù)組的長度oldCap
                        // 使用高位鏈表
                        else {
                            if (hiTail == null)
                                hiHead = e;
                            else
                                hiTail.next = e;
                            hiTail = e;
                        }
                    } while ((e = next) != null);
                    // 將低位鏈表放到bucket桶里
                    if (loTail != null) {
                        loTail.next = null;
                        // 索引位置=當(dāng)前數(shù)組下標(biāo)位置j
                        newTab[j] = loHead;
                    }
                    // 將高位鏈表放到bucket里
                    if (hiTail != null) {
                        hiTail.next = null;
                        // 索引位置=當(dāng)前數(shù)組下標(biāo)位置j + 擴(kuò)容之前數(shù)組的長度oldCap
                        newTab[j + oldCap] = hiHead;
                    }
                }
            }
        }
    }
    // 返回新散列表
    return newTab;
}

(1)如果使用是默認(rèn)構(gòu)造方法,則第一次插入元素時(shí)初始化為默認(rèn)值,容量為16,擴(kuò)容門檻為12;

(2)如果使用的是非默認(rèn)構(gòu)造方法,則第一次插入元素時(shí)初始化容量等于擴(kuò)容門檻,擴(kuò)容門檻在構(gòu)造方法里等于傳入容量向上最近的2的n次方;

(3)如果舊容量大于0,則新容量等于舊容量的2倍,但不超過最大容量2的30次方,新擴(kuò)容門檻為舊擴(kuò)容門檻的2倍;

(4)創(chuàng)建一個(gè)新容量的桶;

(5)搬移元素,原鏈表分化成兩個(gè)鏈表,低位鏈表存儲(chǔ)在原來桶的位置,高位鏈表搬移到原來桶的位置加舊容量的位置;

7.3 刪除方法 remove()

刪除方法就是首先先找到元素的位置,如果是鏈表就遍歷鏈表找到元素之后刪除。如果是用紅黑樹就遍歷樹然后找到之后做刪除,樹小于 6 的時(shí)候要轉(zhuǎn)鏈表。

刪除 remove() 方法

// remove方法的具體實(shí)現(xiàn)在removeNode方法中,所以我們重點(diǎn)看下removeNode方法
// 根據(jù)key刪除
public V remove(Object key) {
        Node<K,V> e;
        return (e = removeNode(hash(key), key, null, false, true)) == null ?
            null : e.value;
    }
// 根據(jù)key,value 刪除
@Override
public boolean remove(Object key, Object value) {
    return removeNode(hash(key), key, value, true, true) != null;
}

removeNode() 方法:

final Node<K,V> removeNode(int hash, Object key, Object value,
                           boolean matchValue, boolean movable) {
    // 參數(shù):
    // matchValue 當(dāng)根據(jù) key和value 刪除的時(shí)候該參數(shù)為true
    // movable 可以先不用考慮這個(gè)參數(shù) 
    // tab:引用當(dāng)前haashMap中的散列表
    // p:當(dāng)前node元素
    // n:當(dāng)前散列表數(shù)組長度
    // index:表示尋址結(jié)果
    Node<K,V>[] tab; Node<K,V> p; int n, index;
	// 根據(jù)hash找到位置 
	// 如果當(dāng)前key映射到的桶不為空
    if ((tab = table) != null && (n = tab.length) > 0 &&
        (p = tab[index = (n - 1) & hash]) != null) {
        // 進(jìn)入這個(gè)if判斷內(nèi)部,說明桶位是有數(shù)據(jù)的,需要進(jìn)行查詢操作,并且執(zhí)行刪除
        // node:通過查找得到的要?jiǎng)h除的元素
        // e:表示當(dāng)前node的下一個(gè)元素
        // k,v 鍵 值
        Node<K,V> node = null, e; K k; V v;
        // 第一種情況:當(dāng)前桶位中的元素 即為我們要?jiǎng)h除的元素
        // 如果桶上的結(jié)點(diǎn)就是要找的key,則將node指向該結(jié)點(diǎn)
        if (p.hash == hash &&
            ((k = p.key) == key || (key != null && key.equals(k))))
            node = p;
        // 如果桶位中的頭一個(gè)元素不是我們要找的元素,且桶位中的e = p.next不為null
        // 說明該桶位中的節(jié)點(diǎn)存在下一個(gè)節(jié)點(diǎn)
        else if ((e = p.next) != null) {
            // 說明:當(dāng)前桶位,要么是 鏈表,要么是 紅黑樹
            // 第二種情況:判斷桶位中是否已經(jīng)形成了紅黑樹
            if (p instanceof TreeNode)
                // 說明是以紅黑樹來處理的沖突,則獲取紅黑樹要?jiǎng)h除的結(jié)點(diǎn)
                node = ((TreeNode<K,V>)p).getTreeNode(hash, key);
            // 第三種情況:桶位中已經(jīng)形成鏈表
            else {
                // 判斷是否以鏈表方式處理hash沖突
                // 是的話則通過遍歷鏈表來尋找要?jiǎng)h除的結(jié)點(diǎn)
                do {
                    if (e.hash == hash &&
                        ((k = e.key) == key ||
                         (key != null && key.equals(k)))) {
                        node = e;
                        break;
                    }
                    p = e;
                } while ((e = e.next) != null);
            }
        }
        // 比較找到的key的value和要?jiǎng)h除的是否匹配
        if (node != null && (!matchValue || (v = node.value) == value ||
                             (value != null && value.equals(v)))) {
            // 第一種情況:如果桶位中是紅黑樹,通過調(diào)用紅黑樹的方法來刪除結(jié)點(diǎn)
            if (node instanceof TreeNode)
                ((TreeNode<K,V>)node).removeTreeNode(this, tab, movable);
            // 第二種情況:如果桶位中是鏈表
            else if (node == p)
                // 鏈表刪除
                tab[index] = node.next;
            // 如果桶位中
            else
                // 第三種情況:將當(dāng)前元素p的下一個(gè)元素設(shè)置為 要?jiǎng)h除元素的 下一個(gè)元素
                p.next = node.next;
            // 記錄修改次數(shù)
            ++modCount;
            // 變動(dòng)的數(shù)量
            --size;
            afterNodeRemoval(node);
            return node;
        }
    }
    return null;
}

7.4 查找元素方法 get()

查找方法,通過元素的 key 找到 value。

代碼如下:

public V get(Object key) {
    Node<K,V> e;
    return (e = getNode(hash(key), key)) == null ? null : e.value;
}

get 方法主要調(diào)用的是 getNode 方法,代碼如下:

final Node<K,V> getNode(int hash, Object key) {
    // tab:引用當(dāng)前hashMap的散列表
    // first:桶位中的頭元素
    // e:臨時(shí)node元素
    // n:table數(shù)組的長度
    Node<K,V>[] tab; Node<K,V> first, e; int n; K k;
    // 如果哈希表不為空,并且key對應(yīng)的桶不為空
    if ((tab = table) != null && (n = tab.length) > 0 &&
        (first = tab[(n - 1) & hash]) != null) {
        /* 
        	判斷數(shù)組元素是否相等
        	根據(jù)索引的位置檢查第一個(gè)元素
        	注意:總是檢查第一個(gè)元素
        */
        // 第一種情況:定位出來的桶位元素 就是我們要get的數(shù)據(jù)
        if (first.hash == hash && // always check first node
            ((k = first.key) == key || (key != null && key.equals(k))))
            return first;
        // 桶位第一個(gè)元素不是我們要找的目標(biāo)元素,且first.next不為null
        // 說明當(dāng)前桶位不止一個(gè)元素,可能是鏈表,也可能是紅黑樹
        if ((e = first.next) != null) {
            // 第二種情況:桶位已經(jīng)升級成了紅黑樹
            // 判斷是否是紅黑樹,是的話調(diào)用紅黑樹中的getTreeNode方法獲取結(jié)點(diǎn)
            if (first instanceof TreeNode)
                // 調(diào)用與樹相關(guān)的方法得到目標(biāo)元素
                return ((TreeNode<K,V>)first).getTreeNode(hash, key);
            // 第三種情況:桶位已經(jīng)形成鏈表
            do {
                // 不是紅黑樹的話,那就是鏈表結(jié)構(gòu)了
                // 通過循環(huán)的方法判斷鏈表中是否存在該key
                if (e.hash == hash &&
                    ((k = e.key) == key || (key != null && key.equals(k))))
                    return e;
            } while ((e = e.next) != null);
        }
    }
    // 如果沒找到返回null
    return null;
}

小結(jié)

get 方法實(shí)現(xiàn)的步驟:

a. 通過 hash 值獲取該 key 映射到的桶

b. 桶上的 key 就是要查找的 key,則直接找到并返回

c. 桶上的 key 不是要找的 key,則查看后續(xù)的結(jié)點(diǎn):

如果后續(xù)結(jié)點(diǎn)是紅黑樹結(jié)點(diǎn),通過調(diào)用紅黑樹的方法根據(jù) key 獲取 value

如果后續(xù)結(jié)點(diǎn)是鏈表結(jié)點(diǎn),則通過循環(huán)遍歷鏈表根據(jù) key 獲取 value

8. 遍歷HashMap的幾種方式

分別遍歷 Key 和 Values

for (String key : map.keySet()) {
	System.out.println(key);
}
for (Object vlaue : map.values() {
	System.out.println(value);
}

使用 Iterator 迭代器迭代

Iterator<Map.Entry<String, Object>> iterator = map.entrySet().iterator();
while (iterator.hasNext()) {
    Map.Entry<String, Object> mapEntry = iterator.next();
    System.out.println(mapEntry.getKey() + "---" + mapEntry.getValue());
}

通過 get 方式(不建議使用)

Set<String> keySet = map.keySet();
for (String str : keySet) {
	System.out.println(str + "---" + map.get(str));
}

說明

根據(jù)阿里開發(fā)手冊,不建議使用這種方式,因?yàn)榈鷥纱?。keySet 獲取 Iterator一次,還有通過 get 又迭代一次,降低性能。

jdk8 以后使用 Map 接口中的默認(rèn)方法:

default void forEach(BiConsumer<? super K,? super V> action) 
// BiConsumer接口中的方法:
	void accept(T t, U u) 對給定的參數(shù)執(zhí)行此操作。  
		參數(shù) 
            t - 第一個(gè)輸入?yún)?shù) 
            u - 第二個(gè)輸入?yún)?shù) 

遍歷代碼:

HashMap<String,String> map = new HashMap();
map.put("001", "zhangsan");
map.put("002", "lisi");
map.forEach((key, value) -> {
    System.out.println(key + "---" + value);
});

9、總結(jié)

(1)HashMap是一種散列表,采用(數(shù)組 + 鏈表 + 紅黑樹)的存儲(chǔ)結(jié)構(gòu);

(2)HashMap的默認(rèn)初始容量為16(1<<4),默認(rèn)裝載因子為0.75f,容量總是2的n次方;

(3)HashMap擴(kuò)容時(shí)每次容量變?yōu)樵瓉淼膬杀叮?/p>

(4)當(dāng)桶的數(shù)量小于64時(shí)不會(huì)進(jìn)行樹化,只會(huì)擴(kuò)容;

(5)當(dāng)桶的數(shù)量大于64且單個(gè)桶中元素的數(shù)量大于8時(shí),進(jìn)行樹化;

(6)當(dāng)單個(gè)桶中元素?cái)?shù)量小于6時(shí),進(jìn)行反樹化;

(7)HashMap是非線程安全的容器;

(8)HashMap查找添加元素的時(shí)間復(fù)雜度都為O(1);

這篇文章就到這里了,也希望大家多多關(guān)注腳本之家的其他內(nèi)容!

相關(guān)文章

  • Spring?Boot日志介紹和配置

    Spring?Boot日志介紹和配置

    在程序中,日志對象通過LoggerFactory獲取,日志框架如SLF4J提供統(tǒng)一API,便于管理和維護(hù),日志級別分為FATAL、ERROR、WARN、INFO、DEBUG、TRACE,通過配置可細(xì)化日志輸出,日志還可持久化存儲(chǔ)和格式化,使用lombok可簡化日志代碼的編寫
    2024-11-11
  • mybatis if test判斷BigDecimal遇到的坑及解決

    mybatis if test判斷BigDecimal遇到的坑及解決

    這篇文章主要介紹了mybatis if test判斷BigDecimal遇到的坑及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • mybatis-plus與mybatis共存的實(shí)現(xiàn)

    mybatis-plus與mybatis共存的實(shí)現(xiàn)

    本文主要介紹了mybatis-plus與mybatis共存的實(shí)現(xiàn),文中根據(jù)實(shí)例編碼詳細(xì)介紹的十分詳盡,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 關(guān)于synchronized的參數(shù)及其含義

    關(guān)于synchronized的參數(shù)及其含義

    這篇文章主要介紹了synchronized的參數(shù)及其含義詳解,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • SpringBoot整合ELK使用教程

    SpringBoot整合ELK使用教程

    對于一個(gè)運(yùn)行中的應(yīng)用來說,線上排查問題是一件很頭疼的問題,不管是springboot單應(yīng)用,還是springcloud微服務(wù)應(yīng)用,一旦在生產(chǎn)環(huán)境出了問題,大多數(shù)人第一反應(yīng)就是趕緊去看日志查問題,本文給大家介紹了SpringBoot整合ELK使用教程,需要的朋友可以參考下
    2024-11-11
  • 如何利用java中String類的substring()字符串截取最后一個(gè)字符

    如何利用java中String類的substring()字符串截取最后一個(gè)字符

    Java中的String是不可變的類型,因此substring()方法并不會(huì)改變原字符串,而是返回了一個(gè)新的字符串,這篇文章主要介紹了如何利用java中String類的substring()字符串截取最后一個(gè)字符,需要的朋友可以參考下
    2023-11-11
  • Java實(shí)戰(zhàn)之在線寄查快遞系統(tǒng)的實(shí)現(xiàn)

    Java實(shí)戰(zhàn)之在線寄查快遞系統(tǒng)的實(shí)現(xiàn)

    這篇文章主要介紹了如何利用Java制作一個(gè)在線寄查快遞系統(tǒng),文中采用的技術(shù)有java、SpringBoot、FreeMarker、Mysql,需要的可以參考一下
    2022-02-02
  • java中stack(棧)的使用代碼實(shí)例

    java中stack(棧)的使用代碼實(shí)例

    這篇文章主要介紹了java中stack(棧)的使用代碼實(shí)例,具有一定借鑒價(jià)值,需要的朋友可以參考下。
    2017-12-12
  • Spring boot2X負(fù)載均衡和反向代理實(shí)現(xiàn)過程解析

    Spring boot2X負(fù)載均衡和反向代理實(shí)現(xiàn)過程解析

    這篇文章主要介紹了Spring boot2X負(fù)載均衡和反向代理實(shí)現(xiàn)過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-12-12
  • Java中TypeReference用法詳情說明

    Java中TypeReference用法詳情說明

    這篇文章主要介紹了Java中TypeReference用法詳情說明,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-07-07

最新評論

日韩特级黄片高清在线看| 大尺度激情四射网站| 欧美一区二区三区在线资源| 婷婷综合蜜桃av在线| 亚洲第17页国产精品| 黄色大片男人操女人逼| 天天干天天操天天摸天天射| 亚洲在线免费h观看网站| 精品91高清在线观看| 国产九色91在线视频| 偷拍自拍 中文字幕| 天天日天天玩天天摸| 亚洲国产美女一区二区三区软件 | 免费观看理论片完整版| 亚洲一区自拍高清免费视频| 亚洲av无硬久久精品蜜桃| 夜女神免费福利视频| 国产精品日韩欧美一区二区| 不卡日韩av在线观看| 福利视频一区二区三区筱慧 | 亚洲 图片 欧美 图片| 美女av色播在线播放| 欧洲精品第一页欧洲精品亚洲| 免费高清自慰一区二区三区网站| 久草免费人妻视频在线| 大肉大捧一进一出好爽在线视频| 久久农村老妇乱69系列| 日本精品视频不卡一二三| 国产欧美精品一区二区高清| 日韩北条麻妃一区在线| 国产精品午夜国产小视频| av天堂资源最新版在线看| 久久美欧人妻少妇一区二区三区| 日本18禁久久久久久| 中文字幕在线一区精品| 午夜dv内射一区区| 天天艹天天干天天操| 日韩激情文学在线视频| 蜜桃视频17c在线一区二区| 日韩av大胆在线观看| 日本一二三区不卡无| xxx日本hd高清| 中文字幕国产专区欧美激情| 黄色大片免费观看网站| 青青青aaaa免费| 久久丁香花五月天色婷婷| 精品国产亚洲av一淫| 中国视频一区二区三区| 视频一区二区综合精品| 亚洲日本一区二区三区 | 免费看国产av网站| 天天日天天透天天操| 77久久久久国产精产品| 日韩三级黄色片网站| 91国产在线免费播放| 久久久久久久久久久免费女人| 天天色天天操天天透| a v欧美一区=区三区| 9色精品视频在线观看| 国产精品一区二区久久久av| 熟女人妻在线观看视频| 国产精品人妻一区二区三区网站| 日本少妇在线视频大香蕉在线观看| 精品美女在线观看视频在线观看 | 国产三级影院在线观看| 91大屁股国产一区二区| 欧美熟妇一区二区三区仙踪林 | 日本一二三区不卡无| 天天干天天操天天插天天日| 日本韩国亚洲综合日韩欧美国产| 亚洲av自拍偷拍综合| 直接观看免费黄网站| 欧美一区二区中文字幕电影| 日韩亚洲高清在线观看| 欧美综合婷婷欧美综合| 亚洲最大黄了色网站| 日韩美在线观看视频黄| jul—619中文字幕在线| 免费在线观看视频啪啪| 天天日天天摸天天爱| 亚洲欧美清纯唯美另类| 91欧美在线免费观看| 美女在线观看日本亚洲一区| 亚洲av无女神免非久久| 日韩欧美一级aa大片| 水蜜桃一区二区三区在线观看视频 | 精内国产乱码久久久久久| 中国黄色av一级片| 自拍偷拍,中文字幕| 亚洲av黄色在线网站| 亚洲激情,偷拍视频| 欧美色婷婷综合在线| 日本在线一区二区不卡视频| 天天草天天色天天干| 青青在线视频性感少妇和隔壁黑丝| 亚洲高清国产拍青青草原| 国产精品污污污久久| 日日夜夜精品一二三| 一二三中文乱码亚洲乱码one | 日本脱亚入欧是指什么| 女同性ⅹxx女同hd| 亚洲综合一区二区精品久久| 东京热男人的av天堂| 少妇ww搡性bbb91| 国产女孩喷水在线观看| 绯色av蜜臀vs少妇| 人妻熟女中文字幕aⅴ在线| 人人妻人人爽人人澡人人精品| 亚洲精品无码久久久久不卡| 337p日本大胆欧美人| 97精品成人一区二区三区| 综合色区亚洲熟妇shxstz| 久久久精品精品视频视频| 亚洲综合乱码一区二区| 精品国产亚洲av一淫| av线天堂在线观看| 521精品视频在线观看| 91色网站免费在线观看| 伊人综合免费在线视频| 密臀av一区在线观看| 久久热久久视频在线观看| 国产午夜无码福利在线看| 久久久精品精品视频视频| 欧美一区二区三区在线资源| 熟女妇女老妇一二三区| 熟女视频一区,二区,三区| 日本免费视频午夜福利视频| 欧美aa一级一区三区四区| 国产女人被做到高潮免费视频| 免费看高清av的网站| 欧美3p在线观看一区二区三区| 狠狠的往里顶撞h百合| 天天躁日日躁狠狠躁av麻豆| 国产亚洲精品视频合集| 亚洲精品久久视频婷婷| 91啪国自产中文字幕在线| 色婷婷六月亚洲综合香蕉| 青青在线视频性感少妇和隔壁黑丝| 中文字幕第1页av一天堂网| 欧洲欧美日韩国产在线| 伊人综合免费在线视频| 亚洲精品 欧美日韩| 97精品人妻一区二区三区精品| 成年美女黄网站18禁久久| 福利视频广场一区二区| 大香蕉伊人国产在线| 成人精品在线观看视频| 日本精品视频不卡一二三| 六月婷婷激情一区二区三区| 综合页自拍视频在线播放| 亚洲日产av一区二区在线| 黑人性生活视频免费看| 精品av久久久久久久| 加勒比视频在线免费观看| 亚洲一级美女啪啪啪| av视屏免费在线播放| 插逼视频双插洞国产操逼插洞| 久久久久久国产精品| 国产三级精品三级在线不卡| yy96视频在线观看| 一二三区在线观看视频| 国产精品大陆在线2019不卡| 内射久久久久综合网| 成人蜜桃美臀九一一区二区三区| 无码精品一区二区三区人| 大胆亚洲av日韩av| 青青青青青手机视频| 日本少妇人妻xxxxx18| 最新91九色国产在线观看| 国产在线一区二区三区麻酥酥 | 超污视频在线观看污污污| 亚洲推理片免费看网站| 最新黄色av网站在线观看| 一区二区三区久久中文字幕| 久久精品久久精品亚洲人| 欧美一区二区三区高清不卡tv | 青青青爽视频在线播放| 在线免费观看日本片| 在线可以看的视频你懂的| 国产精品精品精品999| 干逼又爽又黄又免费的视频| 欧美日韩一级黄片免费观看| 亚洲护士一区二区三区| 五月色婷婷综合开心网4438| 中文 成人 在线 视频| 人人妻人人爽人人添夜| 中文字幕日韩91人妻在线| 偷拍自拍国产在线视频| av欧美网站在线观看| 任你操任你干精品在线视频| 天天干夜夜操天天舔| 五月天中文字幕内射| 人妻少妇性色欲欧美日韩| 国产综合视频在线看片| 黄色片一级美女黄色片| av久久精品北条麻妃av观看| 福利午夜视频在线观看| 亚洲欧美成人综合在线观看| 日韩av大胆在线观看| 青青草视频手机免费在线观看| 国产精品伦理片一区二区| 国产精品自拍偷拍a| 欧美麻豆av在线播放| 91精品资源免费观看| 日韩欧美制服诱惑一区在线| 91传媒一区二区三区| 欧美国产亚洲中英文字幕| ka0ri在线视频| 亚洲天天干 夜夜操| 国产中文精品在线观看| 精品国产亚洲av一淫| 亚洲av无硬久久精品蜜桃| 91传媒一区二区三区| 端庄人妻堕落挣扎沉沦| 特黄老太婆aa毛毛片| 成人av天堂丝袜在线观看| 免费观看国产综合视频| 又粗又硬又猛又黄免费30| 青草久久视频在线观看| 日本啪啪啪啪啪啪啪| 亚洲av琪琪男人的天堂| 无套猛戳丰满少妇人妻| 国产精品国色综合久久| 超黄超污网站在线观看| 91高清成人在线视频| 直接观看免费黄网站| 人人人妻人人澡人人| 中文字幕在线永久免费播放| 久久久久久99国产精品| 欧美日韩人妻久久精品高清国产 | 日韩欧美中文国产在线| 欧美一区二区中文字幕电影 | 久久精品美女免费视频| 青青青国产片免费观看视频| 不卡一区一区三区在线| 2022精品久久久久久中文字幕| 午夜在线一区二区免费| 91高清成人在线视频| 日本熟妇色熟妇在线观看| 天天操天天弄天天射| 熟女人妻在线中出观看完整版| 视频一区二区三区高清在线| 亚洲欧美久久久久久久久| 亚洲天堂第一页中文字幕| 欧美成人猛片aaaaaaa| 青娱乐最新视频在线| 日本人妻少妇18—xx| 亚洲国产成人在线一区| 亚洲成人国产av在线| 韩国男女黄色在线观看| 青青青青青青青青青青草青青| 天天综合天天综合天天网| 小泽玛利亚视频在线观看| 久久丁香婷婷六月天| 99热99re在线播放| 国产激情av网站在线观看| 2020av天堂网在线观看| 偷拍自拍亚洲视频在线观看| 不卡日韩av在线观看| 日韩av有码一区二区三区4| 免费一级黄色av网站| 搡老熟女一区二区在线观看| 午夜福利人人妻人人澡人人爽| 亚洲美女美妇久久字幕组| 人人妻人人爽人人添夜| 欧美精品激情在线最新观看视频| 日本一区美女福利视频| 午夜场射精嗯嗯啊啊视频| 午夜91一区二区三区| 伊拉克及约旦宣布关闭领空| gogo国模私拍视频| 一区二区三区在线视频福利| aiss午夜免费视频| 精品老妇女久久9g国产| 九一传媒制片厂视频在线免费观看 | 大香蕉玖玖一区2区| 同居了嫂子在线播高清中文| yellow在线播放av啊啊啊| 女同性ⅹxx女同h偷拍| 精品区一区二区三区四区人妻| 岛国黄色大片在线观看| 国产一区成人在线观看视频 | 黄色av网站免费在线| 不卡日韩av在线观看| 人妻凌辱欧美丰满熟妇| 任我爽精品视频在线播放| 在线视频这里只有精品自拍| 乱亲女秽乱长久久久| 91精品国产黑色丝袜| 国产亚洲精品品视频在线| 亚洲欧美综合另类13p| 夜女神免费福利视频| 99亚洲美女一区二区三区| 韩国爱爱视频中文字幕| 亚洲美女高潮喷浆视频| 精品久久久久久久久久久a√国产| 青青色国产视频在线| av天堂加勒比在线| 欧美精品亚洲精品日韩在线| 经典av尤物一区二区| 国产品国产三级国产普通话三级| av高潮迭起在线观看| 日韩影片一区二区三区不卡免费 | 最新激情中文字幕视频| 日本少妇人妻xxxxx18| 日韩精品一区二区三区在线播放| 又粗又长 明星操逼小视频| 婷婷综合亚洲爱久久| 五十路丰满人妻熟妇| 亚洲老熟妇日本老妇| 青青青视频自偷自拍38碰| 成人高清在线观看视频| av天堂中文字幕最新| 免费观看成年人视频在线观看| 在线观看视频 你懂的| 人妻无码色噜噜狠狠狠狠色| 国产97视频在线精品| 久久久久久久亚洲午夜综合福利 | 人妻丰满熟妇综合网| 蝴蝶伊人久久中文娱乐网| 亚洲精品麻豆免费在线观看| 精品美女在线观看视频在线观看| 久久美欧人妻少妇一区二区三区| 91亚洲手机在线视频播放| 欧美一级色视频美日韩| 日本人竟这样玩学生妹| 传媒在线播放国产精品一区| 2025年人妻中文字幕乱码在线| 狠狠操狠狠操免费视频| 社区自拍揄拍尻屁你懂的| 97国产在线av精品| 成人av电影免费版| 亚洲综合乱码一区二区| 男生舔女生逼逼视频| 韩国爱爱视频中文字幕| 日韩熟女系列一区二区三区| 中文字幕乱码人妻电影| 污污小视频91在线观看| 欧美成人综合色在线噜噜| 国产使劲操在线播放| 91天堂精品一区二区| 综合国产成人在线观看| 78色精品一区二区三区| huangse网站在线观看| 色综合天天综合网国产成人| 中文字幕无码一区二区免费| 日韩欧美国产一区ab| 国产成人精品av网站| 日韩成人免费电影二区| 91av精品视频在线| 久草视频在线一区二区三区资源站 | 欧美日韩v中文在线| 在线可以看的视频你懂的| 性感美女高潮视频久久久| 色天天天天射天天舔| 午夜在线观看岛国av,com| 97香蕉碰碰人妻国产樱花| 少妇人妻久久久久视频黄片| 91大屁股国产一区二区| 哥哥姐姐综合激情小说| 综合激情网激情五月五月婷婷| 久久国产精品精品美女| 99精品免费观看视频| 国产福利在线视频一区| 后入美女人妻高清在线| 中文字幕日韩人妻在线三区| 99精品视频在线观看免费播放| 成年人啪啪视频在线观看| av在线播放国产不卡| 91av中文视频在线| 在线观看视频网站麻豆| 521精品视频在线观看| 亚洲成人av一区在线| 欧美日本国产自视大全| 日本免费视频午夜福利视频| 在线视频免费观看网| 日韩精品啪啪视频一道免费| 日本熟妇色熟妇在线观看| 中文字幕av第1页中文字幕| 国产va在线观看精品| 欧美激情精品在线观看| 爱爱免费在线观看视频| 91chinese在线视频| 噜噜色噜噜噜久色超碰| 狠狠躁狠狠爱网站视频| 绝顶痉挛大潮喷高潮无码 | 亚洲国产精品美女在线观看| 91国语爽死我了不卡| 一本久久精品一区二区| 亚洲久久午夜av一区二区| 一本久久精品一区二区| 美女大bxxxx内射| 成人av久久精品一区二区| 日本熟妇喷水xxx| 熟女妇女老妇一二三区| 一级黄色片夫妻性生活| 在线不卡成人黄色精品| 欧美女同性恋免费a| 免费福利av在线一区二区三区| 久久久久久国产精品| 和邻居少妇愉情中文字幕| 一二三中文乱码亚洲乱码one| 国产夫妻视频在线观看免费| 日韩人妻在线视频免费| 亚洲免费福利一区二区三区| 久久精品国产999| 天堂va蜜桃一区入口| 人人妻人人爽人人添夜| 老司机你懂得福利视频| 人妻丝袜榨强中文字幕| 亚洲 色图 偷拍 欧美| 大鸡八强奸视频在线观看| 日韩加勒比东京热二区| 福利视频网久久91| 亚洲变态另类色图天堂网| 红桃av成人在线观看| 欧美视频不卡一区四区| 大香蕉大香蕉大香蕉大香蕉大香蕉| 黄片色呦呦视频免费看| 人人爱人人妻人人澡39| 同居了嫂子在线播高清中文| 国产av一区2区3区| 岛国青草视频在线观看| 成年人午夜黄片视频资源| 天天操夜夜操天天操天天操 | 国产视频精品资源网站| 精品少妇一二三视频在线| 无套猛戳丰满少妇人妻| 日本女大学生的黄色小视频| 亚洲一级 片内射视正片| 亚洲成人激情视频免费观看了| 日本熟妇丰满厨房55| 国产成人综合一区2区| 一区二区三区日本伦理| 日韩av中文在线免费观看| 最新欧美一二三视频| 亚洲2021av天堂| 国产亚洲成人免费在线观看 | 日韩精品中文字幕福利| 日韩欧美国产精品91| 亚洲精品午夜aaa久久| 日韩中文字幕在线播放第二页| 青青色国产视频在线| 亚洲av日韩精品久久久久久hd| 特级无码毛片免费视频播放| 97精品人妻一区二区三区精品| 欧美成人综合视频一区二区| 班长撕开乳罩揉我胸好爽| 久久久噜噜噜久久熟女av| 三上悠亚和黑人665番号| 欧美在线偷拍视频免费看| 亚洲伊人av天堂有码在线| 福利片区一区二体验区| 久草视频首页在线观看| 97a片免费在线观看| av完全免费在线观看av| 欧美xxx成人在线| 国产亚洲欧美另类在线观看| 一区二区熟女人妻视频| 日本精品美女在线观看| 欧亚乱色一区二区三区| 绝顶痉挛大潮喷高潮无码| 密臀av一区在线观看| 韩国一级特黄大片做受| 成人蜜桃美臀九一一区二区三区| 亚洲av自拍天堂网| 91九色porny国产蝌蚪视频| 久久人人做人人妻人人玩精品vr| 日韩三级黄色片网站| 亚洲女人的天堂av| 亚洲欧美激情人妻偷拍| 端庄人妻堕落挣扎沉沦| 国产成人综合一区2区| 国产日韩精品电影7777| 91成人在线观看免费视频| 亚洲av午夜免费观看| 国产一区成人在线观看视频| 北条麻妃高跟丝袜啪啪| 日韩美女福利视频网| 日本高清撒尿pissing| 欧美精品中文字幕久久二区| 人妻丝袜榨强中文字幕| 久久久久只精品国产三级| 婷婷激情四射在线观看视频| 2022国产综合在线干| 国产在线91观看免费观看| 精品久久婷婷免费视频| 国产亚洲精品视频合集| 91综合久久亚洲综合| 一区二区久久成人网| 蜜桃视频在线欧美一区| 国产精品欧美日韩区二区| 青青青激情在线观看视频| 自拍偷拍亚洲欧美在线视频| 狠狠操操操操操操操操操| 亚洲的电影一区二区三区| 又大又湿又爽又紧A视频| 在线观看免费岛国av| 大尺度激情四射网站| 欧美综合婷婷欧美综合| 十八禁在线观看地址免费 | 40道精品招牌菜特色| 熟女视频一区,二区,三区| 欧美成人精品在线观看| 亚洲欧美国产麻豆综合| 首之国产AV医生和护士小芳| 大鸡巴操b视频在线| 精品老妇女久久9g国产| av一区二区三区人妻| 天天综合天天综合天天网| 精品久久久久久高潮| 亚洲护士一区二区三区| 天天摸天天干天天操科普| 久久久久久久久久性潮| 88成人免费av网站| 污污小视频91在线观看| 午夜免费体验区在线观看| 成人蜜臀午夜久久一区| 4个黑人操素人视频网站精品91| 亚洲蜜臀av一区二区三区九色 | 午夜av一区二区三区| 国产三级精品三级在线不卡| 在线国产精品一区二区三区| 丰满的子国产在线观看| 国产成人综合一区2区| 在线观看国产免费麻豆| 香蕉aⅴ一区二区三区| 国产aⅴ一线在线观看| 特黄老太婆aa毛毛片| 大屁股肉感人妻中文字幕在线| 国产精品久久久久久美女校花| 亚洲人妻视频在线网| 亚洲熟妇x久久av久久| 日韩近亲视频在线观看| 操操网操操伊剧情片中文字幕网| 午夜在线一区二区免费| 91国偷自产一区二区三区精品| 91免费福利网91麻豆国产精品| 2021年国产精品自拍| 亚洲免费va在线播放| 四川乱子伦视频国产vip| 18禁美女黄网站色大片下载| 亚洲国产成人在线一区| 中文字幕在线第一页成人| 亚洲超碰97人人做人人爱| 91色网站免费在线观看| 成人sm视频在线观看| 国产又粗又硬又大视频| 日韩视频一区二区免费观看| 亚洲中文字幕国产日韩| 激情图片日韩欧美人妻| 天天色天天操天天透| av视网站在线观看| 91福利在线视频免费观看| 日本少妇在线视频大香蕉在线观看| 亚洲黄色av网站免费播放| 日辽宁老肥女在线观看视频| 日本后入视频在线观看 | 免费人成黄页网站在线观看国产| 免费观看理论片完整版| 亚洲在线观看中文字幕av| 日本人竟这样玩学生妹| 少妇与子乱在线观看| 青青草原网站在线观看| 沈阳熟妇28厘米大战黑人| 社区自拍揄拍尻屁你懂的| 亚洲激情唯美亚洲激情图片| 一区二区三区视频,福利一区二区| 中文字幕在线视频一区二区三区 | 亚洲综合自拍视频一区| 久久免费看少妇高潮完整版| 国产中文精品在线观看| 天干天天天色天天日天天射| 青青青爽视频在线播放| 蜜桃视频17c在线一区二区| 不戴胸罩引我诱的隔壁的人妻| 制丝袜业一区二区三区| 在线观看成人国产电影| 日韩写真福利视频在线观看| 国产精品成久久久久三级蜜臀av| 在线免费91激情四射 | 91亚洲国产成人精品性色| 亚洲人人妻一区二区三区| 欧美日本国产自视大全| 国产精选一区在线播放| 啊啊好慢点插舔我逼啊啊啊视频| 人人妻人人爱人人草| 狠狠躁狠狠爱网站视频| 视频一区二区三区高清在线| 国产黄色a级三级三级三级| 在线观看的a站 最新| 青青青视频自偷自拍38碰| 久久精品久久精品亚洲人| 国产成人午夜精品福利| 丝袜美腿视频诱惑亚洲无| 91麻豆精品91久久久久同性| 久久久久只精品国产三级| 家庭女教师中文字幕在线播放| 美女福利视频网址导航| 日韩精品电影亚洲一区| 一区二区三区久久久91| 色吉吉影音天天干天天操| 日本av熟女在线视频| av中文字幕福利网| 熟女91pooyn熟女| 91试看福利一分钟| 免费无毒热热热热热热久| 伊人综合aⅴ在线网| 岛国免费大片在线观看| 黄色片年轻人在线观看| 抽查舔水白紧大视频| 久久久噜噜噜久久熟女av| 久久久久久久亚洲午夜综合福利| 色噜噜噜噜18禁止观看| 人妻少妇av在线观看| 天天操天天污天天射| av中文字幕福利网| 福利一二三在线视频观看| 岛国av高清在线成人在线| 97超碰人人搞人人| 18禁网站一区二区三区四区| 国语对白xxxx乱大交| 91破解版永久免费| 超级av免费观看一区二区三区| 99久久久无码国产精品性出奶水 | 久久机热/这里只有| 亚洲丝袜老师诱惑在线观看| 综合激情网激情五月天| 99久久成人日韩欧美精品| asmr福利视频在线观看| 五月天中文字幕内射| 大鸡八强奸视频在线观看| 日本熟妇丰满厨房55| 国产午夜亚洲精品麻豆| 香蕉av影视在线观看| 免费岛国喷水视频在线观看 | 亚洲欧美精品综合图片小说| 大香蕉福利在线观看| 99热99re在线播放| 一个色综合男人天堂| 欧美va不卡视频在线观看| 99视频精品全部15| 日韩影片一区二区三区不卡免费 | 骚货自慰被发现爆操| 黑人大几巴狂插日本少妇| 日本熟女50视频免费| 国产精品国产三级国产精东| 91亚洲国产成人精品性色| 丰满的子国产在线观看| 中国视频一区二区三区| 日韩欧美国产一区不卡| 午夜国产福利在线观看| 国产日韩av一区二区在线| 成人精品视频99第一页| 午夜久久香蕉电影网| 香蕉aⅴ一区二区三区| 粉嫩av蜜乳av蜜臀| 日本美女性生活一级片| 日本丰满熟妇BBXBBXHD| 天堂中文字幕翔田av| 韩国男女黄色在线观看| 曰本无码人妻丰满熟妇啪啪| 亚洲午夜电影在线观看| 19一区二区三区在线播放| 日本一区美女福利视频| 少妇ww搡性bbb91| av高潮迭起在线观看| 国产片免费观看在线观看| 天天日天天摸天天爱| 天天草天天色天天干| 91免费观看在线网站| gay gay男男瑟瑟在线网站| 成年人免费看在线视频| 日韩近亲视频在线观看| 国产1区,2区,3区| 欧美亚洲偷拍自拍色图| 日韩在线视频观看有码在线| 极品粉嫩小泬白浆20p主播| 姐姐的朋友2在线观看中文字幕| 喷水视频在线观看这里只有精品| 春色激情网欧美成人| 美女日逼视频免费观看| 久久丁香花五月天色婷婷| 亚洲丝袜老师诱惑在线观看| 久久久久久久久久性潮| 亚洲一级特黄特黄黄色录像片| 99精品国产自在现线观看| 亚欧在线视频你懂的| 亚洲一区二区三区在线高清| 亚洲伊人久久精品影院一美女洗澡 | 美女少妇亚洲精选av| 天天干天天操天天爽天天摸| 丝袜肉丝一区二区三区四区在线| 78色精品一区二区三区| 久久久91蜜桃精品ad| 99久久中文字幕一本人| 老司机免费福利视频网| 少妇露脸深喉口爆吞精| 少妇人妻真实精品视频| 内射久久久久综合网| 男人在床上插女人视频| 91免费观看国产免费| 精品91自产拍在线观看一区| 免费男阳茎伸入女阳道视频| 好太好爽好想要免费| 影音先锋女人av噜噜色| 99亚洲美女一区二区三区| 春色激情网欧美成人| chinese国产盗摄一区二区| 男生舔女生逼逼的视频| 中文字幕在线永久免费播放| aaa久久久久久久久| 亚洲va国产va欧美精品88| 啊啊好大好爽啊啊操我啊啊视频| 中国黄片视频一区91| 精品区一区二区三区四区人妻| av完全免费在线观看av| 99热这里只有精品中文| 免费在线观看污污视频网站| 在线免费观看欧美小视频| 日本av在线一区二区三区| 把腿张开让我插进去视频| av在线免费中文字幕| 91自产国产精品视频| 国产精品人妻66p| 91国产在线免费播放| 人人爽亚洲av人人爽av| 亚洲欧美日韩视频免费观看| 天天躁日日躁狠狠躁躁欧美av| 亚洲天堂精品久久久| 99热国产精品666| 一区二区视频视频视频| 老司机在线精品福利视频| 很黄很污很色的午夜网站在线观看| 一区二区三区视频,福利一区二区| 亚洲国产中文字幕啊啊啊不行了| 日本人妻少妇18—xx| 亚洲精品成人网久久久久久小说| 成年人黄视频在线观看| 天天日天天爽天天干| 熟女人妻在线中出观看完整版| 人人妻人人爽人人添夜| 97人妻总资源视频| 天天插天天狠天天操| 色吉吉影音天天干天天操| 亚洲av黄色在线网站| 91九色porny国产在线| 国产麻豆91在线视频| 孕妇奶水仑乱A级毛片免费看| 2020久久躁狠狠躁夜夜躁| 91www一区二区三区| 欧美日韩中文字幕欧美| 亚洲精品欧美日韩在线播放 | av网址国产在线观看| h国产小视频福利在线观看| 日韩特级黄片高清在线看| 中出中文字幕在线观看| 亚洲av色图18p| 日日操综合成人av| 亚洲欧美国产综合777| 啊用力插好舒服视频| 久久久久久性虐视频| 婷婷综合蜜桃av在线| 亚洲一级av大片免费观看| 久久久极品久久蜜桃| 亚洲欧美自拍另类图片| 久久三久久三久久三久久| 女同性ⅹxx女同h偷拍| 天天操夜夜操天天操天天操| 91老师蜜桃臀大屁股| 黑人变态深video特大巨大| 国产在线观看黄色视频| 沙月文乃人妻侵犯中文字幕在线 | 大陆胖女人与丈夫操b国语高清 | 一区二区三区视频,福利一区二区| 精品91高清在线观看 | 换爱交换乱高清大片| 天堂女人av一区二区| av成人在线观看一区| 夜夜嗨av蜜臀av| 欧洲欧美日韩国产在线| 自拍偷拍vs一区二区三区| 精彩视频99免费在线| 爱爱免费在线观看视频| 亚洲精品无码久久久久不卡 | 专门看国产熟妇的网站| 欧美偷拍亚洲一区二区| 成人乱码一区二区三区av| 中文字幕中文字幕 亚洲国产| 国产亚洲欧美45p| 福利视频网久久91| 国产精品免费不卡av| 日本一本午夜在线播放| 一色桃子久久精品亚洲| 熟女人妻在线观看视频| 久久久久久国产精品| 欧美精品免费aaaaaa| 国产精品福利小视频a| 国产精品中文av在线播放| 国产男女视频在线播放| 青青青爽视频在线播放| 日本一道二三区视频久久| 啪啪啪啪啪啪啪免费视频| 91精品国产观看免费| 成年人该看的视频黄免费| 91www一区二区三区| 一区二区三区在线视频福利| 大学生A级毛片免费视频| 亚洲1区2区3区精华液| 久久久久久久亚洲午夜综合福利| 99视频精品全部15| 直接观看免费黄网站| 免费手机黄页网址大全| 视频 国产 精品 熟女 | 2020韩国午夜女主播在线| 91p0rny九色露脸熟女| avjpm亚洲伊人久久| 人妻熟女在线一区二区| 国产精品久久久久久久久福交| 五色婷婷综合狠狠爱| 不卡一区一区三区在线| 免费黄色成人午夜在线网站| 喷水视频在线观看这里只有精品| 熟女少妇激情五十路| 亚洲精品 欧美日韩| 久久精品在线观看一区二区| 国产日韩一区二区在线看| 在线不卡日韩视频播放| 日本福利午夜电影在线观看| 五十路在线观看完整版| 少妇被强干到高潮视频在线观看| 色噜噜噜噜18禁止观看| 中文字幕高清在线免费播放 | 日韩一区二区电国产精品| 东京热男人的av天堂| 人妻另类专区欧美制服| 九色视频在线观看免费| 99的爱精品免费视频| 青青青艹视频在线观看| 欧美地区一二三专区| 99精品免费久久久久久久久a| 2020国产在线不卡视频| 免费福利av在线一区二区三区| 综合激情网激情五月五月婷婷| 欧美成人猛片aaaaaaa| 99视频精品全部15| 91人妻人人做人人爽在线| 18禁污污污app下载| 51精品视频免费在线观看| 亚洲公开视频在线观看| 真实国产乱子伦一区二区| 免费观看国产综合视频| av在线免费中文字幕| 成人国产激情自拍三区| 日本午夜福利免费视频| 男人操女人逼逼视频网站| sejizz在线视频| 日韩欧美亚洲熟女人妻| 一区二区在线视频中文字幕 | 一区二区三区精品日本| 国产三级影院在线观看| 婷婷综合亚洲爱久久| jiuse91九色视频| 熟女视频一区,二区,三区| 九色porny九色9l自拍视频| 国产激情av网站在线观看| 久草福利电影在线观看| 男人在床上插女人视频| 一区二区麻豆传媒黄片| 插逼视频双插洞国产操逼插洞| 天天射夜夜操综合网| 亚洲一区二区三区五区| 在线免费观看国产精品黄色| 国产不卡av在线免费| 男人天堂最新地址av| 97小视频人妻一区二区| 婷婷六月天中文字幕| 亚洲欧美精品综合图片小说| 只有精品亚洲视频在线观看| av一区二区三区人妻| 国产福利小视频免费观看| 888欧美视频在线| 亚洲天堂有码中文字幕视频| 大鸡巴操娇小玲珑的女孩逼| 五色婷婷综合狠狠爱| 国产精品久久久黄网站| 天堂av在线播放免费| 天堂av在线最新版在线| 欧美偷拍亚洲一区二区| 中国把吊插入阴蒂的视频| 岛国青草视频在线观看| av完全免费在线观看av| 成人久久精品一区二区三区| 无码国产精品一区二区高潮久久4 日韩欧美一级精品在线观看 | 国产av国片精品一区二区| 99精品亚洲av无码国产另类| 黄色成年网站午夜在线观看| free性日本少妇| 精品人人人妻人人玩日产欧| 一区二区三区四区视频| 一区二区三区的久久的蜜桃的视频| 国产剧情演绎系列丝袜高跟| 国产高清女主播在线| 亚洲精品高清自拍av| weyvv5国产成人精品的视频| 亚洲国产成人无码麻豆艾秋| 肏插流水妹子在线乐播下载| 日韩a级精品一区二区| 老师啊太大了啊啊啊尻视频| 97少妇精品在线观看| 五十路人妻熟女av一区二区| 国产欧美精品一区二区高清| 91精品高清一区二区三区| 3337p日本欧洲大胆色噜噜| 国产精品日韩欧美一区二区| 做爰视频毛片下载蜜桃视频1| av网址国产在线观看| 天天日天天鲁天天操| 久久丁香花五月天色婷婷| 色综合色综合色综合色| 丝袜长腿第一页在线| 欧美一级片免费在线成人观看 | 18禁无翼鸟成人在线| 亚洲女人的天堂av| 黑人变态深video特大巨大| 亚洲一区二区三区精品视频在线 | 日韩av有码一区二区三区4 | 欧美亚洲少妇福利视频| 一区二区三区日韩久久| 亚洲第一黄色在线观看| jiujiure精品视频在线| 又黄又刺激的午夜小视频| 99精品亚洲av无码国产另类| 国产janese在线播放| 亚洲av黄色在线网站| 成年人该看的视频黄免费| 日日夜夜大香蕉伊人| 亚洲高清视频在线不卡| av天堂加勒比在线| 狠狠鲁狠狠操天天晚上干干| 国产一区二区久久久裸臀| 国产麻豆91在线视频| 夜女神免费福利视频| 国产精彩福利精品视频| 男人的网址你懂的亚洲欧洲av | 国产精品污污污久久| 天堂av狠狠操蜜桃| 青青草原网站在线观看| 99精品国产aⅴ在线观看| 成人高清在线观看视频| 精品一区二区亚洲欧美| 婷婷午夜国产精品久久久| 在线不卡日韩视频播放| 成人免费毛片aaaa| 亚洲一区制服丝袜美腿 | 老熟妇xxxhd老熟女| 国产综合高清在线观看| 蜜桃视频17c在线一区二区| 国产在线91观看免费观看| 国产精品黄页网站视频| 伊人精品福利综合导航| 在线免费观看靠比视频的网站| 可以在线观看的av中文字幕| 91麻豆精品传媒国产黄色片| 亚洲精品欧美日韩在线播放| 91快播视频在线观看| 久久国产精品精品美女| 99久久成人日韩欧美精品| 久久www免费人成一看片| 人妻少妇性色欲欧美日韩 | 中文字幕在线第一页成人| 久草视频在线看免费| 成人24小时免费视频| 老鸭窝在线观看一区| 中国老熟女偷拍第一页| 欧美偷拍亚洲一区二区| 久久香蕉国产免费天天| 丝袜肉丝一区二区三区四区在线| ka0ri在线视频| 四虎永久在线精品免费区二区| 成年午夜免费无码区| 欧美日本aⅴ免费视频| 欧美黑人与人妻精品| 在线观看国产网站资源| 大骚逼91抽插出水视频| 被大鸡吧操的好舒服视频免费| 亚洲欧美国产综合777| 婷婷午夜国产精品久久久| 一区二区三区的久久的蜜桃的视频| 婷婷五月亚洲综合在线| 亚洲国产中文字幕啊啊啊不行了 | 日本欧美视频在线观看三区| avjpm亚洲伊人久久| 色天天天天射天天舔| 日韩a级黄色小视频| 亚洲青青操骚货在线视频| 偷青青国产精品青青在线观看| 97年大学生大白天操逼| 婷婷久久久久深爱网| 超碰在线观看免费在线观看| 久草视频首页在线观看| 女同互舔一区二区三区| 国产麻豆乱子伦午夜视频观看| 精品久久久久久久久久中文蒉| 一区二区三区综合视频| 久久久久久性虐视频| 免费观看国产综合视频| 中文字幕欧美日韩射射一| 任你操视频免费在线观看| 久久久制服丝袜中文字幕| 国产综合精品久久久久蜜臀| 九九视频在线精品播放| 可以免费看的www视频你懂的| 青青青青在线视频免费观看| 中国老熟女偷拍第一页| 100%美女蜜桃视频| 大鸡吧插逼逼视频免费看| 国产精品国色综合久久| 肏插流水妹子在线乐播下载| 人妻素人精油按摩中出| 国产在线自在拍91国语自产精品 | 成人午夜电影在线观看 久久| 9色精品视频在线观看| 中文字幕日韩无敌亚洲精品| 午夜久久久久久久99| wwwxxx一级黄色片| gav成人免费播放| 9色精品视频在线观看| 日日操综合成人av| 国产美女一区在线观看| 早川濑里奈av黑人番号| 欧美va不卡视频在线观看| 婷婷色国产黑丝少妇勾搭AV | 亚洲一区二区三区精品视频在线| 国产成人无码精品久久久电影| 都市激情校园春色狠狠| 好吊操视频这里只有精品| 亚洲高清国产自产av| 不戴胸罩引我诱的隔壁的人妻| 天天日天天操天天摸天天舔| 中文字幕在线观看极品视频| asmr福利视频在线观看| 亚洲激情,偷拍视频| 亚洲精品乱码久久久久久密桃明 | 爱爱免费在线观看视频| www骚国产精品视频| 亚洲精品乱码久久久本| 色av色婷婷人妻久久久精品高清| 91成人在线观看免费视频| yellow在线播放av啊啊啊| 秋霞午夜av福利经典影视| 中文字幕+中文字幕| 日本av熟女在线视频| 日韩一区二区电国产精品| 精品人妻伦一二三区久| 亚洲激情唯美亚洲激情图片| 把腿张开让我插进去视频| 青青青国产片免费观看视频| 黄色片一级美女黄色片| 亚洲成人免费看电影| 青青青青视频在线播放| 欧美另类重口味极品在线观看| 亚洲精品精品国产综合| sw137 中文字幕 在线| 国产精品一区二区av国| 亚洲国产香蕉视频在线播放| 天天操天天污天天射| 福利视频一区二区三区筱慧| 天堂资源网av中文字幕| 国产精品成人xxxx| 成人国产激情自拍三区| 欧美偷拍亚洲一区二区| 日韩av有码一区二区三区4| 日韩中文字幕精品淫| 国产美女一区在线观看| 11久久久久久久久久久| 好太好爽好想要免费| 成人av天堂丝袜在线观看| 五十路熟女人妻一区二| 少妇人妻真实精品视频| 免费在线观看视频啪啪| 狠狠躁夜夜躁人人爽天天天天97| 青娱乐极品视频青青草| 风流唐伯虎电视剧在线观看| 蜜桃久久久久久久人妻| 视频一区二区在线免费播放| 精品视频一区二区三区四区五区| 国产又粗又猛又爽又黄的视频在线| 天天摸天天亲天天舔天天操天天爽| 亚洲国产成人av在线一区| 888亚洲欧美国产va在线播放| 人人妻人人澡欧美91精品| 国产午夜亚洲精品麻豆| 日韩欧美高清免费在线| 成熟丰满熟妇高潮xx×xx| 日本少妇精品免费视频| 精品黑人一区二区三区久久国产| 成年人免费看在线视频| 午夜免费体验区在线观看| 免费看国产av网站| 色综合久久五月色婷婷综合| 骚逼被大屌狂草视频免费看| 黄色大片男人操女人逼| 亚洲最大免费在线观看| 成人精品在线观看视频| 欧美日韩中文字幕欧美| 少妇深喉口爆吞精韩国| 日韩欧美亚洲熟女人妻| 午夜成午夜成年片在线观看| 人人在线视频一区二区| 3337p日本欧洲大胆色噜噜| 久久精品国产999| 欧美精品资源在线观看| 亚洲成人情色电影在线观看 | 成熟熟女国产精品一区| 97成人免费在线观看网站| 在线观看av观看av| 成人久久精品一区二区三区| 中国黄色av一级片| 在线免费观看靠比视频的网站 | 操的小逼流水的文章| 又粗又硬又猛又爽又黄的| 久碰精品少妇中文字幕av | 99精品亚洲av无码国产另类| 鸡巴操逼一级黄色气| av中文字幕网址在线| 在线免费观看日本片| 亚洲区欧美区另类最新章节| 成人24小时免费视频| 成人18禁网站在线播放| 97超碰人人搞人人| 老司机99精品视频在线观看| 青青青青青青草国产| 国产成人无码精品久久久电影| 快插进小逼里大鸡吧视频| 国产综合高清在线观看| av高潮迭起在线观看| 国产精品伦理片一区二区| 青青草成人福利电影| 国产精品国产三级国产精东| 91九色porny蝌蚪国产成人| 亚洲福利天堂久久久久久 | 91老师蜜桃臀大屁股| 中文字幕在线视频一区二区三区 | 国产日韩欧美美利坚蜜臀懂色| 天天日天天干天天插舔舔| 大陆胖女人与丈夫操b国语高清| 91精品高清一区二区三区| 福利一二三在线视频观看| 亚洲视频乱码在线观看| 亚洲免费va在线播放| 亚洲免费视频欧洲免费视频| 亚洲一级av大片免费观看| 88成人免费av网站| 天天操天天爽天天干| 天天日天天爽天天干| 在线观看操大逼视频| 中文乱理伦片在线观看| 人妻丝袜精品中文字幕| 大鸡巴插入美女黑黑的阴毛| av在线观看网址av| 精品亚洲国产中文自在线| 日韩特级黄片高清在线看| 日本av熟女在线视频| 亚洲综合色在线免费观看| 小穴多水久久精品免费看| 蜜桃视频17c在线一区二区| 久久午夜夜伦痒痒想咳嗽P| 天天日夜夜干天天操| 97少妇精品在线观看| 天天日天天敢天天干| 国产一区成人在线观看视频| 国产大学生援交正在播放| 亚洲天堂av最新网址| 狠狠操狠狠操免费视频| 亚洲综合图片20p| 天天操夜夜操天天操天天操| 国产日韩一区二区在线看| 91九色porny蝌蚪国产成人| 含骚鸡巴玩逼逼视频| 在线观看国产网站资源| 91人妻精品久久久久久久网站 | 欧美一级视频一区二区| av乱码一区二区三区| 亚洲视频在线观看高清| 欧美一区二区三区在线资源| 社区自拍揄拍尻屁你懂的| 99久久99一区二区三区| 五月天色婷婷在线观看视频免费| 在线观看视频网站麻豆| 快点插进来操我逼啊视频| 一区二区久久成人网| 亚洲av日韩av第一区二区三区| 黄色片黄色片wyaa| 免费观看国产综合视频| 午夜蜜桃一区二区三区| 免费岛国喷水视频在线观看| 欧美黑人巨大性xxxxx猛交| 欧美亚洲一二三区蜜臀| 真实国模和老外性视频| 人人爱人人妻人人澡39| 免费在线福利小视频| 青青草亚洲国产精品视频| 黄工厂精品视频在线观看| 美洲精品一二三产区区别| 人人爽亚洲av人人爽av| 日韩视频一区二区免费观看| 国产一线二线三线的区别在哪| 国产久久久精品毛片| 爆乳骚货内射骚货内射在线| 青青草成人福利电影| 3D动漫精品啪啪一区二区下载| 美女张开两腿让男人桶av| 性欧美激情久久久久久久| 大胸性感美女羞爽操逼毛片| 又粗又长 明星操逼小视频| 亚洲一级av无码一级久久精品| 换爱交换乱高清大片| 国产视频网站一区二区三区| 在线免费91激情四射| 中文字幕视频一区二区在线观看| 久久久久只精品国产三级| 午夜婷婷在线观看视频| 欧美精产国品一二三区| 国产又粗又硬又大视频| 日韩近亲视频在线观看| 精产国品久久一二三产区区别| 天天干天天操天天玩天天射| 亚洲1区2区3区精华液| 99视频精品全部15| 北条麻妃高跟丝袜啪啪| 五月天中文字幕内射| 熟女少妇激情五十路| 亚洲国产欧美一区二区丝袜黑人| 成人在线欧美日韩国产| 国产老熟女伦老熟妇ⅹ| 一区二区三区日本伦理| 国产精品自拍在线视频| 中文字幕第三十八页久久| 天干天天天色天天日天天射| 国产成人一区二区三区电影网站 | 91精品国产91青青碰| 美女视频福利免费看| 丝袜肉丝一区二区三区四区在线看| av破解版在线观看| av网址在线播放大全| 91片黄在线观看喷潮| 国产在线免费观看成人| 国产精品国产三级麻豆| 国产亚洲国产av网站在线| 亚洲欧洲一区二区在线观看| av新中文天堂在线网址| 亚洲1区2区3区精华液| 日本黄色特一级视频| 国产精品黄色的av| 天天日天天干天天插舔舔| 日本一二三中文字幕| 天天射夜夜操狠狠干| 亚洲推理片免费看网站| 欧洲日韩亚洲一区二区三区| 宅男噜噜噜666免费观看| 亚洲精品国产在线电影| 无忧传媒在线观看视频| 国产高清97在线观看视频| 久久这里只有精彩视频免费| 丝袜国产专区在线观看| 中文字幕免费福利视频6| 亚洲中文字幕乱码区| 欧美亚洲少妇福利视频| 亚洲午夜福利中文乱码字幕| 18禁网站一区二区三区四区| 亚洲一区二区久久久人妻| 99热国产精品666| 午夜大尺度无码福利视频 | 中文字幕日韩91人妻在线| 国产一级精品综合av| 亚洲av成人网在线观看| 一个色综合男人天堂| 天天色天天操天天透| 久草视频在线看免费| 夜女神免费福利视频| 很黄很污很色的午夜网站在线观看| 99热久久这里只有精品8| 激情啪啪啪啪一区二区三区| 国产伊人免费在线播放| 亚洲av成人网在线观看| 91www一区二区三区| 五月精品丁香久久久久福利社| 99亚洲美女一区二区三区| 天天操夜夜骑日日摸| 高清一区二区欧美系列| 一区二区三区日韩久久| 97人人模人人爽人人喊| 老司机99精品视频在线观看 | 国产精品伦理片一区二区| 在线观看亚洲人成免费网址| 成人乱码一区二区三区av| 精品一区二区三四区| 成人动漫大肉棒插进去视频| 国产视频网站一区二区三区| 精品黑人一区二区三区久久国产| 久久精品亚洲成在人线a| 中文字幕一区二区人妻电影冢本| 丝袜美腿视频诱惑亚洲无| 国产视频精品资源网站| 一区二区三区视频,福利一区二区 丰满的子国产在线观看 | 天天操天天干天天插| 最新91九色国产在线观看| 亚洲综合一区成人在线| 国产黑丝高跟鞋视频在线播放| 欧美中文字幕一区最新网址| 一个色综合男人天堂| 成人蜜桃美臀九一一区二区三区| 精品一区二区亚洲欧美| 亚洲成人熟妇一区二区三区 | 100%美女蜜桃视频| 免费在线福利小视频| 黄色资源视频网站日韩| 99热99re在线播放| 国产91精品拍在线观看| 欧美成人黄片一区二区三区| 国产午夜亚洲精品不卡在线观看| 青草亚洲视频在线观看| 91欧美在线免费观看| 亚洲日本一区二区久久久精品| 在线观看的黄色免费网站| av资源中文字幕在线观看| 午夜免费观看精品视频| 日本男女操逼视频免费看| 中文字幕免费福利视频6| 国产黑丝高跟鞋视频在线播放| 香港一级特黄大片在线播放| 色97视频在线播放| 国产精品亚洲а∨天堂免| 久久久精品999精品日本| 国产精品入口麻豆啊啊啊| 狠狠嗨日韩综合久久| 人妻熟女在线一区二区| 2020久久躁狠狠躁夜夜躁| 久久www免费人成一看片| 2019av在线视频| 91色老99久久九九爱精品| 久草福利电影在线观看| 一区二区三区综合视频| 熟女人妻一区二区精品视频| 日本真人性生活视频免费看| 成人国产影院在线观看| 亚洲天天干 夜夜操| 一区二区在线观看少妇| 日本熟女50视频免费| 亚洲欧美清纯唯美另类 | 精品av国产一区二区三区四区| 手机看片福利盒子日韩在线播放| 91精品国产91久久自产久强| 亚洲成人熟妇一区二区三区| 97年大学生大白天操逼| 天堂va蜜桃一区入口| 亚洲一区自拍高清免费视频| 亚洲天堂有码中文字幕视频| 少妇系列一区二区三区视频| 国产精品三级三级三级| 毛片av在线免费看| 超污视频在线观看污污污| 91成人精品亚洲国产| 成人福利视频免费在线| 精品国产成人亚洲午夜| 干逼又爽又黄又免费的视频| av中文字幕在线观看第三页| 成人影片高清在线观看| 欧美国产亚洲中英文字幕| 无码日韩人妻精品久久| 天天做天天干天天操天天射| 55夜色66夜色国产精品站| 国产精品自偷自拍啪啪啪| 1769国产精品视频免费观看| 亚洲一级av无码一级久久精品| 久久久久久性虐视频| 欧美一级色视频美日韩| 精品久久久久久久久久久99| 98视频精品在线观看| 福利一二三在线视频观看| 亚洲一区二区三区偷拍女厕91| 91精品国产综合久久久蜜| 国产老熟女伦老熟妇ⅹ| 五十路熟女人妻一区二| 99re久久这里都是精品视频| 日本三极片视频网站观看| 黄片三级三级三级在线观看| 天天日天天天天天天天天天天| 最新91九色国产在线观看| 一区二区熟女人妻视频| 男人在床上插女人视频| 在线观看欧美黄片一区二区三区| 国产普通话插插视频| 成人av在线资源网站| 国产亚洲四十路五十路| 91国产在线视频免费观看| 欧美日韩不卡一区不区二区| 天天色天天操天天舔| 少妇与子乱在线观看| 在线观看国产免费麻豆| 日韩少妇人妻精品无码专区| 日韩写真福利视频在线观看| 欧美激情精品在线观看| 日本性感美女视频网站| 青青草人人妻人人妻| 中文字幕一区二 区二三区四区| 青青尤物在线观看视频网站| 天天日天天添天天爽| 国产精品国产三级国产午| 国产1区,2区,3区| 欧美日本国产自视大全| yy6080国产在线视频| 亚洲国际青青操综合网站| 日本一区二区三区免费小视频| 偷拍自拍视频图片免费| 新97超碰在线观看| 91一区精品在线观看| 欧美3p在线观看一区二区三区| 国产97视频在线精品| 黑人进入丰满少妇视频| 日本后入视频在线观看| 中文字幕,亚洲人妻| 亚洲精品高清自拍av | 久草视频在线免播放| 色综合天天综合网国产成人| 黄工厂精品视频在线观看| 日本18禁久久久久久| 国产熟妇一区二区三区av| 成人资源在线观看免费官网| 亚洲av色图18p| 最新日韩av传媒在线| 99精品视频之69精品视频| 中文字幕第三十八页久久| 国产午夜亚洲精品不卡在线观看| 国产精品国产精品一区二区| 欧美日韩在线精品一区二区三| av手机免费在线观看高潮| 在线观看免费岛国av| 免费在线看的黄网站| 亚洲国产40页第21页| 2021天天色天天干| 国产精品亚洲а∨天堂免| 激情色图一区二区三区| 岛国黄色大片在线观看| 黄色无码鸡吧操逼视频| 欧美日本在线观看一区二区| 国产午夜亚洲精品麻豆| 青青青青青青草国产| 5528327男人天堂| 好吊操视频这里只有精品| 91国产资源在线视频| 97年大学生大白天操逼| 国产一级麻豆精品免费| 97黄网站在线观看| 欧美精品一区二区三区xxxx| 日韩美女综合中文字幕pp| 午夜婷婷在线观看视频| 欧美亚洲国产成人免费在线| 中文字幕综合一区二区| 国产免费av一区二区凹凸四季| 日韩欧美一级精品在线观看| 日韩一区二区电国产精品| 宅男噜噜噜666免费观看| 鸡巴操逼一级黄色气| 久草视频在线免播放| av完全免费在线观看av| 午夜在线观看岛国av,com| 天码人妻一区二区三区在线看| 日本av高清免费网站| 亚洲国产精品黑丝美女| 少妇人妻100系列| 亚洲国产美女一区二区三区软件 | 999久久久久999| 日噜噜噜夜夜噜噜噜天天噜噜噜 | 视频一区二区综合精品| 免费大片在线观看视频网站| 2020av天堂网在线观看| free性日本少妇| xxx日本hd高清| 日韩国产乱码中文字幕| 午夜精品亚洲精品五月色| 视频久久久久久久人妻| 欧美日韩精品永久免费网址| 精品亚洲国产中文自在线| 欧美中国日韩久久精品| 在线观看视频一区麻豆| 亚洲精品成人网久久久久久小说| 97人妻色免费视频| 天天摸天天干天天操科普| 97黄网站在线观看| 国产亚洲视频在线观看| 国产亚洲欧美视频网站| 亚洲 中文 自拍 另类 欧美| 在线观看av观看av| 88成人免费av网站| 日韩欧美一级精品在线观看| 欧美精品资源在线观看| 日韩近亲视频在线观看| 中文字幕日韩精品日本| 国产精品久久久久久久精品视频| 久草免费人妻视频在线| 成人国产影院在线观看| 可以在线观看的av中文字幕| 日本少妇的秘密免费视频| 欧美激情电影免费在线| 很黄很污很色的午夜网站在线观看| 亚洲综合色在线免费观看| 2020中文字幕在线播放| 馒头大胆亚洲一区二区| 国产综合精品久久久久蜜臀| 日韩av有码中文字幕| 中文字幕在线永久免费播放| 午夜免费观看精品视频| 天天日天天玩天天摸| 免费在线看的黄网站| 香港一级特黄大片在线播放| 亚洲伊人久久精品影院一美女洗澡| 亚洲人一区二区中文字幕| 馒头大胆亚洲一区二区| 亚洲美女高潮喷浆视频| 经典av尤物一区二区| 欧美80老妇人性视频| 啪啪啪啪啪啪啪啪av| 91在线视频在线精品3| 老司机福利精品视频在线| av天堂中文免费在线| 91国内精品自线在拍白富美| 亚洲另类在线免费观看| 国产亚洲精品欧洲在线观看| 2018最新中文字幕在线观看| 社区自拍揄拍尻屁你懂的| 天天日天天操天天摸天天舔| 最新欧美一二三视频| 熟女人妻三十路四十路人妻斩| 久精品人妻一区二区三区| asmr福利视频在线观看| 这里只有精品双飞在线播放| av男人天堂狠狠干| 青青在线视频性感少妇和隔壁黑丝 | 五月婷婷在线观看视频免费| 顶级尤物粉嫩小尤物网站| 欧美国产亚洲中英文字幕| 国产之丝袜脚在线一区二区三区| 视频在线免费观看你懂得| 蜜桃视频在线欧美一区| 中文字幕一区二区人妻电影冢本| 日视频免费在线观看| 天天日天天干天天爱| 伊人精品福利综合导航| 欧美精品免费aaaaaa| 性感美女高潮视频久久久| 国产品国产三级国产普通话三级| 美女福利视频网址导航| 淫秽激情视频免费观看| 视频 一区二区在线观看| 精品亚洲中文字幕av| 好了av中文字幕在线| 亚洲伊人久久精品影院一美女洗澡| 在线免费91激情四射 | 精品久久婷婷免费视频| 国产高清精品一区二区三区| 亚洲免费av在线视频| 一区二区三区欧美日韩高清播放| 这里只有精品双飞在线播放| 欧美性受xx黑人性猛交| 亚洲成人免费看电影| 最新国产精品网址在线观看| 亚洲av男人天堂久久| 中文字幕1卡1区2区3区| 亚洲综合在线视频可播放| 2021年国产精品自拍| 亚洲 欧美 精品 激情 偷拍 | 午夜极品美女福利视频| 2017亚洲男人天堂| 亚洲成人激情av在线| 91精品啪在线免费| 日韩欧美在线观看不卡一区二区 | 日韩人妻丝袜中文字幕| ka0ri在线视频| 人妻凌辱欧美丰满熟妇| 久久尻中国美女视频| 一二三区在线观看视频| 国产又色又刺激在线视频| 国产女人露脸高潮对白视频| 少妇人妻久久久久视频黄片| 噜噜色噜噜噜久色超碰| 在线观看av亚洲情色| 日本最新一二三区不卡在线 | 国产熟妇一区二区三区av| av中文字幕在线观看第三页| 天堂av在线播放免费| 久久综合老鸭窝色综合久久| 在线视频国产欧美日韩| 亚洲狠狠婷婷综合久久app| 91快播视频在线观看| 欧美成人精品欧美一级黄色| 黄色黄色黄片78在线| www,久久久,com| 毛茸茸的大外阴中国视频| 午夜蜜桃一区二区三区| 亚洲国产在线精品国偷产拍 | 精品亚洲中文字幕av| 天天操夜夜操天天操天天操| 精品高潮呻吟久久av| 成人综合亚洲欧美一区| 免费观看丰满少妇做受| 国产高清在线在线视频| 亚洲特黄aaaa片| av亚洲中文天堂字幕网| 日日爽天天干夜夜操| 日韩黄色片在线观看网站| 国产老熟女伦老熟妇ⅹ| 蜜臀av久久久久久久| 78色精品一区二区三区| 黄片大全在线观看观看| 国产高清精品极品美女| 国产伊人免费在线播放| 亚洲天天干 夜夜操| 国产美女一区在线观看| jul—619中文字幕在线| 亚洲欧美一区二区三区电影| 天天操天天干天天日狠狠插| 日视频免费在线观看| 日韩在线视频观看有码在线| 亚洲美女高潮喷浆视频| 97人妻总资源视频| 免费在线看的黄片视频| 欧美成人综合视频一区二区| 女蜜桃臀紧身瑜伽裤| 天天干天天插天天谢| 青青青国产免费视频| 五十路息与子猛烈交尾视频| okirakuhuhu在线观看| 欧美中文字幕一区最新网址| 57pao国产一区二区| 丰满的子国产在线观看| 哥哥姐姐综合激情小说| 91老师蜜桃臀大屁股| 一区二区麻豆传媒黄片| 国产在线免费观看成人| 国产男女视频在线播放| 国产91嫩草久久成人在线视频| 97超碰最新免费在线观看| 四川五十路熟女av| 91麻豆精品秘密入口在线观看| 极品粉嫩小泬白浆20p主播| 亚洲美女高潮喷浆视频| 啪啪啪啪啪啪啪免费视频| 亚洲成人午夜电影在线观看| 99精品国产自在现线观看| 国产精品久久久久久久女人18| 国产自拍在线观看成人| 99国产精品窥熟女精品| 2018最新中文字幕在线观看| 真实国产乱子伦一区二区| 国产精品入口麻豆啊啊啊| 日本中文字幕一二区视频| 国产第一美女一区二区三区四区 | 欧美激情电影免费在线| 亚洲欧美色一区二区| 天堂av中文在线最新版| 国产一区二区神马久久| 天天日天天添天天爽| 人妻少妇av在线观看| 精品suv一区二区69| 欧美viboss性丰满| 亚洲精品 日韩电影| 大香蕉伊人国产在线| 伊人网中文字幕在线视频| 国产精彩福利精品视频| 瑟瑟视频在线观看免费视频| 一区二区三区 自拍偷拍| 日韩美女福利视频网| 在线免费观看日本伦理| 亚洲一区自拍高清免费视频| 亚洲一区二区三区偷拍女厕91| 喷水视频在线观看这里只有精品| 99精品国产自在现线观看| 国产亚州色婷婷久久99精品| 精品国产高潮中文字幕| 国产三级精品三级在线不卡| 特大黑人巨大xxxx| 特黄老太婆aa毛毛片| 天天干夜夜操天天舔| 1区2区3区不卡视频| 中出中文字幕在线观看| 久草视频中文字幕在线观看| 一区二区视频视频视频| 亚洲精品 日韩电影| 亚洲免费福利一区二区三区| 亚洲专区激情在线观看视频| 成人蜜臀午夜久久一区| 亚洲欧美国产麻豆综合| 黄工厂精品视频在线观看 | 亚洲欧美国产综合777| 中文字幕综合一区二区| 久久久制服丝袜中文字幕| 午夜极品美女福利视频| 天天日天天干天天干天天日| 国产+亚洲+欧美+另类| 日本黄在免费看视频| 粉嫩欧美美人妻小视频| 免费观看国产综合视频| 91亚洲手机在线视频播放| 亚洲人人妻一区二区三区| 性色蜜臀av一区二区三区| 亚洲高清国产自产av| 日韩人妻xxxxx| 国产精品人妻熟女毛片av久| 老司机在线精品福利视频| 99精品国产自在现线观看| 人人爽亚洲av人人爽av| 欧美在线精品一区二区三区视频 | 日视频免费在线观看| 久久热久久视频在线观看| 亚洲精品 欧美日韩| 在线观看av观看av| 中文字幕人妻av在线观看| 免费高清自慰一区二区三区网站 | 亚洲超碰97人人做人人爱| 亚洲国产精品黑丝美女| 日日爽天天干夜夜操| 中文字幕人妻一区二区视频 | 蜜桃视频入口久久久| 亚洲午夜电影之麻豆| 亚洲Av无码国产综合色区| 国产精品视频资源在线播放| 欧美日韩激情啪啪啪| 男人的天堂av日韩亚洲| 欧美一级色视频美日韩| 新97超碰在线观看| 美女av色播在线播放| 日韩欧美一级aa大片| 欧美xxx成人在线| 首之国产AV医生和护士小芳| 超碰中文字幕免费观看| 福利一二三在线视频观看| 国产成人精品福利短视频| 男人天堂av天天操| 人人爽亚洲av人人爽av| 亚洲免费福利一区二区三区| 桃色视频在线观看一区二区| 免费观看理论片完整版| 欧美女同性恋免费a| 成人精品视频99第一页| 东京热男人的av天堂| 国产在线一区二区三区麻酥酥 | 大香蕉大香蕉大香蕉大香蕉大香蕉| 亚洲欧美激情人妻偷拍| 亚洲蜜臀av一区二区三区九色| 性感美女诱惑福利视频| 国产精品国色综合久久| 肏插流水妹子在线乐播下载| 日日操夜夜撸天天干| 久久久久久久久久久久久97| 大香蕉伊人中文字幕| 日日夜夜狠狠干视频| 国产在线一区二区三区麻酥酥| 五十路av熟女松本翔子| AV无码一区二区三区不卡| 亚洲国产欧美国产综合在线| 亚洲一区二区三区uij| 久久h视频在线观看| 日本熟女50视频免费| 欧美一区二区中文字幕电影| 亚洲最大免费在线观看| 久久精品亚洲成在人线a| 精品一区二区三区午夜| 中文字幕人妻被公上司喝醉在线| 国产久久久精品毛片| 欧美日韩情色在线观看| 中文字幕乱码av资源| 成人av天堂丝袜在线观看| 国产精品久久久久网| 欧美麻豆av在线播放| 亚洲中文字幕国产日韩| 大鸡吧插入女阴道黄色片| 日本女大学生的黄色小视频| 亚洲综合一区成人在线| 天天射,天天操,天天说| 另类av十亚洲av| 精品av国产一区二区三区四区 | 韩国爱爱视频中文字幕| 97精品视频在线观看| 1000小视频在线| 黄色片黄色片wyaa| 丰满少妇人妻xxxxx| 亚洲精品午夜aaa久久| 日本福利午夜电影在线观看| 免费成人va在线观看| 在线免费观看黄页视频| 日本韩国免费一区二区三区视频| 93人妻人人揉人人澡人人| 女同性ⅹxx女同hd| 国产不卡av在线免费| 日本黄色三级高清视频| 中英文字幕av一区| 青青草人人妻人人妻| 欧美成人小视频在线免费看| 亚洲变态另类色图天堂网| 最新激情中文字幕视频| 美日韩在线视频免费看| 欧美黑人与人妻精品| 2018在线福利视频| 亚洲av日韩高清hd| 18禁精品网站久久| 中文字幕高清资源站| 国产精品久久久久久久久福交| 亚洲av无码成人精品区辽| 日本美女成人在线视频| 好吊操视频这里只有精品| huangse网站在线观看| 精品久久久久久久久久久99| 动漫美女的小穴视频| 精品黑人巨大在线一区| 99热碰碰热精品a中文| free性日本少妇| 91精品国产综合久久久蜜| 国产一区自拍黄视频免费观看| 97精品综合久久在线| 欧美男人大鸡吧插女人视频| 日韩av中文在线免费观看| 中文字幕日本人妻中出| 在线不卡成人黄色精品| 熟女少妇激情五十路| okirakuhuhu在线观看| 欧美精品黑人性xxxx| 1000部国产精品成人观看视频| 人妻久久无码中文成人| 传媒在线播放国产精品一区| aiss午夜免费视频| 区一区二区三国产中文字幕| 国产中文精品在线观看| 色天天天天射天天舔| 91大屁股国产一区二区| aaa久久久久久久久| 男生用鸡操女生视频动漫| av中文字幕电影在线看| 午夜在线观看岛国av,com| 男生舔女生逼逼的视频| 18禁网站一区二区三区四区| 在线观看操大逼视频| 亚洲综合在线视频可播放| 国产黄色a级三级三级三级| 国产亚洲国产av网站在线| 精品美女久久久久久| 制服丝袜在线人妻中文字幕| 中文字幕人妻一区二区视频| 一区二区三区四区五区性感视频| 三级黄色亚洲成人av| 天天摸天天亲天天舔天天操天天爽| 亚洲av成人网在线观看| 97人人模人人爽人人喊| 91大屁股国产一区二区| 在线网站你懂得老司机| av中文字幕国产在线观看| 成人动漫大肉棒插进去视频| 欧美伊人久久大香线蕉综合| 国产chinesehd精品麻豆| 新97超碰在线观看| 超碰97人人澡人人| 人妻少妇亚洲一区二区| 97精品人妻一区二区三区精品| 2017亚洲男人天堂| 国产成人自拍视频播放| 欧美香蕉人妻精品一区二区| 亚洲av日韩av网站| 亚洲人妻视频在线网| 亚洲国产在人线放午夜| 日比视频老公慢点好舒服啊| 2022国产精品视频| 一个色综合男人天堂| 中文字幕亚洲中文字幕| 亚洲av人人澡人人爽人人爱| 国产又粗又黄又硬又爽| 自拍偷拍 国产资源| 国产又粗又硬又大视频| 欧美视频不卡一区四区| 淫秽激情视频免费观看| 青青草精品在线视频观看| 一区二区熟女人妻视频| okirakuhuhu在线观看| 五十路熟女人妻一区二| 中文字幕视频一区二区在线观看| 亚洲国产免费av一区二区三区| 久久热这里这里只有精品| 在线视频自拍第三页| 爆乳骚货内射骚货内射在线| 色偷偷伊人大杳蕉综合网| 91色秘乱一区二区三区| 亚洲精品亚洲人成在线导航 | 9色在线视频免费观看| 欧亚乱色一区二区三区| av大全在线播放免费| 天堂女人av一区二区| 欧美va不卡视频在线观看| xxx日本hd高清| 中文字幕在线视频一区二区三区 | 日本高清成人一区二区三区| 中文字幕AV在线免费看 | 国产三级片久久久久久久| 亚洲1069综合男同| 日韩美女精品视频在线观看网站| 任你操任你干精品在线视频 | 国产女人露脸高潮对白视频| 青青青视频自偷自拍38碰| 五十路息与子猛烈交尾视频| 美女福利写真在线观看视频| 国产极品美女久久久久久| 国产精品黄大片在线播放| 天堂va蜜桃一区入口| 99久久激情婷婷综合五月天| 亚洲精品午夜久久久久| 日韩欧美一级aa大片| 阿v天堂2014 一区亚洲| 成年人的在线免费视频| 99re国产在线精品| 搡老熟女一区二区在线观看| 自拍偷拍亚洲欧美在线视频| 黄片色呦呦视频免费看| 精品亚洲国产中文自在线| 午夜精品九一唐人麻豆嫩草成人| 亚洲精品亚洲人成在线导航| 国产精品免费不卡av| 18禁美女羞羞免费网站| 国产揄拍高清国内精品对白| 99国内小视频在现欢看| 在线 中文字幕 一区| 精品视频国产在线观看| 天天操天天干天天艹| 中文字幕在线乱码一区二区| 日比视频老公慢点好舒服啊| 久久久麻豆精亚洲av麻花| 亚洲日本一区二区三区| 亚洲av香蕉一区区二区三区犇| av中文字幕国产在线观看| 91福利视频免费在线观看| 韩国AV无码不卡在线播放 | 国产视频在线视频播放| 五月天中文字幕内射| 国产夫妻视频在线观看免费| 2020久久躁狠狠躁夜夜躁| 亚洲欧美一区二区三区爱爱动图| 人人爱人人妻人人澡39| 91国产资源在线视频| 9l人妻人人爽人人爽| 国产高清在线在线视频| 91啪国自产中文字幕在线| 沈阳熟妇28厘米大战黑人| 80电影天堂网官网| 亚洲欧美久久久久久久久| 国产白嫩美女一区二区| 成人高潮aa毛片免费| 国产成人精品av网站| 国产激情av网站在线观看| 青青青青视频在线播放| 国产高清在线观看1区2区| 婷婷综合亚洲爱久久| 91老熟女连续高潮对白| 亚洲欧美在线视频第一页| 直接观看免费黄网站| 含骚鸡巴玩逼逼视频| 人人人妻人人澡人人| 亚洲天堂成人在线观看视频网站| 可以免费看的www视频你懂的| 国产精彩对白一区二区三区 | 精品亚洲国产中文自在线| 亚洲精品久久综合久| 欧美精产国品一二三产品价格 | 自拍偷拍,中文字幕| 日韩欧美在线观看不卡一区二区 | 亚洲蜜臀av一区二区三区九色 | 中文字幕中文字幕 亚洲国产| 亚洲综合在线观看免费| av中文字幕福利网| 国产亚洲视频在线二区| 成人动漫大肉棒插进去视频| 亚洲日本一区二区久久久精品| 中文字幕一区二 区二三区四区 | 国产精品视频一区在线播放| 日本熟女精品一区二区三区| 日本阿v视频在线免费观看| av中文字幕福利网| 大鸡巴插入美女黑黑的阴毛| 国产麻豆剧果冻传媒app| 大陆av手机在线观看| 激情综合治理六月婷婷| 亚洲国产精品久久久久蜜桃| weyvv5国产成人精品的视频| 国产成人午夜精品福利| 91she九色精品国产| 欧美黑人巨大性xxxxx猛交| 久久久久久久一区二区三| 欧美日韩在线精品一区二区三| 亚洲免费成人a v| 最近中文字幕国产在线| 91综合久久亚洲综合| 国产女人被做到高潮免费视频| 黑人解禁人妻叶爱071| heyzo蜜桃熟女人妻| 国产欧美日韩在线观看不卡| 亚洲护士一区二区三区| 日韩无码国产精品强奸乱伦| 91精品啪在线免费| 日韩精品中文字幕在线| 视频 一区二区在线观看| 日本福利午夜电影在线观看| 中出中文字幕在线观看| av一区二区三区人妻| 中文亚洲欧美日韩无线码| 一区二区三区久久中文字幕| av老司机精品在线观看| 欧美地区一二三专区| 最新中文字幕乱码在线| xxx日本hd高清| 欧美精品免费aaaaaa| 亚洲高清国产自产av| 一级黄片大鸡巴插入美女| 亚洲 中文字幕在线 日韩| 成人蜜臀午夜久久一区| 黄色大片免费观看网站| 绝色少妇高潮3在线观看| 九一传媒制片厂视频在线免费观看 | 日美女屁股黄邑视频| 日韩美女搞黄视频免费| 亚洲精品三级av在线免费观看| 男人天堂色男人av| 天天干天天搞天天摸| 欧美国产亚洲中英文字幕| 中文字幕人妻被公上司喝醉在线| 91破解版永久免费| 国产夫妻视频在线观看免费| 97精品视频在线观看| 少妇高潮无套内谢麻豆| 女警官打开双腿沦为性奴| 人妻激情图片视频小说| 人人妻人人爱人人草| 国产熟妇一区二区三区av| 中文字幕在线永久免费播放| japanese五十路熟女熟妇| 亚洲综合色在线免费观看| 伊人综合aⅴ在线网| 一级A一级a爰片免费免会员 | 青青草视频手机免费在线观看| 欧美国产亚洲中英文字幕| 人人妻人人爱人人草| 日韩不卡中文在线视频网站| 中文字幕欧美日韩射射一| 六月婷婷激情一区二区三区| 亚洲美女高潮喷浆视频| 欧美精品资源在线观看| 男人的天堂av日韩亚洲| 啪啪啪啪啪啪啪啪啪啪黄色| 人人妻人人人操人人人爽| 天天干夜夜操啊啊啊| 久久久久只精品国产三级| 91免费放福利在线观看| 青青青青青青青在线播放视频| 91麻豆精品传媒国产黄色片| 2022天天干天天操| 日韩欧美一级黄片亚洲| 少妇人妻久久久久视频黄片| 青青草成人福利电影| 成年人午夜黄片视频资源| 成人av天堂丝袜在线观看 | 成人av免费不卡在线观看| 国产欧美精品一区二区高清| 欧美一区二区中文字幕电影| 国产丰满熟女成人视频| 成年午夜免费无码区| 日本女大学生的黄色小视频| 亚洲精品无码色午夜福利理论片| 国产精品入口麻豆啊啊啊| 欧美精品伦理三区四区| 中文字幕第1页av一天堂网| 99国内小视频在现欢看| 激情色图一区二区三区| 天天插天天色天天日| 2020国产在线不卡视频 | 超碰中文字幕免费观看| 红杏久久av人妻一区| 视频一区 视频二区 视频| 欧美熟妇一区二区三区仙踪林| 自拍偷拍日韩欧美一区二区| 国产欧美日韩第三页| 99久久超碰人妻国产| 国产成人综合一区2区| 日本少妇精品免费视频| 久草电影免费在线观看| 99精品一区二区三区的区| 97香蕉碰碰人妻国产樱花| 欧美日韩不卡一区不区二区| 国产三级片久久久久久久 | 非洲黑人一级特黄片| 国产午夜亚洲精品麻豆| 国产九色91在线视频| 亚洲中文字字幕乱码| 在线免费视频 自拍| 国产中文精品在线观看| 久久久久久久亚洲午夜综合福利| 国产精品黄片免费在线观看| 国产精品久久久久久久久福交| 在线播放国产黄色av| 色噜噜噜噜18禁止观看| 精品成人啪啪18免费蜜臀| 国产高清在线在线视频| 久久艹在线观看视频| 男人插女人视频网站| 91在线免费观看成人| 国产又粗又猛又爽又黄的视频美国| 92福利视频午夜1000看| 国产福利小视频免费观看| 欧美日韩国产一区二区三区三州| 岛国毛片视频免费在线观看| 日韩亚洲高清在线观看| 美女骚逼日出水来了| 亚洲的电影一区二区三区| 福利视频一区二区三区筱慧| 97精品视频在线观看| av在线shipin| 亚洲区欧美区另类最新章节| 亚洲高清国产拍青青草原| 国产精品中文av在线播放| 无码国产精品一区二区高潮久久4| 97人妻色免费视频| 亚洲综合一区成人在线| 91精品国产91青青碰| 91精品一区二区三区站长推荐| 国产精彩福利精品视频| 粉嫩小穴流水视频在线观看| 色婷婷综合激情五月免费观看| 亚洲成人av一区久久| 成人综合亚洲欧美一区| nagger可以指黑人吗| 国产高清精品一区二区三区| 国产一区二区神马久久| jiuse91九色视频| 动漫黑丝美女的鸡巴| 香蕉片在线观看av| 日本成人不卡一区二区| 成人激情文学网人妻| 亚洲乱码中文字幕在线| 97精品视频在线观看| 一区二区三区四区视频在线播放| 97国产精品97久久| 亚洲综合乱码一区二区| 在线网站你懂得老司机| 久久久久91精品推荐99| 欧美在线一二三视频| 欧美专区日韩专区国产专区| 亚洲粉嫩av一区二区三区| 亚洲欧美久久久久久久久| 欧美少妇性一区二区三区| 黄工厂精品视频在线观看| 国产女人叫床高潮大片视频| 午夜久久久久久久99| 午夜精品一区二区三区更新| 黑人借宿ntr人妻的沦陷2| 中文字幕免费在线免费| 国产免费av一区二区凹凸四季| 久久机热/这里只有| 中文字幕AV在线免费看 | 久久久精品精品视频视频| 大尺度激情四射网站| av中文字幕国产在线观看| 又色又爽又黄又刺激av网站| 日噜噜噜夜夜噜噜噜天天噜噜噜| 欧美黑人性暴力猛交喷水| 91亚洲国产成人精品性色| 久久精品国产999| 免费观看国产综合视频| 色噜噜噜噜18禁止观看| 55夜色66夜色国产精品站| 久久尻中国美女视频| 91天堂精品一区二区| 无码精品一区二区三区人| 久久久超爽一二三av| 欧美亚洲一二三区蜜臀| 狠狠的往里顶撞h百合| 特一级特级黄色网片| 亚洲伊人久久精品影院一美女洗澡 | 国产亚洲国产av网站在线| 东游记中文字幕版哪里可以看到 | 久精品人妻一区二区三区| 超碰在线观看免费在线观看| 久久精品美女免费视频| 亚洲成人国产综合一区| 婷婷综合蜜桃av在线| 人妻最新视频在线免费观看| 免费岛国喷水视频在线观看| 93人妻人人揉人人澡人人| 伊人成人在线综合网| 国产一区二区在线欧美| 岛国免费大片在线观看| 天天做天天干天天舔| 日韩人妻丝袜中文字幕| 国产精品伦理片一区二区| 欧美偷拍自拍色图片| 久久麻豆亚洲精品av| 中文字幕熟女人妻久久久| 老有所依在线观看完整版| 一区二区三区久久中文字幕| 老司机福利精品免费视频一区二区| 国产av福利网址大全| 青青青视频自偷自拍38碰| 久久综合老鸭窝色综合久久| 偷拍自拍国产在线视频| 2017亚洲男人天堂| 黑人借宿ntr人妻的沦陷2| 天天日天天日天天射天天干| 国产亚州色婷婷久久99精品| 亚洲成人三级在线播放| 中国黄色av一级片| 偷青青国产精品青青在线观看| 亚洲中文字幕综合小综合| 国产又色又刺激在线视频| 国产性色生活片毛片春晓精品| 一级A一级a爰片免费免会员| 日韩av免费观看一区| 人人爱人人妻人人澡39| 日本性感美女写真视频| 国产麻豆91在线视频| 久久久人妻一区二区| 天天摸天天亲天天舔天天操天天爽 | 2020av天堂网在线观看| 熟女少妇激情五十路| 久久麻豆亚洲精品av| av资源中文字幕在线观看| 最新91精品视频在线| 男人插女人视频网站| 国产精品三级三级三级| 精品一区二区三区午夜| 不卡日韩av在线观看| 深田咏美亚洲一区二区| 无码中文字幕波多野不卡| 91国产在线免费播放| 国产精品中文av在线播放| 水蜜桃国产一区二区三区| 欧美精产国品一二三产品价格| 91福利视频免费在线观看| 日韩a级精品一区二区| 亚洲一区二区三区偷拍女厕91| 亚洲综合一区成人在线| 亚洲免费av在线视频| 亚洲图库另类图片区| 青青青青青免费视频| 国产妇女自拍区在线观看| 淫秽激情视频免费观看| 免费岛国喷水视频在线观看 | 99热色原网这里只有精品| 亚洲精品ww久久久久久| 午夜激情高清在线观看| 亚洲在线免费h观看网站| 国产精品福利小视频a| 成人av电影免费版| 天天日天天做天天日天天做| 亚洲伊人久久精品影院一美女洗澡| 国产成人午夜精品福利| 国产精品人妻66p| 久草视频在线免播放| 日日爽天天干夜夜操| 一区二区三区国产精选在线播放 | 老司机免费视频网站在线看| 免费手机黄页网址大全| 在线国产中文字幕视频| 男人天堂最新地址av| 青草亚洲视频在线观看| 老师啊太大了啊啊啊尻视频| huangse网站在线观看| 青青青青青免费视频| 国产精品自偷自拍啪啪啪| 午夜精品九一唐人麻豆嫩草成人| 婷婷色中文亚洲网68| 水蜜桃国产一区二区三区| 国产欧美日韩在线观看不卡| 国产欧美精品不卡在线| 免费国产性生活视频| 久久尻中国美女视频| 久久久精品999精品日本| 91av中文视频在线| 91啪国自产中文字幕在线| 精品乱子伦一区二区三区免费播 | av俺也去在线播放| 人妻少妇精品久久久久久| 嫩草aⅴ一区二区三区| 男生用鸡操女生视频动漫| 国产精品黄大片在线播放| 免费黄色成人午夜在线网站| 国产亚洲精品视频合集| 亚洲天堂精品福利成人av| 秋霞午夜av福利经典影视| 色婷婷久久久久swag精品| 国产使劲操在线播放| 亚洲另类伦春色综合小| 国产亚洲精品欧洲在线观看| 精品国产亚洲av一淫| 精品suv一区二区69| 社区自拍揄拍尻屁你懂的| 99热99这里精品6国产| 99的爱精品免费视频| 人人爱人人妻人人澡39| 风流唐伯虎电视剧在线观看| 男大肉棒猛烈插女免费视频| 久久综合老鸭窝色综合久久| 亚洲麻豆一区二区三区| 在线免费视频 自拍| 国产综合视频在线看片| 91p0rny九色露脸熟女| 久久永久免费精品人妻专区| 韩国女主播精品视频网站| 久久机热/这里只有| 免费黄色成人午夜在线网站| 亚洲国产香蕉视频在线播放| 天天躁夜夜躁日日躁a麻豆| 18禁精品网站久久| 青青青视频自偷自拍38碰| 激情内射在线免费观看| 国产日韩精品一二三区久久久| 国产午夜激情福利小视频在线| 人妻少妇中文有码精品| 亚洲专区激情在线观看视频| 91在线免费观看成人| 午夜国产福利在线观看| 最新的中文字幕 亚洲| 日本五十路熟新垣里子| 色哟哟在线网站入口| 午夜在线观看一区视频| rct470中文字幕在线| 亚洲国产精品中文字幕网站| 午夜在线观看一区视频| 成人av免费不卡在线观看| 337p日本大胆欧美人| 中文字幕一区二区自拍| 一区二区视频视频视频| 国产女人被做到高潮免费视频| 99热久久极品热亚洲| 嫩草aⅴ一区二区三区| 97精品综合久久在线| 免费看高清av的网站| 国产欧美日韩在线观看不卡| 在线播放 日韩 av| 日本脱亚入欧是指什么| 91在线免费观看成人| 绝色少妇高潮3在线观看| 国产极品美女久久久久久| 亚洲精品国品乱码久久久久| 中文人妻AV久久人妻水| 中文字幕人妻av在线观看| 五十路熟女人妻一区二区9933| av在线观看网址av| 偷拍自拍亚洲视频在线观看| 国产美女精品福利在线| 91传媒一区二区三区| 18禁美女黄网站色大片下载| 老司机福利精品视频在线| 超碰在线观看免费在线观看 | 很黄很污很色的午夜网站在线观看| 黑人大几巴狂插日本少妇| 中文字幕中文字幕人妻| 五色婷婷综合狠狠爱| 美女大bxxxx内射| 成年人啪啪视频在线观看| 欧美老妇精品另类不卡片| 精品美女在线观看视频在线观看| 久久精品国产23696| 亚洲国产欧美一区二区三区久久| 91传媒一区二区三区| 做爰视频毛片下载蜜桃视频1| 国产av国片精品一区二区| 99久久99一区二区三区| 午夜福利资源综合激情午夜福利资| 一级黄片久久久久久久久| 亚洲精品 日韩电影| 乱亲女秽乱长久久久| 九一传媒制片厂视频在线免费观看| 91精品免费久久久久久| 亚洲天堂精品久久久| 欧美精品伦理三区四区 | 欧美在线精品一区二区三区视频| 最新中文字幕乱码在线| 丝袜美腿视频诱惑亚洲无| 女同性ⅹxx女同h偷拍| 欧美亚洲牲夜夜综合久久| 亚洲成人免费看电影| 亚洲一级av大片免费观看| 欧美viboss性丰满| 韩国男女黄色在线观看| 亚洲一区二区激情在线| 黑人大几巴狂插日本少妇| 国产熟妇人妻ⅹxxxx麻豆| 国产麻豆乱子伦午夜视频观看| 阴茎插到阴道里面的视频| 国产高清97在线观看视频| 国产精品亚洲а∨天堂免| 国产成人一区二区三区电影网站| 中文字幕一区二区亚洲一区| 人妻少妇亚洲一区二区| 97香蕉碰碰人妻国产樱花| 国产男女视频在线播放| 成年人啪啪视频在线观看| 青草亚洲视频在线观看| 偷偷玩弄新婚人妻h视频| 青青青青青免费视频| 免费一级黄色av网站| 最新国产精品网址在线观看| 亚洲人成精品久久久久久久| 青青社区2国产视频| 大白屁股精品视频国产| 日韩美女精品视频在线观看网站| 久久热久久视频在线观看| 国产1区,2区,3区| 五月天久久激情视频| 在线新三级黄伊人网| av老司机精品在线观看| 午夜成午夜成年片在线观看| 超pen在线观看视频公开97| 亚洲天堂成人在线观看视频网站 | 国产V亚洲V天堂无码欠欠| 人人妻人人人操人人人爽| 国产亚洲精品欧洲在线观看| 端庄人妻堕落挣扎沉沦| 亚洲av色图18p| 老司机午夜精品视频资源| 99久久99一区二区三区| 亚洲综合一区二区精品久久| 在线免费91激情四射 | 丰满的子国产在线观看| 欧美va不卡视频在线观看|