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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

String hashCode 方法为什么选择数字31作为乘子

發布時間:2025/3/21 编程问答 53 豆豆
生活随笔 收集整理的這篇文章主要介紹了 String hashCode 方法为什么选择数字31作为乘子 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1. 背景

某天,我在寫代碼的時候,無意中點開了 String hashCode 方法。然后大致看了一下 hashCode 的實現,發現并不是很復雜。但是我從源碼中發現了一個奇怪的數字,也就是本文的主角31。這個數字居然不是用常量聲明的,所以沒法從字面意思上推斷這個數字的用途。后來帶著疑問和好奇心,到網上去找資料查詢一下。在看完資料后,默默的感嘆了一句,原來是這樣啊。那么到底是哪樣呢?在接下來章節里,請大家帶著好奇心和我揭開數字31的用途之謎。

?2. 選擇數字31的原因

在詳細說明 String hashCode 方法選擇數字31的作為乘子的原因之前,我們先來看看 String hashCode 方法是怎樣實現的,如下:

1 2 3 4 5 6 7 8 9 10 11 12 public int hashCode() {int h = hash;if (h == 0 && value.length > 0) {char val[] = value;for (int i = 0; i < value.length; i++) {h = 31 * h + val[i];}hash = h;}return h; }

上面的代碼就是 String hashCode 方法的實現,是不是很簡單。實際上 hashCode 方法核心的計算邏輯只有三行,也就是代碼中的 for 循環。我們可以由上面的 for 循環推導出一個計算公式,hashCode 方法注釋中已經給出。如下:

s[0]*31^(n-1) + s[1]*31^(n-2) + … + s[n-1]

這里說明一下,上面的 s 數組即源碼中的 val 數組,是 String 內部維護的一個 char 類型數組。這里我來簡單推導一下這個公式:

1 2 3 4 5 6 假設 n=3 i=0 -> h = 31 * 0 + val[0] i=1 -> h = 31 * (31 * 0 + val[0]) + val[1] i=2 -> h = 31 * (31 * (31 * 0 + val[0]) + val[1]) + val[2]h = 31*31*31*0 + 31*31*val[0] + 31*val[1] + val[2]h = 31^(n-1)*val[0] + 31^(n-2)*val[1] + val[2]

上面的公式包括公式的推導并不是本文的重點,大家了解了解即可。接下來來說說本文的重點,即選擇31的理由。從網上的資料來看,一般有如下兩個原因:

第一,31是一個不大不小的質數,是作為 hashCode 乘子的優選質數之一。另外一些相近的質數,比如37、41、43等等,也都是不錯的選擇。那么為啥偏偏選中了31呢?請看第二個原因。

第二、31可以被 JVM 優化,31 * i = (i << 5) - i。

上面兩個原因中,第一個需要解釋一下,第二個比較簡單,就不說了。下面我來解釋第一個理由。一般在設計哈希算法時,會選擇一個特殊的質數。至于為啥選擇質數,我想應該是可以降低哈希算法的沖突率。至于原因,這個就要問數學家了,我幾乎可以忽略的數學水平解釋不了這個原因。上面說到,31是一個不大不小的質數,是優選乘子。那為啥同是質數的2和101(或者更大的質數)就不是優選乘子呢,分析如下。

這里先分析質數2。首先,假設?n = 6,然后把質數2和 n 帶入上面的計算公式。并僅計算公式中次數最高的那一項,結果是2^5 = 32,是不是很小。所以這里可以斷定,當字符串長度不是很長時,用質數2做為乘子算出的哈希值,數值不會很大。也就是說,哈希值會分布在一個較小的數值區間內,分布性不佳,最終可能會導致沖突率上升。

上面說了,質數2做為乘子會導致哈希值分布在一個較小區間內,那么如果用一個較大的大質數101會產生什么樣的結果呢?根據上面的分析,我想大家應該可以猜出結果了。就是不用再擔心哈希值會分布在一個小的區間內了,因為101^5 = 10,510,100,501。但是要注意的是,這個計算結果太大了。如果用 int 類型表示哈希值,結果會溢出,最終導致數值信息丟失。盡管數值信息丟失并不一定會導致沖突率上升,但是我們暫且先認為質數101(或者更大的質數)也不是很好的選擇。最后,我們再來看看質數31的計算結果:31^5 = 28629151,結果值相對于32和10,510,100,501來說。是不是很nice,不大不小。

上面用了比較簡陋的數學手段證明了數字31是一個不大不小的質數,是作為 hashCode 乘子的優選質數之一。接下來我會用詳細的實驗來驗證上面的結論,不過在驗證前,我們先看看 Stack Overflow 上關于這個問題的討論,Why does Java’s hashCode() in String use 31 as a multiplier?。其中排名第一的答案引用了《Effective Java》中的一段話,這里也引用一下:

The value 31 was chosen because it is an odd prime. If it were even and the multiplication overflowed, information would be lost, as multiplication by 2 is equivalent to shifting. The advantage of using a prime is less clear, but it is traditional. A nice property of 31 is that the multiplication can be replaced by a shift and a subtraction for better performance: `31 * i == (i << 5) - i``. Modern VMs do this sort of optimization automatically.

簡單翻譯一下:

選擇數字31是因為它是一個奇質數,如果選擇一個偶數會在乘法運算中產生溢出,導致數值信息丟失,因為乘二相當于移位運算。選擇質數的優勢并不是特別的明顯,但這是一個傳統。同時,數字31有一個很好的特性,即乘法運算可以被移位和減法運算取代,來獲取更好的性能:31 * i == (i << 5) - i,現代的 Java 虛擬機可以自動的完成這個優化。

排名第二的答案設這樣說的:

As Goodrich and Tamassia point out, If you take over 50,000 English words (formed as the union of the word lists provided in two variants of Unix), using the constants 31, 33, 37, 39, and 41 will produce less than 7 collisions in each case. Knowing this, it should come as no surprise that many Java implementations choose one of these constants.

這段話也翻譯一下:

正如 Goodrich 和 Tamassia 指出的那樣,如果你對超過 50,000 個英文單詞(由兩個不同版本的 Unix 字典合并而成)進行 hash code 運算,并使用常數 31, 33, 37, 39 和 41 作為乘子,每個常數算出的哈希值沖突數都小于7個,所以在上面幾個常數中,常數 31 被 Java 實現所選用也就不足為奇了。

上面的兩個答案完美的解釋了 Java 源碼中選用數字 31 的原因。接下來,我將針對第二個答案就行驗證,請大家繼續往下看。

?3. 實驗及數據可視化

本節,我將使用不同的數字作為乘子,對超過23萬個英文單詞進行哈希運算,并計算哈希算法的沖突率。同時,我也將針對不同乘子算出的哈希值分布情況進行可視化處理,讓大家可以直觀的看到數據分布情況。本次實驗所使用的數據是 Unix/Linux 平臺中的英文字典文件,文件路徑為?/usr/share/dict/words。

?3.1 哈希值沖突率計算

計算哈希算法沖突率并不難,比如可以一次性將所有單詞的 hash code 算出,并放入 Set 中去除重復值。之后拿單詞數減去 set.size() 即可得出沖突數,有了沖突數,沖突率就可以算出來了。當然,如果使用 JDK8 提供的流式計算 API,則可更方便算出,代碼片段如下:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 public static Integer hashCode(String str, Integer multiplier) {int hash = 0;for (int i = 0; i < str.length(); i++) {hash = multiplier * hash + str.charAt(i);}return hash; }/*** 計算 hash code 沖突率,順便分析一下 hash code 最大值和最小值,并輸出* @param multiplier* @param hashs*/ public static void calculateConflictRate(Integer multiplier, List<Integer> hashs) {Comparator<Integer> cp = (x, y) -> x > y ? 1 : (x < y ? -1 : 0);int maxHash = hashs.stream().max(cp).get();int minHash = hashs.stream().min(cp).get();// 計算沖突數及沖突率int uniqueHashNum = (int) hashs.stream().distinct().count();int conflictNum = hashs.size() - uniqueHashNum;double conflictRate = (conflictNum * 1.0) / hashs.size();System.out.println(String.format("multiplier=%4d, minHash=%11d, maxHash=%10d, conflictNum=%6d, conflictRate=%.4f%%",multiplier, minHash, maxHash, conflictNum, conflictRate * 100)); }

結果如下:

從上圖可以看出,使用較小的質數做為乘子時,沖突率會很高。尤其是質數2,沖突率達到了 55.14%。同時我們注意觀察質數2作為乘子時,哈希值的分布情況。可以看得出來,哈希值分布并不是很廣,僅僅分布在了整個哈希空間的正半軸部分,即 0 ~ 231-1。而負半軸 -231?~ -1,則無分布。這也證明了我們上面斷言,即質數2作為乘子時,對于短字符串,生成的哈希值分布性不佳。然后再來看看我們之前所說的 31、37、41 這三個不大不小的質數,表現都不錯,沖突數都低于7個。而質數 101 和 199 表現的也很不錯,沖突率很低,這也說明哈希值溢出并不一定會導致沖突率上升。但是這兩個家伙一言不合就溢出,我們認為他們不是哈希算法的優選乘子。最后我們再來看看 32 和 36 這兩個偶數的表現,結果并不好,尤其是 32,沖突率超過了了50%。盡管 36 表現的要好一點,不過和 31,37相比,沖突率還是比較高的。當然并非所有的偶數作為乘子時,沖突率都會比較高,大家有興趣可以自己驗證。

?3.2 哈希值分布可視化

上一節分析了不同數字作為乘子時的沖突率情況,這一節來分析一下不同數字作為乘子時,哈希值的分布情況。在詳細分析之前,我先說說哈希值可視化的過程。我原本是打算將所有的哈希值用一維散點圖進行可視化,但是后來找了一圈,也沒找到合適的畫圖工具。加之后來想了想,一維散點圖可能不合適做哈希值可視化,因為這里有超過23萬個哈希值。也就意味著會在圖上顯示超過23萬個散點,如果不出意外的話,這23萬個散點會聚集的很密,有可能會變成一個大黑塊,就失去了可視化的意義了。所以這里選擇了另一種可視化效果更好的圖表,也就是 excel 中的平滑曲線的二維散點圖(下面簡稱散點曲線圖)。當然這里同樣沒有把23萬散點都顯示在圖表上,太多了。所以在實際繪圖過程中,我將哈希空間等分成了64個子區間,并統計每個區間內的哈希值數量。最后將分區編號做為X軸,哈希值數量為Y軸,就繪制出了我想要的二維散點曲線圖了。這里舉個例子說明一下吧,以第0分區為例。第0分區數值區間是[-2147483648, -2080374784),我們統計落在該數值區間內哈希值的數量,得到?<分區編號, 哈希值數量>?數值對,這樣就可以繪圖了。分區代碼如下:

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 /*** 將整個哈希空間等分成64份,統計每個空間內的哈希值數量* @param hashs*/ public static Map<Integer, Integer> partition(List<Integer> hashs) {// step = 2^32 / 64 = 2^26final int step = 67108864;List<Integer> nums = new ArrayList<>();Map<Integer, Integer> statistics = new LinkedHashMap<>();int start = 0;for (long i = Integer.MIN_VALUE; i <= Integer.MAX_VALUE; i += step) {final long min = i;final long max = min + step;int num = (int) hashs.parallelStream().filter(x -> x >= min && x < max).count();statistics.put(start++, num);nums.add(num);}// 為了防止計算出錯,這里驗證一下int hashNum = nums.stream().reduce((x, y) -> x + y).get();assert hashNum == hashs.size();return statistics; }

本文中的哈希值是用整形表示的,整形的數值區間是?[-2147483648, 2147483647],區間大小為?2^32。所以這里可以將區間等分成64個子區間,每個自子區間大小為?2^26。詳細的分區對照表如下:

分區編號分區下限分區上限分區編號分區下限分區上限
0-2147483648-208037478432067108864
1-2080374784-20132659203367108864134217728
2-2013265920-194615705634134217728201326592
3-1946157056-187904819235201326592268435456
4-1879048192-181193932836268435456335544320
5-1811939328-174483046437335544320402653184
6-1744830464-167772160038402653184469762048
7-1677721600-161061273639469762048536870912
8-1610612736-154350387240536870912603979776
9-1543503872-147639500841603979776671088640
10-1476395008-140928614442671088640738197504
11-1409286144-134217728043738197504805306368
12-1342177280-127506841644805306368872415232
13-1275068416-120795955245872415232939524096
14-1207959552-1140850688469395240961006632960
15-1140850688-10737418244710066329601073741824
16-1073741824-10066329604810737418241140850688
17-1006632960-9395240964911408506881207959552
18-939524096-8724152325012079595521275068416
19-872415232-8053063685112750684161342177280
20-805306368-7381975045213421772801409286144
21-738197504-6710886405314092861441476395008
22-671088640-6039797765414763950081543503872
23-603979776-5368709125515435038721610612736
24-536870912-4697620485616106127361677721600
25-469762048-4026531845716777216001744830464
26-402653184-3355443205817448304641811939328
27-335544320-2684354565918119393281879048192
28-268435456-2013265926018790481921946157056
29-201326592-1342177286119461570562013265920
30-134217728-671088646220132659202080374784
31-6710886406320803747842147483648

接下來,讓我們對照上面的分區表,對數字2、3、17、31、101的散點曲線圖進行簡單的分析。先從數字2開始,數字2對于的散點曲線圖如下:

上面的圖還是很一幕了然的,乘子2算出的哈希值幾乎全部落在第32分區,也就是?[0, 67108864)數值區間內,落在其他區間內的哈希值數量幾乎可以忽略不計。這也就不難解釋為什么數字2作為乘子時,算出哈希值的沖突率如此之高的原因了。所以這樣的哈希算法要它有何用啊,拖出去斬了吧。接下來看看數字3作為乘子時的表現:

3作為乘子時,算出的哈希值分布情況和2很像,只不過稍微好了那么一點點。從圖中可以看出絕大部分的哈希值最終都落在了第32分區里,哈希值的分布性很差。這個也沒啥用,拖出去槍斃5分鐘吧。在看看數字17的情況怎么樣:

數字17作為乘子時的表現,明顯比上面兩個數字好點了。雖然哈希值在第32分區和第34分區有一定的聚集,但是相比較上面2和3,情況明顯好好了很多。除此之外,17作為乘子算出的哈希值在其他區也均有分布,且較為均勻,還算是一個不錯的乘子吧。

接下來來看看我們本文的主角31了,31作為乘子算出的哈希值在第33分區有一定的小聚集。不過相比于數字17,主角31的表現又好了一些。首先是哈希值的聚集程度沒有17那么嚴重,其次哈希值在其他區分布的情況也要好于17。總之,選31,準沒錯啊。


最后再來看看大質數101的表現,不難看出,質數101作為乘子時,算出的哈希值分布情況要好于主角31,有點喧賓奪主的意思。不過不可否認的是,質數101的作為乘子時,哈希值的分布性確實更加均勻。所以如果不在意質數101容易導致數據信息丟失問題,或許其是一個更好的選擇。

?4.寫在最后

經過上面的分析與實踐,我想大家應該明白了 String hashCode 方法中選擇使用數字31作為乘子的原因了。本文本質是一篇簡單的科普文而已,并沒有銀彈?。如果大家讀完后覺得又漲知識了,那這篇文章的目的就達到了。最后,本篇文章的配圖畫的還是很辛苦的,所以如果大家覺得文章不錯,不妨就給個贊吧,就當是對我的鼓勵了。另外,如果文章中有不妥或者錯誤的地方,也歡迎指出來。如果能不吝賜教,那就更好了。最后祝大家生活愉快,再見。

  • 本文鏈接:?https://www.tianxiaobo.com/2018/01/18/String-hashCode-方法為什么選擇數字31作為乘子/

from:?http://www.tianxiaobo.com/2018/01/18/String-hashCode-%E6%96%B9%E6%B3%95%E4%B8%BA%E4%BB%80%E4%B9%88%E9%80%89%E6%8B%A9%E6%95%B0%E5%AD%9731%E4%BD%9C%E4%B8%BA%E4%B9%98%E5%AD%90/?

總結

以上是生活随笔為你收集整理的String hashCode 方法为什么选择数字31作为乘子的全部內容,希望文章能夠幫你解決所遇到的問題。

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

国语黄色片 | 久久午夜电影 | 五月婷社区 | 91av视频在线免费观看 | 久久国产一区二区三区 | 五月婷婷色综合 | 国产午夜三级一二三区 | 丁香激情综合国产 | 一本一本久久a久久精品综合妖精 | 久久老司机精品视频 | 色婷婷综合久久久中文字幕 | 在线视频 一区二区 | 国产999精品久久久久久麻豆 | 欧美国产视频在线 | 国产成人精品亚洲 | 五月婷婷久久丁香 | 国产精品久久久久影院日本 | 黄色在线观看免费网站 | 国产精品自产拍在线观看中文 | 亚洲精品久久久久久久蜜桃 | 欧美色精品天天在线观看视频 | 国产在线观看免费 | 久久高清精品 | 一区二区三区免费网站 | 日韩黄色网络 | 成年人视频在线免费 | 亚洲精品在线免费看 | 国产男女免费完整视频 | 久久久久久免费 | 欧美色图视频一区 | 亚洲专区欧美 | 丁香五月亚洲综合在线 | 人成免费网站 | 五月天综合色 | 欧美性大战久久久久 | 免费大片av | 天天操天天射天天 | 在线观看视频在线观看 | 99精品在线 | 天天操综合网站 | 亚洲 欧美 成人 | 粉嫩av一区二区三区四区五区 | 中文字幕观看av | 免费在线观看日韩欧美 | 国模视频一区二区三区 | 成人少妇影院yyyy | 免费成人在线电影 | 欧美精品久久久久久 | 97精品国产一二三产区 | 国产在线91精品 | 最新成人av | av在线a| 久久视频这里有久久精品视频11 | 欧美一级性生活片 | 亚洲黄色影院 | 亚洲欧洲精品一区二区精品久久久 | 久久久影院 | 日日干天天爽 | 在线观看免费91 | 日韩欧美在线免费观看 | 久久久香蕉视频 | 特级毛片在线 | 久久国产精品99国产精 | 日韩欧美精品免费 | h动漫中文字幕 | 国产精品一区二区久久 | 黄网站色视频免费观看 | 亚洲精品2区 | 久久综合久久综合久久综合 | 麻豆视频免费入口 | 99久久精品国产一区 | 久香蕉 | 国产美女精品视频免费观看 | 三级av片| 日本精品视频在线播放 | 探花视频在线版播放免费观看 | 字幕网av| 免费av网址大全 | 99免费在线观看视频 | 国产精品一区二区久久久久 | 免费在线一区二区 | 国产精品综合久久久久久 | 国产精品二区在线 | 久久草草热国产精品直播 | 99精品乱码国产在线观看 | 亚洲综合成人专区片 | 香蕉影视在线观看 | 高清国产午夜精品久久久久久 | 99久久99久久综合 | 日韩一区正在播放 | 在线播放精品一区二区三区 | 国产精品嫩草69影院 | 免费人成网ww44kk44 | 国产亚洲精品综合一区91 | 99热在线精品观看 | 成人三级网站在线观看 | 日韩在线免费不卡 | 丁香婷婷激情国产高清秒播 | 99国产高清| 亚洲精品乱码久久久久久蜜桃欧美 | 99视频精品视频高清免费 | 久久久久久美女 | 色九九影院 | 五月色综合 | 日韩免费观看视频 | 精品一区在线看 | 日韩中文字幕免费看 | 碰超人人 | 美女在线观看av | 在线婷婷| 国产黄a三级 | 国产视频999 | 亚洲免费av网站 | 欧美黄色软件 | 国产在线中文 | 久久久久久久久爱 | 精品久久九九 | 久热av | 日韩免费观看视频 | 成人黄色毛片视频 | 在线观看你懂的网址 | 久久综合一本 | 少妇bbbb搡bbbb桶 | 亚洲成人免费观看 | 手机色在线 | 亚洲一区二区观看 | 国产精品黄色影片导航在线观看 | 在线看片中文字幕 | 国产精品久久在线 | 久久免费99精品久久久久久 | 欧洲精品在线视频 | 最近最新mv字幕免费观看 | 国产中文字幕视频 | 亚洲第二色 | 亚洲网站在线看 | 国产黄色免费在线观看 | 福利一区二区在线 | 国产精品美女999 | 波多野结衣在线观看一区二区三区 | 激情五月激情综合网 | 99视频这里只有 | 在线观看av中文字幕 | 久久精品香蕉 | 亚洲欧美一区二区三区孕妇写真 | 在线电影a| 97色se| 在线成人观看 | 国产黄色在线看 | 久久久久久久免费看 | 国产日韩欧美视频在线观看 | 亚洲精品在线视频播放 | 999抗病毒口服液 | 中文久久精品 | 操一草| 国产日本三级 | 精品久久久久久久久久久久久 | 国产一区二区高清视频 | 黄网站免费大全入口 | 黄色av电影免费观看 | 96久久 | 日本丶国产丶欧美色综合 | 国产在线精品观看 | 久久99国产精品久久 | 日韩精品中文字幕久久臀 | 三级av免费 | 欧美国产日韩一区二区三区 | 成年人在线免费看片 | 99在线观看免费视频精品观看 | 一区二区三区在线视频111 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 一区二区三区免费在线播放 | 欧美伦理一区 | 亚洲精品在线观看免费 | 午夜av在线电影 | 日韩小视频网站 | 亚洲在线网址 | 日本精品视频一区 | 久久久国产精品人人片99精片欧美一 | 激情电影影院 | 激情视频免费观看 | 男女激情免费网站 | 麻豆网站免费观看 | 久久久精品国产免费观看一区二区 | 久久成人国产精品免费软件 | 国产精品永久久久久久久www | 国产精品一区久久久久 | 久久综合偷偷噜噜噜色 | 91最新视频在线观看 | 久久精品美女视频 | 亚洲国产美女精品久久久久∴ | av在线播放免费 | 黄色一级在线免费观看 | 国模精品一区二区三区 | 91刺激视频 | 91精品在线麻豆 | 久久久亚洲国产精品麻豆综合天堂 | 婷婷激情5月天 | 九草视频在线观看 | 免费看黄在线 | 日韩精品在线播放 | 久久艹综合 | 亚洲 欧美日韩 国产 中文 | 日韩亚洲国产中文字幕 | 国产免费xvideos视频入口 | 激情av五月婷婷 | av高清网站在线观看 | 国产午夜免费视频 | 日韩电影久久久 | 中文字幕丝袜美腿 | 久久精品综合视频 | 有没有在线观看av | 国产小视频福利在线 | 人人草人| 美女视频永久黄网站免费观看国产 | 久久在线精品 | 日韩中文字幕免费在线播放 | 久久久久欠精品国产毛片国产毛生 | 日本中文字幕一二区观 | 91热精品 | 99精品视频观看 | 国产精品毛片久久久久久久久久99999999 | av一区二区在线观看中文字幕 | 精品福利av | 九九国产视频 | 超碰99在线 | 激情视频免费在线 | 香蕉视频久久 | 999久久久久久 | 亚洲精品国产成人av在线 | 99久久精品国| 久免费视频 | 日日操日日插 | 日韩免费大片 | 国产精品乱码高清在线看 | 国产在线探花 | 99久久日韩精品视频免费在线观看 | 国语精品免费视频 | 日韩综合色 | 偷拍精偷拍精品欧洲亚洲网站 | 亚洲精品av在线 | 国产精品久久电影观看 | 久久天堂影院 | 美女视频黄是免费的 | 久久激情婷婷 | 国产麻豆果冻传媒在线观看 | 天天综合天天做天天综合 | 欧美精品日韩 | 中文乱幕日产无线码1区 | 精品国内自产拍在线观看视频 | 免费日韩一区二区三区 | av电影av在线 | 国产欧美精品一区aⅴ影院 99视频国产精品免费观看 | 92中文资源在线 | 一级片免费观看 | 超级碰碰碰碰 | 中文字幕av电影下载 | 欧美日韩一区二区视频在线观看 | 亚洲婷婷综合色高清在线 | 国产精品美女久久久久久 | 国产成人黄色网址 | 久久免费国产视频 | 成人福利在线 | 久久精品8 | 亚洲一区在线看 | 日日躁夜夜躁aaaaxxxx | 亚洲第一av在线播放 | 久草在线免费电影 | 国产中文字幕三区 | 久久午夜影视 | 免费无遮挡动漫网站 | 91久久国产自产拍夜夜嗨 | 激情在线网站 | 日韩欧美高清一区二区三区 | 欧美精品一区二区三区一线天视频 | 国内精品视频久久 | 亚洲国产日韩一区 | 天天爽网站 | 国产成人333kkk | 狠狠躁18三区二区一区ai明星 | 久久久国产一区二区 | 97视频资源| 欧美日韩一级视频 | 亚洲精品一区二区网址 | 国产精品久久久久久久久搜平片 | 五月婷婷网站 | 亚洲精品久久久蜜桃直播 | 日韩最新中文字幕 | 99精品欧美一区二区 | 免费日韩一区二区 | 久久五月婷婷综合 | 国产亚州av | 免费看黄色小说的网站 | 91精品国产一区 | 成人97人人超碰人人99 | 国产色区 | 婷婷五月在线视频 | 在线观看成人小视频 | 在线日韩亚洲 | caobi视频 | avwww在线观看 | 制服丝袜亚洲 | 欧美精品生活片 | 欧美日本国产在线观看 | 国产精品网站一区二区三区 | 九九久久国产 | 国产成人亚洲在线观看 | 美女精品| 日韩欧美xx | 国产精品久久久久久久久久久久午 | av免费观看高清 | 中文字幕 国产视频 | 欧美精品亚洲精品 | 干 操 插 | 成人资源在线观看 | 国产精品久久久久久久99 | 很黄很黄的网站免费的 | 成人一级黄色片 | www.超碰97.com | 久久视频在线 | www.在线看片.com | 网站你懂的 | 亚洲天堂毛片 | 国产精品v欧美精品v日韩 | 欧美性成人 | 91免费观看视频在线 | 99婷婷 | 天天操网 | 人人爽夜夜爽 | 国产成人在线一区 | 精品一区二区视频 | 999成人免费视频 | 欧美一区二区三区在线观看 | 国产一性一爱一乱一交 | 日韩欧美精品一区二区三区经典 | av观看网站| 伊人丁香 | 91香蕉视频污在线 | 久久久久久久久久久久久国产精品 | 婷婷激情5月天 | 国产精品视频地址 | 欧美日韩在线精品 | 久久视屏网 | 2024国产在线| 九月婷婷色| 免费欧美高清视频 | 在线观看完整版免费 | 91成人免费电影 | av免费线看| 91久久精品一区二区三区 | 99热在线网站 | 黄色官网在线观看 | 九九视频一区 | 极品久久久久 | 日韩1页 | 国产精品久久久久久久久费观看 | 97碰在线 | 青青河边草手机免费 | 国产中出在线观看 | 国产精品午夜免费福利视频 | 最近更新的中文字幕 | 国产色秀视频 | 欧美日韩高清在线一区 | 成人黄色短片 | 欧美午夜精品久久久久久浪潮 | 亚洲精品中文字幕在线观看 | 中文字幕在线看视频 | 永久免费毛片 | 婷婷亚洲综合五月天小说 | 国产网红在线观看 | 国产在线国偷精品产拍 | 中文字幕视频网 | 日韩av在线一区二区 | 国产原创在线视频 | 久久精品一区二区三区视频 | 91视频黄色| 国产精品18久久久久白浆 | 黄色aaa毛片 | 天天综合五月天 | 在线观看国产永久免费视频 | 婷婷丁香花五月天 | 国产精品久久久久久久久久白浆 | 久久人91精品久久久久久不卡 | 国产一区免费在线 | 亚洲黄网站 | av在线永久免费观看 | 免费美女久久99 | 夜夜骑天天操 | 久久久久久久综合色一本 | 国产精品福利久久久 | 国产精品丝袜久久久久久久不卡 | 天天操天天插 | 国产精品欧美日韩 | 欧美大片aaa | 国产精品久久嫩一区二区免费 | 欧美日韩国语 | 最新99热| 午夜美女网站 | 久久免费视频一区 | 蜜臀aⅴ国产精品久久久国产 | 久久黄色片 | 天天综合亚洲 | 青青网视频 | 91精品在线观看视频 | 亚洲波多野结衣 | 狠狠色丁婷婷日日 | 在线播放 一区 | 日本丶国产丶欧美色综合 | 久草在线免 | www天天干com | 成人久久亚洲 | 亚洲高清国产视频 | 免费精品 | 亚洲欧美视频一区二区三区 | 久久国语露脸国产精品电影 | 亚洲午夜av久久乱码 | 国产精品成人久久久 | 中文字幕黄网 | 欧美韩国日本在线观看 | 激情婷婷久久 | 久久国语露脸国产精品电影 | 一区二区国产精品 | 中字幕视频在线永久在线观看免费 | 国产一区网址 | 国产免费xvideos视频入口 | 国产一区欧美二区 | 九九电影在线 | 国产女做a爱免费视频 | 在线电影 一区 | 在线视频精品播放 | 国产电影黄色av | 欧美伊人网 | 夜夜爽天天爽 | 中文字幕在线观看一区二区 | 黄a在线看 | 国产美女视频免费观看的网站 | 狠狠久久综合 | 国产一区国产二区在线观看 | 欧美日韩国产精品一区二区三区 | 麻豆系列在线观看 | 久久久久久伊人 | 中文字幕成人一区 | 国产精品中文字幕av | 日韩在线观看精品 | 成人午夜片av在线看 | 免费av观看网站 | 欧美日韩精品久久久 | 久久国产午夜精品理论片最新版本 | 久久这里有精品 | 亚洲欧洲xxxx | 在线韩国电影免费观影完整版 | 在线免费视频你懂的 | 天天干天天摸天天操 | 人人狠狠综合久久亚洲 | 97福利社 | 久久国产美女视频 | 欧美日韩高清一区二区三区 | 草久中文字幕 | 欧美大片大全 | 久久刺激视频 | 久久综合久久88 | 国产丝袜网站 | 日韩欧美在线观看一区二区 | 精品视频免费观看 | 亚洲国产最新 | 亚洲一区日韩在线 | 少妇做爰k8经典 | 99re8这里有精品热视频免费 | 久久久久看片 | 草久久精品 | 免费看黄色大全 | 国产精品1区2区在线观看 | 狠狠色丁香久久婷婷综 | 丁香久久五月 | 亚洲午夜久久久久久久久 | 久久精品视频日本 | 日韩免费在线一区 | 免费色视频网址 | 人人看黄色 | 久久综合偷偷噜噜噜色 | av在线网站大全 | 免费精品在线观看 | 久久精品超碰 | av免费看av | 91电影福利 | 精品自拍sae8—视频 | 国产在线久久久 | 国产一区二区在线免费播放 | 国产成人久久精品77777综合 | 国产精品一区二区三区久久 | 国产色视频一区二区三区qq号 | 亚洲精品麻豆视频 | 久久欧美精品 | 精品视频免费 | 日韩字幕 | 色播五月激情综合网 | 91爱爱中文字幕 | 99久高清在线观看视频99精品热在线观看视频 | 成人黄色在线观看视频 | 日日日视频 | 99精彩视频 | 国产精品一区免费看8c0m | 国产一级91 | 91秒拍国产福利一区 | 99久久er热在这里只有精品15 | 中文字幕 第二区 | av千婊在线免费观看 | 久精品视频 | 亚洲美女在线国产 | 在线观看日韩一区 | 欧美午夜精品久久久久 | 中文十次啦 | 国产精品第72页 | 日本中文在线 | www.99av| 狠狠色丁婷婷日日 | 狠狠干狠狠久久 | 久久99国产视频 | 西西4444www大胆无视频 | 9992tv成人免费看片 | 亚洲天堂网在线视频 | 久久99国产一区二区三区 | 亚洲黄色在线免费观看 | 午夜成人免费影院 | 亚洲一级二级 | 97精品国产 | 国产亚洲精品综合一区91 | 精品久久久久久久久久久久久久久久久久 | 国产成人精品一区二区三区在线观看 | 丁香激情五月婷婷 | 99精品电影| 中文字幕在线播放日韩 | 天天综合亚洲 | 91手机电影 | 怡红院久久 | 国内一级片在线观看 | 久久亚洲国产精品 | 免费中文字幕视频 | 丁香在线观看完整电影视频 | 国内视频| 操操操人人人 | 久久精品999| 操操色 | 四虎影视成人精品 | 久久婷婷亚洲 | 美女精品在线观看 | 亚洲最新av网址 | 午夜狠狠操 | 少妇高潮流白浆在线观看 | 欧美一区二区三区免费看 | 国产精品自在欧美一区 | 美女视频a美女大全免费下载蜜臀 | 日韩亚洲在线视频 | 一区二区理论片 | 在线播放第一页 | 久久国产精品99久久久久久丝袜 | 超碰九九 | 丝袜足交在线 | 亚洲精品欧洲精品 | 国产午夜不卡 | 精品国产一区二区三区不卡 | 国产精品一区二区你懂的 | 又黄又爽的视频在线观看网站 | 国产高清av免费在线观看 | 一区在线免费观看 | 美国av大片 | 99久久精品无免国产免费 | 欧美在一区 | 91热视频| 在线电影av | 91桃色在线免费观看 | 综合色站导航 | 亚洲精品黄网站 | 久久久久久欧美二区电影网 | 97精产国品一二三产区在线 | 天天色天天射天天综合网 | 免费色婷婷 | 中文高清av | 日韩视频一区二区三区 | 欧美日韩精品在线视频 | 黄污网站在线观看 | 手机在线视频福利 | 久草在线视频在线 | 97国产大学生情侣白嫩酒店 | 99精品福利 | 在线观看免费91 | 久久精品免费电影 | 中文字幕免费一区二区 | 一本一本久久a久久精品综合小说 | 美腿丝袜av | 国产精品久久久久久av | 五月婷婷视频在线 | 免费看的黄色小视频 | 一区二区三区日韩在线 | 中文字幕日韩一区二区三区不卡 | 精品亚洲免费视频 | 一区二区三区久久 | 激情视频免费观看 | 久久激情五月丁香伊人 | 精品在线观 | 国产色黄网站 | 色综合色综合久久综合频道88 | 国产精品视频app | 久久久久久久久久久久国产精品 | caobi视频| 国产美女视频网站 | 一区二区三区视频在线 | 国产亚洲免费的视频看 | 97精品国产97久久久久久 | 波多野结衣网址 | 亚洲精品黄色片 | 91大神免费视频 | 综合色综合色 | 午夜精品av | 最近免费观看的电影完整版 | 99热国产精品 | 五月婷婷国产 | 国产1区在线观看 | 色欧美综合 | 欧美一进一出抽搐大尺度视频 | 色综合咪咪久久网 | 亚洲综合在线播放 | 成人av高清| 婷婷色在线 | 蜜臀aⅴ精品一区二区三区 久久视屏网 | 91亚洲视频在线观看 | 狠狠干夜夜操 | 亚洲国产精品99久久久久久久久 | 亚洲精品美女在线观看播放 | 一区二区三区中文字幕在线观看 | 中文字幕中文字幕在线中文字幕三区 | 久久爽久久爽久久av东京爽 | 久在线观看视频 | 国产在线精品福利 | 国产在线精品国自产拍影院 | 国产日韩在线播放 | 97精品国产一二三产区 | 免费黄色av电影 | 在线观看视频免费大全 | 久久欧洲视频 | 91精品一区二区三区蜜桃 | 99热九九这里只有精品10 | 色就色,综合激情 | 97偷拍在线视频 | 狂野欧美激情性xxxx欧美 | 亚洲97在线 | 超碰在线人人艹 | 久久999精品 | 中文字幕在线国产精品 | 九九九热| 久久 一区| 久久久久女人精品毛片九一 | 成人午夜影视 | 亚洲精品一区中文字幕乱码 | 精品国产自在精品国产精野外直播 | 久久久在线视频 | 在线 精品 国产 | 免费v片| 国产女人免费看a级丨片 | 91成人免费看片 | 精品无人国产偷自产在线 | 永久免费精品视频 | 国产高清在线观看av | 手机av永久免费 | 国产伦精品一区二区三区无广告 | 国产精品99久久久精品免费观看 | 成人一区电影 | 超碰在线人人 | 4438全国亚洲精品在线观看视频 | 精品v亚洲v欧美v高清v | 91欧美精品 | 日韩精品黄 | 国产精品九九热 | aa一级片| 国产99中文字幕 | 中文字幕av在线电影 | 国产在线观看网站 | 久久久精品福利视频 | 丁香婷婷久久 | 国产精品成人在线 | 久久久国产一区二区三区四区小说 | 97视频在线 | 永久免费毛片在线观看 | 天天爽天天爽天天爽 | 久久精品电影网 | 九七在线视频 | 天天操夜夜做 | 久久亚洲电影 | 99久久精品国产免费看不卡 | 91久草视频 | 人成在线免费视频 | 国产亚洲精品bv在线观看 | 五月婷婷电影网 | 国产偷在线 | 国产又粗又猛又爽又黄的视频先 | 麻豆一二 | 最新免费av在线 | 日韩在线三级 | 高清在线一区 | 国产精品美女久久 | 国产成人精品亚洲 | 蜜桃麻豆www久久囤产精品 | 日韩在线中文字幕视频 | 97超碰香蕉 | 天天操操操操操操 | 欧美精品国产综合久久 | 天天插日日插 | 欧美一级在线 | 日韩在线观看一区二区三区 | 五月婷婷婷婷婷 | 成人av播放 | 伊人导航 | 激情六月婷婷久久 | 五月激情综合婷婷 | 日韩电影精品一区 | 亚洲精选视频免费看 | 日韩一三区 | 日韩av不卡在线观看 | 在线观看中文字幕dvd播放 | 亚洲综合在线观看视频 | 综合五月 | 黄网站免费大全入口 | 成人在线视频免费观看 | 中文字幕日韩在线播放 | 久久y | 9ⅰ精品久久久久久久久中文字幕 | 日韩欧美视频一区 | 丁香5月婷婷久久 | 91精品国产自产91精品 | 国产精品999久久久 久产久精国产品 | 婷婷网在线 | 91片黄在线观 | 欧美日韩一区二区在线 | 精品欧美日韩 | 国产精品久久久久久久久软件 | 欧美福利片在线观看 | 免费a v观看 | 91视频中文字幕 | 天天干,天天操,天天射 | 免费观看一级视频 | 亚洲最新精品 | 国产一级二级在线观看 | 白丝av免费观看 | 91精品国产综合久久久久久久 | 四虎永久免费 | 久久tv| 99久久精品无码一区二区毛片 | 国产不卡在线观看视频 | 久久精品亚洲 | 香蕉视频网站在线观看 | 日韩超碰 | 久久久午夜精品福利内容 | 精品毛片久久久久久 | 天天色天天色 | 五月天综合色激情 | 日韩欧美一级二级 | 天天色天天操天天爽 | 片网址| 日韩91在线| 国产一二三四在线观看视频 | 国产日韩精品在线 | 国产91影视 | 一级片视频在线 | 国产精品网站 | 久久久久久久久久久久电影 | 国产精品高清免费在线观看 | 婷婷午夜天 | 美女免费视频一区二区 | 在线观看免费一区 | 欧洲精品久久久久毛片完整版 | 国产视频一区在线播放 | 亚洲精品乱码久久久久久蜜桃动漫 | 成人九九视频 | 最新中文字幕在线播放 | av大全免费在线观看 | 国产资源在线播放 | 久久免费在线观看 | 精品国产一区二区三区噜噜噜 | 麻豆一二三精选视频 | 黄色在线观看污 | 黄色视屏免费在线观看 | 精品 激情 | 一区二区三区在线不卡 | 91亚洲欧美激情 | 美女一区网站 | 亚洲欧洲精品一区 | 91免费看黄色 | 亚洲成色| 日韩av中文字幕在线免费观看 | 国产精品黄 | 中文字幕在线播放第一页 | 日韩中文字幕免费电影 | 97在线视 | 五月天激情开心 | 久久99精品国产麻豆宅宅 | 麻花豆传媒一二三产区 | 国产在线 一区二区三区 | 久艹在线播放 | 99精品在线免费观看 | 亚洲一级免费电影 | 999电影免费在线观看 | 精品亚洲视频在线 | 91丨九色丨蝌蚪丨老版 | 97人人爽人人 | 五月天网页 | 亚洲高清免费在线 | 欧美精品在线一区二区 | 国产精品午夜免费福利视频 | 亚洲精品乱码久久久久久久久久 | 91免费在线 | 免费看一级黄色 | 国内精品久久久久久久久久 | 久香蕉| 日韩欧美在线不卡 | 狠狠操.com | 天天色天天射天天操 | 中文字幕在线中文 | 91中文字幕 | 深爱激情开心 | 亚洲国产影院av久久久久 | 欧美一级性生活片 | 成人久久毛片 | 天天草天天干天天射 | 三级午夜片| 久久少妇免费视频 | 精品久久久久久久久亚洲 | wwwwww色| 又黄又刺激 | 国产日韩精品在线观看 | 波多野结衣在线视频免费观看 | 亚洲劲爆av| 黄色免费在线看 | 亚洲成人黄色在线 | 在线97| 亚洲一区 影院 | 国产精品一区二区三区在线 | 国产精品高 | 久久精品成人 | 国产色拍拍拍拍在线精品 | 欧美日韩国产mv | 婷婷激情站 | 精品一区91 | 超碰在线亚洲 | 日韩一区正在播放 | 久久久久久久久久网 | 97超碰资源总站 | 911免费视频 | 午夜久久电影网 | 一级黄色免费网站 | 精品影院 | 午夜 久久 tv | 久久夜色精品国产亚洲aⅴ 91chinesexxx | 色偷偷88欧美精品久久久 | 婷婷国产一区二区三区 | 激情综合亚洲精品 | 久久有精品 | 精品久久免费看 | 在线观看的a站 | 四虎永久国产精品 | 国产成人久久精品 | 91在线看网站 | 色先锋资源网 | 国产精品国产三级在线专区 | 中文字幕 在线看 | 国产精品久久伊人 | 91视频 - 114av | 99re久久资源最新地址 | 久草在线视频免赞 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 久在线观看视频 | 国产手机在线观看 | 麻豆你懂的 | 精品国内自产拍在线观看视频 | 在线免费观看国产视频 | 色综合天天天天做夜夜夜夜做 | 麻豆久久精品 | 亚洲三级视频 | 日日夜夜噜噜噜 | 日韩视频在线观看免费 | 日韩av女优视频 | 欧美一级视频免费看 | 久久综合狠狠综合久久综合88 | 热久久在线视频 | 久久久国产精品免费 | 日韩av网站在线播放 | 丁香婷五月 | 夜夜躁狠狠躁 | 一区二区三区日韩视频在线观看 | 国产在线观看免 | 天天操狠狠操网站 | 夜夜操天天干 | 国产精品免费观看国产网曝瓜 | 毛片美女网站 | 精品毛片久久久久久 | 二区三区在线 | 欧美极品在线播放 | 在线观看免费黄视频 | 国语对白少妇爽91 | 欧美激情精品一区 | 男女拍拍免费视频 | 欧美日韩国产高清视频 | 在线观看av中文字幕 | 天天操天天综合网 | 91成人免费看片 | 黄色国产在线 | 欧美乱大交| 最近中文字幕在线 | 亚洲激情在线观看 | 日日躁天天躁 | 国产 日韩 欧美 在线 | 精品极品在线 | 国产精品入口66mio女同 | 国产精品免费观看在线 | 91av亚洲| 久久久久综合精品福利啪啪 | 久久久久99精品成人片三人毛片 | 日韩色综合网 | 国产手机视频在线 | 91成人免费视频 | 久久伊人操 | 国产精品黄色在线观看 | 日韩在线观看第一页 | 亚洲国产精品成人综合 | 99在线热播精品免费99热 | av手机版 | 国产精品精品国产婷婷这里av | 免费高清在线观看成人 | 久草在线视频首页 | 激情综合啪啪 | 国产精品美女网站 | 日韩欧美视频免费在线观看 | 中文字幕在线日本 | 日韩精品视频免费看 | 日韩欧美国产精品 | 亚洲精品国精品久久99热一 | 精品综合久久 | 亚洲精品美女在线 | 欧美视屏一区二区 | 日韩精品专区在线影院重磅 | 又爽又黄又刺激的视频 | 国产精品久久久久久久久久久久久 | av中文字幕在线免费观看 | 午夜精品久久久久99热app | 亚洲精品www. | 97日日碰人人模人人澡分享吧 | 三级动图| 日韩两性视频 | 国产精品一区二区三区久久 | 日韩欧美高清视频在线观看 | 中文字幕 国产精品 | 国产精品综合久久 | 一本一本久久aa综合精品 | 日韩精品三区四区 | 天天干夜夜夜 | av免费片| 国产中文字幕在线免费观看 | 99精品免费在线 | 九九三级毛片 | 九九热在线观看视频 | 婷婷视频在线 | 国产在线综合视频 | 一色屋精品视频在线观看 | 在线成人中文字幕 | 精品久久久久久久 | 久久精品艹 | 亚洲视频在线看 | 91精品视频在线观看免费 | 精品国产大片 | 亚洲综合黄色 | 片网址| 91黄视频在线 | 成人福利在线播放 | 精品国模一区二区 | 亚洲闷骚少妇在线观看网站 | 日韩欧美综合在线视频 | 久久色在线观看 | 亚洲国产精品资源 | 99免费精品视频 | 久久精品福利视频 | 婷婷av网站 | 国产精品国产毛片 | 天天射天天射天天 | 日韩av不卡在线播放 | 精品视频123区在线观看 | 国产精品毛片一区 | 久久久久视 | 精品久久网站 | 97视频资源 | 干干夜夜 | 日本黄色免费网站 | 欧美a√在线 | 免费黄色a网站 | 99视频+国产日韩欧美 | 欧美午夜精品久久久久久孕妇 | 成人av播放 | 国产视频日本 | 亚洲黄色在线免费观看 | 91精品视频免费 | 四虎永久视频 |