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

Golang map實(shí)踐及實(shí)現(xiàn)原理解析

 更新時(shí)間:2022年06月08日 09:36:05   作者:lzq  
這篇文章主要介紹了Golang map實(shí)踐以及實(shí)現(xiàn)原理,Go 語言中,通過哈希查找表實(shí)現(xiàn) map,用鏈表法解決哈希沖突,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧

Map實(shí)踐以及實(shí)現(xiàn)原理

使用實(shí)例內(nèi)存模型創(chuàng)建maphash函數(shù)key定位和碰撞解決擴(kuò)容元素訪問刪除迭代核心點(diǎn):

使用實(shí)例

測(cè)試的主要目的是對(duì)于map,當(dāng)作為函數(shù)傳參時(shí)候,函數(shù)內(nèi)部的改變會(huì)不會(huì)透?jìng)鞯酵獠?,以及函?shù)傳參內(nèi)外是不是一個(gè)map,也就是傳遞的是實(shí)例還是指針。(golang里面的傳參都是值傳遞)。

Test Case1:傳參為map。

func main(){
	fmt.Println("--------------- m ---------------")
	m := make(map[string]string)
	m["1"] = "0"
	fmt.Printf("m outer address %p, m=%v \n", m, m)
	passMap(m)
	fmt.Printf("post m outer address %p, m=%v \n", m, m)
}
func passMap(m map[string]string) {
	fmt.Printf("m inner address %p \n", m)
	m["11111111"] = "11111111"
	fmt.Printf("post m inner address %p \n", m)
}

運(yùn)行結(jié)果是:

--------------- m ---------------
m outer address 0xc0000b0000, m=map[1:0] 
m inner address 0xc0000b0000 
post m inner address 0xc0000b0000 
post m outer address 0xc0000b0000, m=map[1:0 11111111:11111111] 

從運(yùn)行結(jié)果我們可以知道:

當(dāng)傳參為map的時(shí)候,其實(shí)傳遞的是指針地址。函數(shù)內(nèi)外map的地址都是一樣的。函數(shù)內(nèi)部的改變會(huì)透?jìng)鞯胶瘮?shù)外部。

Test Case2:Test Case1的實(shí)現(xiàn)其實(shí)也有個(gè)特殊使用例子,也就是當(dāng)函數(shù)入?yún)ap沒有初始化的時(shí)候。

func main(){
	fmt.Println("--------------- m2 ---------------")
	var m2 map[string]string//未初始化
	fmt.Printf("m2 outer address %p, m=%v \n", m2, m2)
	passMapNotInit(m2)
	fmt.Printf("post m2 outer address %p, m=%v \n", m2, m2)
}
func passMapNotInit(m map[string]string)  {
	fmt.Printf("inner: %v, %p\n",m, m)
	m = make(map[string]string, 0)
	m["a"]="11"
	fmt.Printf("inner: %v, %p\n",m, m)
}

運(yùn)行結(jié)果是:

--------------- m2 ---------------
m2 outer address 0x0, m=map[] 
inner: map[], 0x0
inner: map[a:11], 0xc0000ac120
post m2 outer address 0x0, m=map[] 

從結(jié)果可以看出,當(dāng)入?yún)ap沒有初始化的時(shí)候,就不一樣了:

  • 沒有初始化的map地址都是0;
  • 函數(shù)內(nèi)部初始化map不會(huì)透?jìng)鞯酵獠縨ap。

其實(shí)也好理解,因?yàn)閙ap沒有初始化,所以map的地址傳遞到函數(shù)內(nèi)部之后初始化,會(huì)改變map的地址,但是外部地址不會(huì)改變。有一種方法,return 新建的map。

內(nèi)存模型

我這邊的源碼版本是:go 1.13

Golang的map從high level的角度來看,采用的是哈希表,并使用鏈表查找法解決沖突。但是golang的map實(shí)現(xiàn)在鏈表解決沖突時(shí)候有很多優(yōu)化,具體我們?cè)诤竺婵醇?xì)節(jié)。

數(shù)據(jù)結(jié)構(gòu)最能說明原理,我們先看map的數(shù)據(jù)結(jié)構(gòu):

// A header for a Go map.
type hmap struct {
	//map 中的元素個(gè)數(shù),必須放在 struct 的第一個(gè)位置,因?yàn)閮?nèi)置的 len 函數(shù)會(huì)通過unsafe.Pointer會(huì)從這里讀取
	count     int 
	flags     uint8
	// bucket的數(shù)量是2^B, 最多可以放 loadFactor * 2^B 個(gè)元素,再多就要 hashGrow 了
	B         uint8
	//overflow 的 bucket 近似數(shù)
	noverflow uint16
	hash0     uint32 // hash seed
	//2^B 大小的數(shù)組,如果 count == 0 的話,可能是 nil
	buckets    unsafe.Pointer 
	// 擴(kuò)容的時(shí)候,buckets 長(zhǎng)度會(huì)是 oldbuckets 的兩倍,只有在 growing 時(shí)候?yàn)榭铡?
	oldbuckets unsafe.Pointer
	// 指示擴(kuò)容進(jìn)度,小于此地址的 buckets 遷移完成
	nevacuate  uintptr // progress counter for evacuation (buckets less than this have been evacuated)
	// 當(dāng) key 和 value 都可以 inline 的時(shí)候,就會(huì)用這個(gè)字段
	extra *mapextra // optional fields 
}

這里B是map的bucket數(shù)組長(zhǎng)度的對(duì)數(shù),每個(gè)bucket里面存儲(chǔ)了kv對(duì)。buckets是一個(gè)指針,指向?qū)嶋H存儲(chǔ)的bucket數(shù)組的首地址。 bucket的結(jié)構(gòu)體如下:

type bmap struct {
	// tophash generally contains the top byte of the hash value
	// for each key in this bucket. If tophash[0] < minTopHash,
	// tophash[0] is a bucket evacuation state instead.
	tophash [bucketCnt]uint8
	// Followed by bucketCnt keys and then bucketCnt elems.
	// NOTE: packing all the keys together and then all the elems together makes the
	// code a bit more complicated than alternating key/elem/key/elem/... but it allows
	// us to eliminate padding which would be needed for, e.g., map[int64]int8.
	// Followed by an overflow pointer.
}

上面這個(gè)數(shù)據(jù)結(jié)構(gòu)并不是 golang runtime 時(shí)的結(jié)構(gòu),在編譯時(shí)候編譯器會(huì)給它動(dòng)態(tài)創(chuàng)建一個(gè)新的結(jié)構(gòu),如下:

type bmap struct {
    topbits  [8]uint8
    keys     [8]keytype
    values   [8]valuetype
    pad      uintptr
    overflow uintptr
}

bmap 就是我們常說的“bucket”結(jié)構(gòu),每個(gè) bucket 里面最多存儲(chǔ) 8 個(gè) key,這些 key 之所以會(huì)落入同一個(gè)桶,是因?yàn)樗鼈兘?jīng)過哈希計(jì)算后,哈希結(jié)果是“一類”的。在桶內(nèi),又會(huì)根據(jù) key 計(jì)算出來的 hash 值的高 8 位來決定 key 到底落入桶內(nèi)的哪個(gè)位置(一個(gè)桶內(nèi)最多有8個(gè)位置)。

這里引用網(wǎng)絡(luò)上的一張圖:

當(dāng) map 的 key 和 value 都不是指針,并且 size 都小于 128 字節(jié)的情況下,會(huì)把 bmap 標(biāo)記為不含指針,這樣可以避免 gc 時(shí)掃描整個(gè) hmap。但是,我們看 bmap 其實(shí)有一個(gè) overflow 的字段,是指針類型的,破壞了 bmap 不含指針的設(shè)想,這時(shí)會(huì)把 overflow 移動(dòng)到 extra 字段來。

// mapextra holds fields that are not present on all maps.
type mapextra struct {
	// If both key and elem do not contain pointers and are inline, then we mark bucket
	// type as containing no pointers. This avoids scanning such maps.
	// However, bmap.overflow is a pointer. In order to keep overflow buckets
	// alive, we store pointers to all overflow buckets in hmap.extra.overflow and hmap.extra.oldoverflow.
	// overflow and oldoverflow are only used if key and elem do not contain pointers.
	// overflow contains overflow buckets for hmap.buckets.
	// oldoverflow contains overflow buckets for hmap.oldbuckets.
	// The indirection allows to store a pointer to the slice in hiter.
	overflow    *[]*bmap
	oldoverflow *[]*bmap

	// nextOverflow holds a pointer to a free overflow bucket.
	nextOverflow *bmap
}

bmap 是存放 k-v 的地方,我們看看bmap詳細(xì)的存儲(chǔ)分布細(xì)節(jié):

上圖就是 bucket 的內(nèi)存模型,HOB Hash 指的就是 top hash字段。我們可以看到bucket的kv分布分開的,沒有按照我們常規(guī)的kv/kv/kv…這種。源碼里說明這樣的好處是在某些情況下可以省略掉 padding 字段,節(jié)省內(nèi)存空間。

比如: map[int64]int8

如果按照 key/value/key/value/… 這樣的模式存儲(chǔ),那在每一個(gè) key/value pair 之后都要額外 padding 7 個(gè)字節(jié);而將所有的 key,value 分別綁定到一起,這種形式 key/key/…/value/value/…,則只需要在最后添加 padding。

每個(gè) bucket 設(shè)計(jì)成最多只能放 8 個(gè) key-value 對(duì),如果有第 9 個(gè) key-value 落入當(dāng)前的 bucket,那就需要再構(gòu)建一個(gè) bucket ,通過 overflow 指針連接起來。

創(chuàng)建map

map的創(chuàng)建非常簡(jiǎn)單,比如下面的語句:

m := make(map[string]string)
// 指定 map 長(zhǎng)度
m := make(map[string]string, 10)

make函數(shù)實(shí)際上會(huì)被編譯器定位到調(diào)用 runtime.makemap(),主要做的工作就是初始化 hmap 結(jié)構(gòu)體的各種字段,例如計(jì)算 B 的大小,設(shè)置哈希種子 hash0 等等。

// 這里的hint就是我們 make 時(shí)候后面指定的初始化長(zhǎng)度.
func makemap(t *maptype, hint int, h *hmap) *hmap {
	//......省略各種檢查的邏輯
	
	// 找到一個(gè) B,使得 map 的裝載因子在正常范圍內(nèi)。
	B := uint8(0)
	for overLoadFactor(hint, B) {
		B++
	}
	h.B = B

	// 初始化 hash table
	// 如果 B 等于 0,那么 buckets 就會(huì)在賦值的時(shí)候再分配
	// 如果長(zhǎng)度比較大,分配內(nèi)存會(huì)花費(fèi)長(zhǎng)一點(diǎn)
	if h.B != 0 {
		var nextOverflow *bmap
		h.buckets, nextOverflow = makeBucketArray(t, h.B, nil)
		if nextOverflow != nil {
			h.extra = new(mapextra)
			h.extra.nextOverflow = nextOverflow
		}
	}

	return h
}

注意,這個(gè)函數(shù)返回的結(jié)果:*hmap 是一個(gè)指針,而我們之前講過的 makeslice 函數(shù)返回的是 Slice 結(jié)構(gòu)體對(duì)象。這也是 makemap 和 makeslice 返回值的區(qū)別所帶來一個(gè)不同點(diǎn):當(dāng) map 和 slice 作為函數(shù)參數(shù)時(shí),在函數(shù)參數(shù)內(nèi)部對(duì) map 的操作會(huì)影響 map 自身;而對(duì) slice 卻不會(huì)(之前講 slice 的文章里有講過)。

主要原因:一個(gè)是指針(*hmap),一個(gè)是結(jié)構(gòu)體(slice)。Go 語言中的函數(shù)傳參都是值傳遞,在函數(shù)內(nèi)部,參數(shù)會(huì)被 copy 到本地。*hmap指針 copy 完之后,仍然指向同一個(gè) map,因此函數(shù)內(nèi)部對(duì) map 的操作會(huì)影響實(shí)參。而 slice 被 copy 后,會(huì)成為一個(gè)新的 slice,對(duì)它進(jìn)行的操作不會(huì)影響到實(shí)參。

hash函數(shù)

關(guān)于hash函數(shù)的細(xì)節(jié),這里就不介紹了。這里需要重點(diǎn)提示的是,哈希函數(shù)的算法與key的類型一一對(duì)應(yīng)的。根據(jù) key 的類型, maptype結(jié)構(gòu)體的 key字段的alg 字段會(huì)被設(shè)置對(duì)應(yīng)類型的 hash 和 equal 函數(shù)。

key定位和碰撞解決

對(duì)于 hashmap 來說,最重要的就是根據(jù)key定位實(shí)際存儲(chǔ)位置。key 經(jīng)過哈希計(jì)算后得到哈希值,哈希值是 64 個(gè) bit 位(針對(duì)64位機(jī))。根據(jù)hash值的最后B個(gè)bit位來確定這個(gè)key落在哪個(gè)桶。如果 B = 5,那么桶的數(shù)量,也就是 buckets 數(shù)組的長(zhǎng)度是 2^5 = 32。

suppose,現(xiàn)在有一個(gè) key 經(jīng)過哈希函數(shù)計(jì)算后,得到的哈希結(jié)果是:

10010111 | 000011110110110010001111001010100010010110010101010 │ 01010

用最后的 5 個(gè) bit 位,也就是 01010,值為 10,也就是 10 號(hào)桶。這個(gè)操作實(shí)際上就是取余操作,但是取余開銷太大,所以代碼實(shí)現(xiàn)上用的位操作代替。

再用哈希值的高 8 位,找到此 key 在 bucket 中的位置,這是在尋找已有的 key。最開始桶內(nèi)還沒有 key,新加入的 key 會(huì)找到第一個(gè)空位,放入。

buckets 編號(hào)就是桶編號(hào),當(dāng)兩個(gè)不同的 key 落在同一個(gè)桶中,也就是發(fā)生了哈希沖突。沖突的解決手段是用鏈表法:在 bucket 中,從前往后找到第一個(gè)空位。這樣,在查找某個(gè) key 時(shí),先找到對(duì)應(yīng)的桶,再去遍歷 bucket 中的 key。

下面是檢索的示意圖:


上圖中,假定 B = 5,所以 bucket 總數(shù)就是 2^5 = 32。首先計(jì)算出待查找 key 的哈希,使用低 5 位 00110,找到對(duì)應(yīng)的 6 號(hào) bucket,使用高 8 位 10010111,對(duì)應(yīng)十進(jìn)制 151,在 6 號(hào) bucket 中 遍歷bucket 尋找 tophash 值(HOB hash)為 151 的 key,找到了 2 號(hào)槽位,這樣整個(gè)查找過程就結(jié)束了。

如果在 bucket 中沒找到,并且 overflow 不為空,還要繼續(xù)去 overflow bucket 中尋找,直到找到或是所有的 key 槽位都找遍了,包括所有的 overflow bucket。(這里需要遍歷bucket數(shù)組中某個(gè)槽位的bucket鏈表的所有bucket)

下面我們通過源碼驗(yàn)證:

// mapaccess1 returns a pointer to h[key].  Never returns nil, instead
// it will return a reference to the zero object for the elem type if
// the key is not in the map.
func mapaccess1(t *maptype, h *hmap, key unsafe.Pointer) unsafe.Pointer {
	//......校驗(yàn)邏輯
	
	//如果 h 什么都沒有,返回value類型的零值
	if h == nil || h.count == 0 {
		if t.hashMightPanic() {
			t.key.alg.hash(key, 0) // see issue 23734
		}
		return unsafe.Pointer(&zeroVal[0])
	}
	
	// 并發(fā)寫沖突
	if h.flags&hashWriting != 0 {
		throw("concurrent map read and map write")
	}
	// 不同類型 key 使用的 hash 算法在編譯期確定
	alg := t.key.alg
	hash := alg.hash(key, uintptr(h.hash0))
	
	// 求低 B 位的掩碼.
	// 比如 B=5,那 m 就是31,低五位二進(jìn)制是全1
	m := bucketMask(h.B)
	// b 就是 當(dāng)前key對(duì)應(yīng)的 bucket 的地址
	b := (*bmap)(add(h.buckets, (hash&m)*uintptr(t.bucketsize)))
	// oldbuckets 不為 nil,說明發(fā)生了擴(kuò)容
	if c := h.oldbuckets; c != nil {
		if !h.sameSizeGrow() {
			// There used to be half as many buckets; mask down one more power of two.
			m >>= 1
		}
		// 求出 key 在老的 map 中的 bucket 位置
		oldb := (*bmap)(add(c, (hash&m)*uintptr(t.bucketsize)))
		// 如果 oldb 沒有搬遷到新的 bucket
		// 那就在老的 bucket 中尋找
		if !evacuated(oldb) {
			b = oldb
		}
	}
	// 計(jì)算出高 8 位的 hash
	// 相當(dāng)于右移 56 位,只取高8位
	top := tophash(hash)

// 這里進(jìn)入bucket的二層循環(huán)找到對(duì)應(yīng)的kv(第一層是bucket,第二層是bucket內(nèi)部的8個(gè)slot)
bucketloop:
	// 遍歷bucket以及overflow鏈表
	for ; b != nil; b = b.overflow(t) {
		//遍歷bucket的8個(gè)slot
		for i := uintptr(0); i < bucketCnt; i++ {
			// tophash 不匹配
			if b.tophash[i] != top {
				// 標(biāo)識(shí)當(dāng)前bucket剩下的slot都是empty
				if b.tophash[i] == emptyRest {
					break bucketloop
				}
				continue
			}
			// 獲取bucket的key
			k := add(unsafe.Pointer(b), dataOffset+i*uintptr(t.keysize))
			if t.indirectkey() {
				k = *((*unsafe.Pointer)(k))
			}
			if alg.equal(key, k) {
				//定位到 value 的位置
				e := add(unsafe.Pointer(b), dataOffset+bucketCnt*uintptr(t.keysize)+i*uintptr(t.elemsize))
				// value 解引用
				if t.indirectelem() {
					e = *((*unsafe.Pointer)(e))
				}
				return e
			}
		}
	}
	// overflow bucket 也找完了,說明沒有目標(biāo) key
	// 返回零值
	return unsafe.Pointer(&zeroVal[0])
}

函數(shù)返回 h[key] 的指針,如果 h 中沒有此 key,那就會(huì)返回一個(gè) key 相應(yīng)類型的零值,不會(huì)返回 nil。

代碼整體比較直接,沒什么難懂的地方。跟著上面的注釋一步步理解就好了。

這里,說一下定位 key 和 value 的方法以及整個(gè)循環(huán)的寫法。

// key 定位公式
k := add(unsafe.Pointer(b), dataOffset+i*uintptr(t.keysize))

// value 定位公式
v := add(unsafe.Pointer(b), dataOffset+bucketCnt*uintptr(t.keysize)+i*uintptr(t.valuesize))

b 是 bmap 的地址,這里 bmap 還是源碼里定義的結(jié)構(gòu)體,只包含一個(gè) tophash 數(shù)組,經(jīng)編譯器擴(kuò)充之后的結(jié)構(gòu)體才包含 key,value,overflow 這些字段。dataOffset 是 key 相對(duì)于 bmap 起始地址的偏移:

dataOffset = unsafe.Offsetof(struct {
		b bmap
		v int64
	}{}.v)

因此 bucket 里 key 的起始地址就是 unsafe.Pointer(b)+dataOffset。第 i 個(gè) key 的地址就要在此基礎(chǔ)上跨過 i 個(gè) key 的大??;而我們又知道,value 的地址是在所有 key 之后,因此第 i 個(gè) value 的地址還需要加上所有 key 的偏移。理解了這些,上面 key 和 value 的定位公式就很好理解了。

當(dāng)定位到一個(gè)具體的 bucket 時(shí),里層循環(huán)就是遍歷這個(gè) bucket 里所有的 cell,或者說所有的槽位,也就是 bucketCnt=8 個(gè)槽位。整個(gè)循環(huán)過程:

再說一下 minTopHash,當(dāng)一個(gè) cell 的 tophash 值小于 minTopHash 時(shí),標(biāo)志這個(gè) cell 的遷移狀態(tài)。因?yàn)檫@個(gè)狀態(tài)值是放在 tophash 數(shù)組里,為了和正常的哈希值區(qū)分開,會(huì)給 key 計(jì)算出來的哈希值一個(gè)增量:minTopHash。這樣就能區(qū)分正常的 top hash 值和表示狀態(tài)的哈希值。

下面的這幾種狀態(tài)就表征了 bucket 的情況:

emptyRest      = 0 // this cell is empty, and there are no more non-empty cells at higher indexes or overflows.
emptyOne       = 1 // this cell is empty
// 擴(kuò)容相關(guān)
evacuatedX     = 2 // key/elem is valid.  Entry has been evacuated to first half of larger table.
// 擴(kuò)容相關(guān)
evacuatedY     = 3 // same as above, but evacuated to second half of larger table.
evacuatedEmpty = 4 // cell is empty, bucket is evacuated.
minTopHash     = 5 // minimum tophash for a normal filled cell.

源碼里判斷這個(gè) bucket 是否已經(jīng)搬遷完畢,用到的函數(shù):

func evacuated(b *bmap) bool {
	h := b.tophash[0]
	return h > emptyOne && h < minTopHash
}

只取了 tophash 數(shù)組的第一個(gè)值,判斷它是否在 1-5 之間。對(duì)比上面的常量,當(dāng) top hash 是 evacuatedEmpty、evacuatedX、evacuatedY 這三個(gè)值之一,說明此 bucket 中的 key 全部被搬遷到了新 bucket。

擴(kuò)容

使用 key 的 hash 值可以快速定位到目標(biāo) key,然而,隨著向 map 中添加的 key 越來越多,key 發(fā)生碰撞的概率也越來越大。bucket 中的 8 個(gè) cell 會(huì)被逐漸塞滿,查找、插入、刪除 key 的效率也會(huì)越來越低。最理想的情況是一個(gè) bucket 只裝一個(gè) key,這樣,就能達(dá)到 O(1) 的效率,但這樣空間消耗太大,用空間換時(shí)間的代價(jià)太高。

Go 語言采用一個(gè) bucket 里裝載 8 個(gè) key,定位到某個(gè) bucket 后,還需要再定位到具體的 key,這實(shí)際上又用了時(shí)間換空間。

當(dāng)然,這樣做,要有一個(gè)度,不然所有的 key 都落在了同一個(gè) bucket 里,直接退化成了鏈表,各種操作的效率直接降為 O(n),是不行的。

因此,需要有一個(gè)指標(biāo)來衡量前面描述的情況,這就是裝載因子。Go 源碼里這樣定義 裝載因子:

loadFactor := count / (2^B)

count 就是 map 的元素個(gè)數(shù),2^B 表示 bucket 數(shù)量。

再來說觸發(fā) map 擴(kuò)容的時(shí)機(jī):在向 map 插入新 key 的時(shí)候,會(huì)進(jìn)行條件檢測(cè),符合下面這 2 個(gè)條件,就會(huì)觸發(fā)擴(kuò)容:

載因子超過閾值,源碼里定義的閾值是 6.5。overflow 的 bucket 數(shù)量過多,這有兩種情況:(1)當(dāng) B 大于15時(shí),也就是 bucket 總數(shù)大于 2^15 時(shí),如果overflow的bucket數(shù)量大于2^15,就觸發(fā)擴(kuò)容。(2)當(dāng)B小于15時(shí),如果overflow的bucket數(shù)量大于2^B 也會(huì)觸發(fā)擴(kuò)容。

通過匯編語言可以找到賦值操作對(duì)應(yīng)源碼中的函數(shù)是 mapassign,對(duì)應(yīng)擴(kuò)容條件的源碼如下:

// src/runtime/hashmap.go/mapassign

// 觸發(fā)擴(kuò)容時(shí)機(jī)
if !h.growing() && (overLoadFactor(h.count+1, h.B) || tooManyOverflowBuckets(h.noverflow, h.B)) {
	hashGrow(t, h)
	goto again // Growing the table invalidates everything, so try again
}

// overLoadFactor reports whether count items placed in 1<<B buckets is over loadFactor.
// 裝載因子超過 6.5
func overLoadFactor(count int, B uint8) bool {
	return count > bucketCnt && uintptr(count) > loadFactorNum*(bucketShift(B)/loadFactorDen)
}

// tooManyOverflowBuckets reports whether noverflow buckets is too many for a map with 1<<B buckets.
// Note that most of these overflow buckets must be in sparse use;
// if use was dense, then we'd have already triggered regular map growth.
func tooManyOverflowBuckets(noverflow uint16, B uint8) bool {
	// If the threshold is too low, we do extraneous work.
	// If the threshold is too high, maps that grow and shrink can hold on to lots of unused memory.
	// "too many" means (approximately) as many overflow buckets as regular buckets.
	// See incrnoverflow for more details.
	if B > 15 {
		B = 15
	}
	// The compiler doesn't see here that B < 16; mask B to generate shorter shift code.
	// overflow buckets 太多
	return noverflow >= uint16(1)<<(B&15)
}

這里解釋一下這種觸發(fā)擴(kuò)容的原理:

第 1 點(diǎn):我們知道,每個(gè) bucket 有 8 個(gè)空位,在沒有溢出,且所有的桶都裝滿了的情況下,裝載因子算出來的結(jié)果是 8。因此當(dāng)裝載因子超過 6.5 時(shí),表明很多 bucket 都快要裝滿了,查找效率和插入效率都變低了。在這個(gè)時(shí)候進(jìn)行擴(kuò)容是有必要的。

第 2 點(diǎn):是對(duì)第 1 點(diǎn)的補(bǔ)充。就是說在裝載因子比較小的情況下,這時(shí)候 map 的查找和插入效率也很低,而第 1 點(diǎn)識(shí)別不出來這種情況。表面現(xiàn)象就是計(jì)算裝載因子的分子比較小,即 map 里元素總數(shù)少,但是 bucket 數(shù)量多(真實(shí)分配的 bucket 數(shù)量多,包括大量的 overflow bucket)。

不難想像造成這種情況的原因:不停地插入、刪除元素。先插入很多元素,導(dǎo)致創(chuàng)建了很多 bucket,但是裝載因子達(dá)不到第 1 點(diǎn)的臨界值,未觸發(fā)擴(kuò)容來緩解這種情況。之后,刪除元素降低元素總數(shù)量,再插入很多元素,導(dǎo)致創(chuàng)建很多的 overflow bucket,但就是不會(huì)觸犯第 1 點(diǎn)的規(guī)定,你能拿我怎么辦?**overflow bucket 數(shù)量太多,導(dǎo)致 key 會(huì)很分散,查找插入效率低得嚇人,**因此出臺(tái)第 2 點(diǎn)規(guī)定。這就像是一座空城,房子很多,但是住戶很少,都分散了,找起人來很困難。

對(duì)于命中條件 1,2 的限制,都會(huì)發(fā)生擴(kuò)容。但是擴(kuò)容的策略并不相同,畢竟兩種條件應(yīng)對(duì)的場(chǎng)景不同。

對(duì)于條件 1,元素太多,而 bucket 數(shù)量太少,很簡(jiǎn)單:將 B 加 1,bucket 最大數(shù)量 (2^B) 直接變成原來 bucket 數(shù)量的 2 倍。于是,就有新老 bucket 了。注意,這時(shí)候元素都在老 bucket 里,還沒遷移到新的 bucket 來。而且,新 bucket 只是最大數(shù)量變?yōu)樵瓉碜畲髷?shù)量(2^B)的 2 倍(2^B * 2)。

對(duì)于條件 2,其實(shí)元素沒那么多,但是 overflow bucket 數(shù)特別多,說明很多 bucket 都沒裝滿。解決辦法就是開辟一個(gè)新 bucket 空間,將老 bucket 中的元素移動(dòng)到新 bucket,使得同一個(gè) bucket 中的 key 排列地更緊密。這樣,原來,在 overflow bucket 中的 key 可以移動(dòng)到 bucket 中來。結(jié)果是節(jié)省空間,提高 bucket 利用率,map 的查找和插入效率自然就會(huì)提升。

對(duì)于條件 2 的解決方案,有一個(gè)極端的情況:如果插入 map 的 key 哈希都一樣,就會(huì)落到同一個(gè) bucket 里,超過 8 個(gè)就會(huì)產(chǎn)生 overflow bucket,結(jié)果也會(huì)造成 overflow bucket 數(shù)過多。移動(dòng)元素其實(shí)解決不了問題,因?yàn)檫@時(shí)整個(gè)哈希表已經(jīng)退化成了一個(gè)鏈表,操作效率變成了 O(n)。

前面說了擴(kuò)容的條件,下面看一下擴(kuò)容到底是怎么做的:由于 map 擴(kuò)容需要將原有的 key/value 重新搬遷到新的內(nèi)存地址,如果有大量的 key/value 需要搬遷,在搬遷過程中map會(huì)阻塞,非常影響性能。因此 Go map 的擴(kuò)容采取了一種稱為 “漸進(jìn)式” 的方式,原有的 key 并不會(huì)一次性搬遷完畢,每次最多只會(huì)搬遷 2 個(gè)bucket。

上面說的 hashGrow() 函數(shù)實(shí)際上并沒有真正地“搬遷”,它只是分配好了新的 buckets,并將老的 buckets 掛到了新的map的 oldbuckets 字段上。真正搬遷 buckets 的動(dòng)作在 growWork() 函數(shù)中,而調(diào)用 growWork() 函數(shù)的動(dòng)作是在 mapassignmapdelete 函數(shù)中。也就是插入或修改、刪除 key 的時(shí)候,都會(huì)嘗試進(jìn)行搬遷 buckets 的工作。先檢查 oldbuckets 是否搬遷完畢,具體來說就是檢查 oldbuckets 是否為 nil。

我們先看 hashGrow() 函數(shù)所做的工作,再來看具體的搬遷 buckets 是如何進(jìn)行的。

func hashGrow(t *maptype, h *hmap) {
	// B+1 相當(dāng)于是原來 2 倍的空間
	bigger := uint8(1)
	
	// 對(duì)應(yīng)于等容擴(kuò)容
	if !overLoadFactor(h.count+1, h.B) {
		// 進(jìn)行等量的內(nèi)存擴(kuò)容,所以 B 不變
		bigger = 0
		h.flags |= sameSizeGrow
	}
	oldbuckets := h.buckets
	// 申請(qǐng)新的 buckets 空間
	newbuckets, nextOverflow := makeBucketArray(t, h.B+bigger, nil)

	flags := h.flags &^ (iterator | oldIterator)
	if h.flags&iterator != 0 {
		flags |= oldIterator
	}
	// commit the grow (atomic wrt gc)
	h.B += bigger
	h.flags = flags
	h.oldbuckets = oldbuckets
	h.buckets = newbuckets
	// 當(dāng)前搬遷進(jìn)度為0
	h.nevacuate = 0
	h.noverflow = 0

	//......
}

主要是申請(qǐng)到了新的 buckets 空間,把相關(guān)的標(biāo)志位都進(jìn)行了處理:例如標(biāo)志 nevacuate 被置為 0, 表示當(dāng)前搬遷進(jìn)度為 0。

需要特別提一下的是h.flags的操作:

flags := h.flags &^ (iterator | oldIterator)
if h.flags&iterator != 0 {
	flags |= oldIterator
}

這里得先說下運(yùn)算符:&^。這叫按位置 0運(yùn)算符。例如:

x = 01010011
y = 01010100
z = x &^ y = 00000011

如果 y bit 位為 1,那么結(jié)果 z 對(duì)應(yīng) bit 位就為 0,否則 z 對(duì)應(yīng) bit 位就和 x 對(duì)應(yīng) bit 位的值相同。

所以上面那段對(duì) flags 一頓操作的代碼的意思是:先把 h.flags 中 iterator 和 oldIterator 對(duì)應(yīng)位清 0,然后如果發(fā)現(xiàn) iterator 位為 1,那就把它轉(zhuǎn)接到 oldIterator 位,使得 oldIterator 標(biāo)志位變成 1。潛臺(tái)詞就是:buckets 現(xiàn)在掛到了 oldBuckets 名下了,對(duì)應(yīng)的標(biāo)志位也轉(zhuǎn)接過去。

幾個(gè)標(biāo)志位如下:

// 可能有迭代器使用 buckets
iterator     = 1
// 可能有迭代器使用 oldbuckets
oldIterator  = 2
// 有協(xié)程正在并發(fā)的向 map 中寫入 key
hashWriting  = 4
// 等量擴(kuò)容(對(duì)應(yīng)條件 2)
sameSizeGrow = 8

再來看看真正執(zhí)行搬遷工作的 growWork() 函數(shù)。

func growWork(t *maptype, h *hmap, bucket uintptr) {
	// 確認(rèn)搬遷老的 bucket 對(duì)應(yīng)正在使用的 bucket
	evacuate(t, h, bucket&h.oldbucketmask())

	// 再搬遷一個(gè) bucket,以加快搬遷進(jìn)程
	if h.growing() {
		evacuate(t, h, h.nevacuate)
	}
}

h.growing() 函數(shù)非常簡(jiǎn)單:

func (h *hmap) growing() bool {
	return h.oldbuckets != nil
}

如果 oldbuckets 不為空,說明還沒有搬遷完畢,還得繼續(xù)搬。

bucket&h.oldbucketmask() 這行代碼,如源碼注釋里說的,是為了確認(rèn)搬遷的 bucket 是我們正在使用的 bucket。oldbucketmask() 函數(shù)返回?cái)U(kuò)容前的 map 的 bucketmask。

所謂的 bucketmask,作用就是將 key 計(jì)算出來的哈希值與 bucketmask 相&,得到的結(jié)果就是 key 應(yīng)該落入的桶。比如 B = 5,那么 bucketmask 的低 5 位是 11111,其余位是 0,hash 值與其相與的意思是,只有 hash 值的低 5 位決策 key 到底落入哪個(gè) bucket。

接下來,重點(diǎn)放在搬遷的關(guān)鍵函數(shù) evacuate。源碼如下:

// oldbucket是
func evacuate(t *maptype, h *hmap, oldbucket uintptr) {
	//  獲取old bucket 的地址
	b := (*bmap)(add(h.oldbuckets, oldbucket*uintptr(t.bucketsize)))
	newbit := h.noldbuckets()
	if !evacuated(b) {
		// TODO: reuse overflow buckets instead of using new ones, if there
		// is no iterator using the old buckets.  (If !oldIterator.)

		// xy contains the x and y (low and high) evacuation destinations.
		// X和Y分別代表,如果是2倍擴(kuò)容時(shí),對(duì)應(yīng)的前半部分和后半部分
		var xy [2]evacDst
		x := &xy[0]
		// 默認(rèn)是等 size 擴(kuò)容,前后 bucket 序號(hào)不變
		x.b = (*bmap)(add(h.buckets, oldbucket*uintptr(t.bucketsize)))
		x.k = add(unsafe.Pointer(x.b), dataOffset)
		x.e = add(x.k, bucketCnt*uintptr(t.keysize))
		
		if !h.sameSizeGrow() {
			// Only calculate y pointers if we're growing bigger.
			// Otherwise GC can see bad pointers.
			// 如果不是等 size 擴(kuò)容,前后 bucket 序號(hào)有變
			// 使用 y 來進(jìn)行搬遷
			y := &xy[1]
			y.b = (*bmap)(add(h.buckets, (oldbucket+newbit)*uintptr(t.bucketsize)))
			y.k = add(unsafe.Pointer(y.b), dataOffset)
			y.e = add(y.k, bucketCnt*uintptr(t.keysize))
		}
		// 遍歷所有的 bucket,包括 overflow buckets
		// b 是老的 bucket 地址
		for ; b != nil; b = b.overflow(t) {
			k := add(unsafe.Pointer(b), dataOffset)
			e := add(k, bucketCnt*uintptr(t.keysize))
			for i := 0; i < bucketCnt; i, k, e = i+1, add(k, uintptr(t.keysize)), add(e, uintptr(t.elemsize)) {
				// 當(dāng)前 cell 的 top hash 值
				top := b.tophash[i]
				// 如果 cell 為空,即沒有 key
				if isEmpty(top) {
					b.tophash[i] = evacuatedEmpty
					continue
				}
				// 正常不會(huì)出現(xiàn)這種情況
				// 未被搬遷的 cell 只可能是 empty 或是
				// 正常的 top hash(大于 minTopHash)
				if top < minTopHash {
					throw("bad map state")
				}
				k2 := k
				if t.indirectkey() {
					k2 = *((*unsafe.Pointer)(k2))
				}
				var useY uint8
				// 如果不是等量擴(kuò)容,說明要移動(dòng)到Y(jié) part
				if !h.sameSizeGrow() {
					// Compute hash to make our evacuation decision (whether we need
					// to send this key/elem to bucket x or bucket y).
					hash := t.key.alg.hash(k2, uintptr(h.hash0))
					// // 如果有協(xié)程正在遍歷 map 且出現(xiàn) 相同的 key 值,算出來的 hash 值不同
					if h.flags&iterator != 0 && !t.reflexivekey() && !t.key.alg.equal(k2, k2) {
						// If key != key (NaNs), then the hash could be (and probably
						// will be) entirely different from the old hash. Moreover,
						// it isn't reproducible. Reproducibility is required in the
						// presence of iterators, as our evacuation decision must
						// match whatever decision the iterator made.
						// Fortunately, we have the freedom to send these keys either
						// way. Also, tophash is meaningless for these kinds of keys.
						// We let the low bit of tophash drive the evacuation decision.
						// We recompute a new random tophash for the next level so
						// these keys will get evenly distributed across all buckets
						// after multiple grows.
						useY = top & 1
						top = tophash(hash)
					} else {
						if hash&newbit != 0 {
							useY = 1
						}
					}
				}

				if evacuatedX+1 != evacuatedY || evacuatedX^1 != evacuatedY {
					throw("bad evacuatedN")
				}

				b.tophash[i] = evacuatedX + useY // evacuatedX + 1 == evacuatedY
				// 找到實(shí)際的目的bucket.
				dst := &xy[useY]                 // evacuation destination

				if dst.i == bucketCnt {
					dst.b = h.newoverflow(t, dst.b)
					dst.i = 0
					dst.k = add(unsafe.Pointer(dst.b), dataOffset)
					dst.e = add(dst.k, bucketCnt*uintptr(t.keysize))
				}
				dst.b.tophash[dst.i&(bucketCnt-1)] = top // mask dst.i as an optimization, to avoid a bounds check
				// 執(zhí)行實(shí)際的復(fù)制操作.
				if t.indirectkey() {
					*(*unsafe.Pointer)(dst.k) = k2 // copy pointer
				} else {
					typedmemmove(t.key, dst.k, k) // copy elem
				}
				if t.indirectelem() {
					*(*unsafe.Pointer)(dst.e) = *(*unsafe.Pointer)(e)
				} else {
					typedmemmove(t.elem, dst.e, e)
				}
				// 定位到下一個(gè) cell
				dst.i++
				// These updates might push these pointers past the end of the
				// key or elem arrays.  That's ok, as we have the overflow pointer
				// at the end of the bucket to protect against pointing past the
				// end of the bucket.
				dst.k = add(dst.k, uintptr(t.keysize))
				dst.e = add(dst.e, uintptr(t.elemsize))
			}
		}
		// 如果沒有協(xié)程在使用老的 buckets,就把老 buckets 清除掉,幫助gc
		if h.flags&oldIterator == 0 && t.bucket.ptrdata != 0 {
			b := add(h.oldbuckets, oldbucket*uintptr(t.bucketsize))
			// Preserve b.tophash because the evacuation
			// state is maintained there.
			ptr := add(b, dataOffset)
			n := uintptr(t.bucketsize) - dataOffset
			memclrHasPointers(ptr, n)
		}
	}

	if oldbucket == h.nevacuate {
		advanceEvacuationMark(h, t, newbit)
	}
}

搬遷的目的就是將老的 buckets 搬遷到新的 buckets。而通過前面的說明我們知道,應(yīng)對(duì)條件 1,新的 buckets 數(shù)量是之前的一倍,應(yīng)對(duì)條件 2,新的 buckets 數(shù)量和之前相等。

對(duì)于條件 1,從老的 buckets 搬遷到新的 buckets,由于 bucktes 數(shù)量不變,因此可以按序號(hào)來搬,比如原來在 0 號(hào) bucktes,到新的地方后,仍然放在 0 號(hào) buckets。

對(duì)于條件 2,就沒這么簡(jiǎn)單了。要重新計(jì)算 key 的哈希,才能決定它到底落在哪個(gè) bucket。例如,原來 B = 5,計(jì)算出 key 的哈希后,只用看它的低 5 位,就能決定它落在哪個(gè) bucket。擴(kuò)容后,B 變成了 6,因此需要多看一位,它的低 6 位決定 key 落在哪個(gè) bucket。這稱為 rehash。


因此,某個(gè) key 在搬遷前后 bucket 序號(hào)可能和原來相等,也可能是相比原來加上 2^B(原來的 B 值),取決于 hash 值 第 6 bit 位是 0 還是 1。

理解了上面 bucket 序號(hào)的變化,我們就可以回答另一個(gè)問題了:為什么遍歷 map 是無序的?

map 在擴(kuò)容后,會(huì)發(fā)生 key 的搬遷,原來落在同一個(gè) bucket 中的 key,搬遷后,有些 key 就要遠(yuǎn)走高飛了(bucket 序號(hào)加上了 2^B)。而遍歷的過程,就是按順序遍歷 bucket,同時(shí)按順序遍歷 bucket 中的 key。搬遷后,key 的位置發(fā)生了重大的變化,有些 key 飛上高枝,有些 key 則原地不動(dòng)。這樣,遍歷 map 的結(jié)果就不可能按原來的順序了。

當(dāng)然,如果我就一個(gè) hard code 的 map,我也不會(huì)向 map 進(jìn)行插入刪除的操作,按理說每次遍歷這樣的 map 都會(huì)返回一個(gè)固定順序的 key/value 序列吧。的確是這樣,但是 Go 杜絕了這種做法,因?yàn)檫@樣會(huì)給新手程序員帶來誤解,以為這是一定會(huì)發(fā)生的事情,在某些情況下,可能會(huì)釀成大錯(cuò)。

當(dāng)然,Go 做得更絕,當(dāng)我們?cè)诒闅v map 時(shí),并不是固定地從 0 號(hào) bucket 開始遍歷,每次都是從一個(gè)隨機(jī)值序號(hào)的 bucket 開始遍歷,并且是從這個(gè) bucket 的一個(gè)隨機(jī)序號(hào)的 cell 開始遍歷。這樣,即使你是一個(gè)寫死的 map,僅僅只是遍歷它,也不太可能會(huì)返回一個(gè)固定序列的 key/value 對(duì)了。

再明確一個(gè)問題:如果擴(kuò)容后,B 增加了 1,意味著 buckets 總數(shù)是原來的 2 倍,原來 1 號(hào)的桶“裂變”到兩個(gè)桶。

例如,原始 B = 2,1號(hào) bucket 中有 2 個(gè) key 的哈希值低 3 位分別為:010,110。由于原來 B = 2,所以低 2 位 10 決定它們落在 2 號(hào)桶,現(xiàn)在 B 變成 3,所以 010、110 分別落入 2、6 號(hào)桶。

理解了這個(gè),后面講 map 迭代的時(shí)候會(huì)用到。

再來講搬遷函數(shù)中的幾個(gè)關(guān)鍵點(diǎn):

evacuate 函數(shù)每次只完成一個(gè) bucket 的搬遷工作,因此要遍歷完此 bucket 的所有的 cell,將有值的 cell copy 到新的地方。bucket 還會(huì)鏈接 overflow bucket,它們同樣需要搬遷。因此會(huì)有 2 層循環(huán),外層遍歷 bucket 和 overflow bucket,內(nèi)層遍歷 bucket 的所有 cell。這樣的循環(huán)在 map 的源碼里到處都是,要理解透了。

源碼里提到 X, Y part,其實(shí)就是我們說的如果是擴(kuò)容到原來的 2 倍,桶的數(shù)量是原來的 2 倍,前一半桶被稱為 X part,后一半桶被稱為 Y part。一個(gè) bucket 中的 key 可能會(huì)分裂落到 2 個(gè)桶,一個(gè)位于 X part,一個(gè)位于 Y part。所以在搬遷一個(gè) cell 之前,需要知道這個(gè) cell 中的 key 是落到哪個(gè) Part。很簡(jiǎn)單,重新計(jì)算 cell 中 key 的 hash,并向前“多看”一位,決定落入哪個(gè) Part,這個(gè)前面也說得很詳細(xì)了。

有一個(gè)特殊情況是:有一種 key,每次對(duì)它計(jì)算 hash,得到的結(jié)果都不一樣。這個(gè) key 就是 math.NaN() 的結(jié)果,它的含義是 not a number,類型是 float64。當(dāng)它作為 map 的 key,在搬遷的時(shí)候,會(huì)遇到一個(gè)問題:再次計(jì)算它的哈希值和它當(dāng)初插入 map 時(shí)的計(jì)算出來的哈希值不一樣!

你可能想到了,這樣帶來的一個(gè)后果是,這個(gè) key 是永遠(yuǎn)不會(huì)被 Get 操作獲取的!當(dāng)我使用 m[math.NaN()] 語句的時(shí)候,是查不出來結(jié)果的。這個(gè) key 只有在遍歷整個(gè) map 的時(shí)候,才有機(jī)會(huì)現(xiàn)身。所以,可以向一個(gè) map 插入任意數(shù)量的 math.NaN() 作為 key。

當(dāng)搬遷碰到 math.NaN() 的 key 時(shí),只通過 tophash 的最低位決定分配到 X part 還是 Y part(如果擴(kuò)容后是原來 buckets 數(shù)量的 2 倍)。如果 tophash 的最低位是 0 ,分配到 X part;如果是 1 ,則分配到 Y part。

確定了要搬遷到的目標(biāo) bucket 后,搬遷操作就比較好進(jìn)行了。將源 key/value 值 copy 到目的地相應(yīng)的位置。

設(shè)置 key 在原始 buckets 的 tophash 為 evacuatedX 或是 evacuatedY,表示已經(jīng)搬遷到了新 map 的 x part 或是 y part。新 map 的 tophash 則正常取 key 哈希值的高 8 位。

下面通過圖來宏觀地看一下擴(kuò)容前后的變化。

擴(kuò)容前,B = 2,共有 4 個(gè) buckets,lowbits 表示 hash 值的低位。假設(shè)我們不關(guān)注其他 buckets 情況,專注在 2 號(hào) bucket。并且假設(shè) overflow 太多,觸發(fā)了等量擴(kuò)容(對(duì)應(yīng)于前面的條件 2)。

擴(kuò)容完成后,overflow bucket 消失了,key 都集中到了一個(gè) bucket,更為緊湊了,提高了查找的效率。

假設(shè)觸發(fā)了 2 倍的擴(kuò)容,那么擴(kuò)容完成后,老 buckets 中的 key 分裂到了 2 個(gè) 新的 bucket。一個(gè)在 x part,一個(gè)在 y 的 part。依據(jù)是 hash 的 lowbits。新 map 中 0-3 稱為 x part,4-7 稱為 y part。

注意,上面的兩張圖忽略了其他 buckets 的搬遷情況,表示所有的 bucket 都搬遷完畢后的情形。實(shí)際上,我們知道,搬遷是一個(gè)“漸進(jìn)”的過程,并不會(huì)一下子就全部搬遷完畢。所以在搬遷過程中,oldbuckets 指針還會(huì)指向原來老的 []bmap,并且已經(jīng)搬遷完畢的 key 的 tophash 值會(huì)是一個(gè)狀態(tài)值,表示 key 的搬遷去向。

元素訪問

通過匯編語言可以看到,向 map 中插入或者修改 key,最終調(diào)用的是 mapassign 函數(shù)。

實(shí)際上插入或修改 key 的語法是一樣的,只不過前者操作的 key 在 map 中不存在,而后者操作的 key 存在 map 中。

mapassign 有一個(gè)系列的函數(shù),根據(jù) key 類型的不同,編譯器會(huì)將其優(yōu)化為相應(yīng)的“快速函數(shù)”。

我們只用研究最一般的賦值函數(shù) mapassign。

整體來看,流程非常得簡(jiǎn)單:對(duì) key 計(jì)算 hash 值,根據(jù) hash 值按照之前的流程,找到要賦值的位置(可能是插入新 key,也可能是更新老 key),對(duì)相應(yīng)位置進(jìn)行賦值。

源碼大體和之前講的類似,核心還是一個(gè)雙層循環(huán),外層遍歷 bucket 和它的 overflow bucket,內(nèi)層遍歷整個(gè) bucket 的各個(gè) cell。限于篇幅,這部分代碼的注釋我也不展示了,有興趣的可以去看,保證理解了這篇文章內(nèi)容后,能夠看懂。

我這里會(huì)針對(duì)這個(gè)過程提幾點(diǎn)重要的。

函數(shù)首先會(huì)檢查 map 的標(biāo)志位 flags。如果 flags 的寫標(biāo)志位此時(shí)被置 1 了,說明有其他協(xié)程在執(zhí)行“寫”操作,進(jìn)而導(dǎo)致程序 panic。這也說明了 map 對(duì)協(xié)程是不安全的。

通過前文我們知道擴(kuò)容是漸進(jìn)式的,如果 map 處在擴(kuò)容的過程中,那么當(dāng) key 定位到了某個(gè) bucket 后,需要確保這個(gè) bucket 對(duì)應(yīng)的老 bucket 完成了遷移過程。即老 bucket 里的 key 都要遷移到新的 bucket 中來(分裂到 2 個(gè)新 bucket),才能在新的 bucket 中進(jìn)行插入或者更新的操作。

上面說的操作是在函數(shù)靠前的位置進(jìn)行的,只有進(jìn)行完了這個(gè)搬遷操作后,我們才能放心地在新 bucket 里定位 key 要安置的地址,再進(jìn)行之后的操作。

現(xiàn)在到了定位 key 應(yīng)該放置的位置了,所謂找準(zhǔn)自己的位置很重要。準(zhǔn)備兩個(gè)指針,一個(gè)(inserti)指向 key 的 hash 值在 tophash 數(shù)組所處的位置,另一個(gè)(insertk)指向 cell 的位置(也就是 key 最終放置的地址),當(dāng)然,對(duì)應(yīng) value 的位置就很容易定位出來了。這三者實(shí)際上都是關(guān)聯(lián)的,在 tophash 數(shù)組中的索引位置決定了 key 在整個(gè) bucket 中的位置(共 8 個(gè) key),而 value 的位置需要“跨過” 8 個(gè) key 的長(zhǎng)度。

在循環(huán)的過程中,inserti 和 insertk 分別指向第一個(gè)找到的空閑的 cell。如果之后在 map 沒有找到 key 的存在,也就是說原來 map 中沒有此 key,這意味著插入新 key。那最終 key 的安置地址就是第一次發(fā)現(xiàn)的“空位”(tophash 是 empty)。

如果這個(gè) bucket 的 8 個(gè) key 都已經(jīng)放置滿了,那在跳出循環(huán)后,發(fā)現(xiàn) inserti 和 insertk 都是空,這時(shí)候需要在 bucket 后面掛上 overflow bucket。當(dāng)然,也有可能是在 overflow bucket 后面再掛上一個(gè) overflow bucket。這就說明,太多 key hash 到了此 bucket。

在正式安置 key 之前,還要檢查 map 的狀態(tài),看它是否需要進(jìn)行擴(kuò)容。如果滿足擴(kuò)容的條件,就主動(dòng)觸發(fā)一次擴(kuò)容操作。

這之后,整個(gè)之前的查找定位 key 的過程,還得再重新走一次。因?yàn)閿U(kuò)容之后,key 的分布都發(fā)生了變化。

最后,會(huì)更新 map 相關(guān)的值,如果是插入新 key,map 的元素?cái)?shù)量字段 count 值會(huì)加 1;在函數(shù)之初設(shè)置的 hashWriting 寫標(biāo)志出會(huì)清零。

另外,有一個(gè)重要的點(diǎn)要說一下。前面說的找到 key 的位置,進(jìn)行賦值操作,實(shí)際上并不準(zhǔn)確。我們看 mapassign 函數(shù)的原型就知道,函數(shù)并沒有傳入 value 值,所以賦值操作是什么時(shí)候執(zhí)行的呢?

func mapassign(t *maptype, h *hmap, key unsafe.Pointer) unsafe.Pointer

答案還得從匯編語言中尋找。我直接揭曉答案,有興趣可以私下去研究一下。mapassign 函數(shù)返回的指針就是指向的 key 所對(duì)應(yīng)的 value 值位置,有了地址,就很好操作賦值了。

刪除

寫操作底層的執(zhí)行函數(shù)是 mapdelete:

func mapdelete(t *maptype, h *hmap, key unsafe.Pointer)

根據(jù) key 類型的不同,刪除操作會(huì)被優(yōu)化成更具體的函數(shù):

當(dāng)然,我們只關(guān)心 mapdelete 函數(shù)。它首先會(huì)檢查 h.flags 標(biāo)志,如果發(fā)現(xiàn)寫標(biāo)位是 1,直接 panic,因?yàn)檫@表明有其他協(xié)程同時(shí)在進(jìn)行寫操作。

計(jì)算 key 的哈希,找到落入的 bucket。檢查此 map 如果正在擴(kuò)容的過程中,直接觸發(fā)一次搬遷操作。

刪除操作同樣是兩層循環(huán),核心還是找到 key 的具體位置。尋找過程都是類似的,在 bucket 中挨個(gè) cell 尋找。

找到對(duì)應(yīng)位置后,對(duì) key 或者 value 進(jìn)行“清零”操作。

迭代

本來 map 的遍歷過程比較簡(jiǎn)單:遍歷所有的 bucket 以及它后面掛的 overflow bucket,然后挨個(gè)遍歷 bucket 中的所有 cell。每個(gè) bucket 中包含 8 個(gè) cell,從有 key 的 cell 中取出 key 和 value,這個(gè)過程就完成了。

但是,現(xiàn)實(shí)并沒有這么簡(jiǎn)單。還記得前面講過的擴(kuò)容過程嗎?擴(kuò)容過程不是一個(gè)原子的操作,它每次最多只搬運(yùn) 2 個(gè) bucket,所以如果觸發(fā)了擴(kuò)容操作,那么在很長(zhǎng)時(shí)間里,map 的狀態(tài)都是處于一個(gè)中間態(tài):有些 bucket 已經(jīng)搬遷到新家,而有些 bucket 還待在老地方。

因此,遍歷如果發(fā)生在擴(kuò)容的過程中,就會(huì)涉及到遍歷新老 bucket 的過程,這是難點(diǎn)所在。

我先寫一個(gè)簡(jiǎn)單的代碼樣例,假裝不知道遍歷過程具體調(diào)用的是什么函數(shù):

package main

import "fmt"

func main() {
	ageMp := make(map[string]int)
	ageMp["qcrao"] = 18

	for name, age := range ageMp {
		fmt.Println(name, age)
	}
}

執(zhí)行命令:

go tool compile -S main.go

得到匯編命令。這里就不逐行講解了,可以去看之前的幾篇文章,說得很詳細(xì)。

關(guān)鍵的幾行匯編代碼如下:

// ......
0x0124 00292 (test16.go:9)      CALL    runtime.mapiterinit(SB)

// ......
0x01fb 00507 (test16.go:9)      CALL    runtime.mapiternext(SB)
0x0200 00512 (test16.go:9)      MOVQ    ""..autotmp_4+160(SP), AX
0x0208 00520 (test16.go:9)      TESTQ   AX, AX
0x020b 00523 (test16.go:9)      JNE     302

// ......

這樣,關(guān)于 map 迭代,底層的函數(shù)調(diào)用關(guān)系一目了然。先是調(diào)用 mapiterinit 函數(shù)初始化迭代器,然后循環(huán)調(diào)用 mapiternext 函數(shù)進(jìn)行 map 迭代。

迭代器的結(jié)構(gòu)體定義:

type hiter struct {
	key         unsafe.Pointer // Must be in first position.  Write nil to indicate iteration end (see cmd/internal/gc/range.go).
	elem        unsafe.Pointer // Must be in second position (see cmd/internal/gc/range.go).
	t           *maptype
	h           *hmap
	buckets     unsafe.Pointer // bucket ptr at hash_iter initialization time
	bptr        *bmap          // current bucket
	overflow    *[]*bmap       // keeps overflow buckets of hmap.buckets alive
	oldoverflow *[]*bmap       // keeps overflow buckets of hmap.oldbuckets alive
	startBucket uintptr        // bucket iteration started at
	offset      uint8          // intra-bucket offset to start from during iteration (should be big enough to hold bucketCnt-1)
	wrapped     bool           // already wrapped around from end of bucket array to beginning
	B           uint8
	i           uint8
	bucket      uintptr
	checkBucket uintptr
}

mapiterinit 就是對(duì) hiter 結(jié)構(gòu)體里的字段進(jìn)行初始化賦值操作。

前面已經(jīng)提到過,即使是對(duì)一個(gè)寫死的 map 進(jìn)行遍歷,每次出來的結(jié)果也是無序的。下面我們就可以近距離地觀察他們的實(shí)現(xiàn)了。

// 生成隨機(jī)數(shù) r
r := uintptr(fastrand())
if h.B > 31-bucketCntBits {
	r += uintptr(fastrand()) << 31
}
// 從哪個(gè) bucket 開始遍歷
it.startBucket = r & bucketMask(h.B)
it.offset = uint8(r >> h.B & (bucketCnt - 1))

例如,B = 2,那 uintptr(1)<<h.B - 1 結(jié)果就是 3,低 8 位為 0000 0011,將 r 與之 & ,就可以得到一個(gè)0~3的 bucket 序號(hào);bucketCnt - 1 等于 7,低 8 位為 0000 0111,將 r 右移 2 位后,與 7 相與,就可以得到一個(gè) 0~7 號(hào)的 cell。

于是,在 mapiternext 函數(shù)中就會(huì)從 it.startBucket 的 it.offset 號(hào)的 cell 開始遍歷,取出其中的 key 和 value,直到又回到起點(diǎn) bucket,完成遍歷過程。

源碼部分比較好看懂,尤其是理解了前面注釋的幾段代碼后,再看這部分代碼就沒什么壓力了。所以,接下來,我將通過圖形化的方式講解整個(gè)遍歷過程,希望能夠清晰易懂。

假設(shè)我們有下圖所示的一個(gè) map,起始時(shí) B = 1,有兩個(gè) bucket,后來觸發(fā)了擴(kuò)容(這里不要深究擴(kuò)容條件,只是一個(gè)設(shè)定),B 變成 2。并且, 1 號(hào) bucket 中的內(nèi)容搬遷到了新的 bucket,1 號(hào)裂變成 1 號(hào)和 3 號(hào);0 號(hào) bucket 暫未搬遷。老的 bucket 掛在在 *oldbuckets 指針上面,新的 bucket 則掛在 *buckets 指針上面。

這時(shí),我們對(duì)此 map 進(jìn)行遍歷。假設(shè)經(jīng)過初始化后,startBucket = 3,offset = 2。于是,遍歷的起點(diǎn)將是 3 號(hào) bucket 的 2 號(hào) cell,下面這張圖就是開始遍歷時(shí)的狀態(tài):

標(biāo)紅的表示起始位置,bucket 遍歷順序?yàn)椋? -> 0 -> 1 -> 2。

因?yàn)?3 號(hào) bucket 對(duì)應(yīng)老的 1 號(hào) bucket,因此先檢查老 1 號(hào) bucket 是否已經(jīng)被搬遷過。判斷方法就是:

func evacuated(b *bmap) bool {
	h := b.tophash[0]
	return h > emptyOne && h < minTopHash
}

如果 b.tophash[0] 的值在標(biāo)志值范圍內(nèi),即在 (1,5) 區(qū)間里,說明已經(jīng)被搬遷過了。

emptyRest      = 0 // this cell is empty, and there are no more non-empty cells at higher indexes or overflows.
emptyOne       = 1 // this cell is empty
evacuatedX     = 2 // key/elem is valid.  Entry has been evacuated to first half of larger table.
evacuatedY     = 3 // same as above, but evacuated to second half of larger table.
evacuatedEmpty = 4 // cell is empty, bucket is evacuated.
minTopHash     = 5 // minimum tophash for a normal filled cell.

在本例中,老 1 號(hào) bucket 已經(jīng)被搬遷過了。所以它的 tophash[0] 值在 (1,5) 范圍內(nèi),因此只用遍歷新的 3 號(hào) bucket。

依次遍歷 3 號(hào) bucket 的 cell,這時(shí)候會(huì)找到第一個(gè)非空的 key:元素 e。到這里,mapiternext 函數(shù)返回,這時(shí)我們的遍歷結(jié)果僅有一個(gè)元素:

由于返回的 key 不為空,所以會(huì)繼續(xù)調(diào)用 mapiternext 函數(shù)。

繼續(xù)從上次遍歷到的地方往后遍歷,從新 3 號(hào) overflow bucket 中找到了元素 f 和 元素 g。

遍歷結(jié)果集也因此壯大:

新 3 號(hào) bucket 遍歷完之后,回到了新 0 號(hào) bucket。0 號(hào) bucket 對(duì)應(yīng)老的 0 號(hào) bucket,經(jīng)檢查,老 0 號(hào) bucket 并未搬遷,因此對(duì)新 0 號(hào) bucket 的遍歷就改為遍歷老 0 號(hào) bucket。那是不是把老 0 號(hào) bucket 中的所有 key 都取出來呢?

并沒有這么簡(jiǎn)單,回憶一下,老 0 號(hào) bucket 在搬遷后將裂變成 2 個(gè) bucket:新 0 號(hào)、新 2 號(hào)。而我們此時(shí)正在遍歷的只是新 0 號(hào) bucket(注意,遍歷都是遍歷的 *bucket 指針,也就是所謂的新 buckets)。所以,我們只會(huì)取出老 0 號(hào) bucket 中那些在裂變之后,分配到新 0 號(hào) bucket 中的那些 key。

因此,lowbits == 00 的將進(jìn)入遍歷結(jié)果集:

和之前的流程一樣,繼續(xù)遍歷新 1 號(hào) bucket,發(fā)現(xiàn)老 1 號(hào) bucket 已經(jīng)搬遷,只用遍歷新 1 號(hào) bucket 中現(xiàn)有的元素就可以了。結(jié)果集變成:

繼續(xù)遍歷新 2 號(hào) bucket,它來自老 0 號(hào) bucket,因此需要在老 0 號(hào) bucket 中那些會(huì)裂變到新 2 號(hào) bucket 中的 key,也就是 lowbit == 10 的那些 key。

這樣,遍歷結(jié)果集變成:

最后,繼續(xù)遍歷到新 3 號(hào) bucket 時(shí),發(fā)現(xiàn)所有的 bucket 都已經(jīng)遍歷完畢,整個(gè)迭代過程執(zhí)行完畢。

順便說一下,如果碰到 key 是 math.NaN() 這種的,處理方式類似。核心還是要看它被分裂后具體落入哪個(gè) bucket。只不過只用看它 top hash 的最低位。如果 top hash 的最低位是 0 ,分配到 X part;如果是 1 ,則分配到 Y part。據(jù)此決定是否取出 key,放到遍歷結(jié)果集里。

map 遍歷的核心在于理解 2 倍擴(kuò)容時(shí),老 bucket 會(huì)分裂到 2 個(gè)新 bucket 中去。而遍歷操作,會(huì)按照新 bucket 的序號(hào)順序進(jìn)行,碰到老 bucket 未搬遷的情況時(shí),要在老 bucket 中找到將來要搬遷到新 bucket 來的 key。

核心點(diǎn):

(1)可以邊遍歷邊刪除嗎?
map 并不是一個(gè)線程安全的數(shù)據(jù)結(jié)構(gòu)。同時(shí)讀寫一個(gè) map 是未定義的行為,如果被檢測(cè)到,會(huì)直接 panic。

一般而言,這可以通過讀寫鎖來解決:sync.RWMutex。

讀之前調(diào)用 RLock() 函數(shù),讀完之后調(diào)用 RUnlock() 函數(shù)解鎖;寫之前調(diào)用 Lock() 函數(shù),寫完之后,調(diào)用 Unlock() 解鎖。

另外,sync.Map 是線程安全的 map,也可以使用。它的實(shí)現(xiàn)原理,這次先不說了。

(2)key 可以是 float 型嗎?
從語法上看,是可以的。Go 語言中只要是可比較的類型都可以作為 key。除開 slice,map,functions 這幾種類型,其他類型都是 OK 的。具體包括:布爾值、數(shù)字、字符串、指針、通道、接口類型、結(jié)構(gòu)體、只包含上述類型的數(shù)組。這些類型的共同特征是支持== 和 != 操作符,k1 == k2 時(shí),可認(rèn)為 k1 和 k2 是同一個(gè) key。如果是結(jié)構(gòu)體,則需要它們的字段值都相等,才被認(rèn)為是相同的 key。

順便說一句,任何類型都可以作為 value,包括 map 類型。

最后說結(jié)論:float 型可以作為 key,但是由于精度的問題,會(huì)導(dǎo)致一些詭異的問題,慎用之。

(3)總結(jié)
總結(jié)一下,Go 語言中,通過哈希查找表實(shí)現(xiàn) map,用鏈表法解決哈希沖突。

通過 key 的哈希值將 key 散落到不同的桶中,每個(gè)桶中有 8 個(gè) cell。哈希值的低位決定桶序號(hào),高位標(biāo)識(shí)同一個(gè)桶中的不同 key。

當(dāng)向桶中添加了很多 key,造成元素過多,或者溢出桶太多,就會(huì)觸發(fā)擴(kuò)容。擴(kuò)容分為等量擴(kuò)容和 2 倍容量擴(kuò)容。擴(kuò)容后,原來一個(gè) bucket 中的 key 一分為二,會(huì)被重新分配到兩個(gè)桶中。

擴(kuò)容過程是漸進(jìn)的,主要是防止一次擴(kuò)容需要搬遷的 key 數(shù)量過多,引發(fā)性能問題。觸發(fā)擴(kuò)容的時(shí)機(jī)是增加了新元素,bucket 搬遷的時(shí)機(jī)則發(fā)生在賦值、刪除期間,每次最多搬遷兩個(gè) bucket。

查找、賦值、刪除的一個(gè)很核心的內(nèi)容是如何定位到 key 所在的位置,需要重點(diǎn)理解。一旦理解,關(guān)于 map 的源碼就可以看懂了。

到此這篇關(guān)于Golang map實(shí)踐以及實(shí)現(xiàn)原理的文章就介紹到這了,更多相關(guān)Golang map實(shí)現(xiàn)原理內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • GO語言標(biāo)準(zhǔn)錯(cuò)誤處理機(jī)制error用法實(shí)例

    GO語言標(biāo)準(zhǔn)錯(cuò)誤處理機(jī)制error用法實(shí)例

    這篇文章主要介紹了GO語言標(biāo)準(zhǔn)錯(cuò)誤處理機(jī)制error用法,實(shí)例分析了錯(cuò)誤處理機(jī)制的具體用法,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2014-12-12
  • 手把手教你如何在Goland中創(chuàng)建和運(yùn)行項(xiàng)目

    手把手教你如何在Goland中創(chuàng)建和運(yùn)行項(xiàng)目

    歡迎來到本指南!我們將手把手地教您在Goland中如何創(chuàng)建、配置并運(yùn)行項(xiàng)目,通過簡(jiǎn)單的步驟,您將迅速上手這款強(qiáng)大的集成開發(fā)環(huán)境(IDE),輕松實(shí)現(xiàn)您的編程夢(mèng)想,讓我們一起開啟這段精彩的旅程吧!
    2024-02-02
  • Go語言防范SQL注入CSRF及XSS攻擊實(shí)例探究

    Go語言防范SQL注入CSRF及XSS攻擊實(shí)例探究

    在本文中,我們將會(huì)介紹幾種最常見的攻擊類型,并且介紹如何使用Golang來防范這些攻擊,本文會(huì)涉及XSS攻擊、CSRF攻擊、SQL注入等,如果你想學(xué)習(xí)Golang和網(wǎng)絡(luò)安全的相關(guān)知識(shí),那么這篇文章會(huì)是一個(gè)很好的開始
    2024-01-01
  • Go?內(nèi)聯(lián)優(yōu)化讓程序員愛不釋手

    Go?內(nèi)聯(lián)優(yōu)化讓程序員愛不釋手

    這篇文章主要介紹了Go?內(nèi)聯(lián)優(yōu)化讓程序員愛不釋手,內(nèi)聯(lián)是在編譯過程中自動(dòng)進(jìn)行的一類基本優(yōu)化之一,文章圍繞主題展開更多詳細(xì)介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-06-06
  • 深入了解Go語言中context的用法

    深入了解Go語言中context的用法

    這篇文章主要為大家詳細(xì)介紹了Go語言中context用法的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-07-07
  • Go語言操作redis用法實(shí)例

    Go語言操作redis用法實(shí)例

    這篇文章主要介紹了Go語言操作redis用法,實(shí)例分析了Go語言操作redis的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-02-02
  • 深入了解Golang的指針用法

    深入了解Golang的指針用法

    與C語言一樣,Go語言中同樣有指針,通過指針,我們可以只傳遞變量的內(nèi)存地址,而不是傳遞整個(gè)變量,這在一定程度上可以節(jié)省內(nèi)存的占用。本文將通過示例詳細(xì)講講Golang的指針用法,需要的可以參考一下
    2022-07-07
  • Golang單元測(cè)試與覆蓋率的實(shí)例講解

    Golang單元測(cè)試與覆蓋率的實(shí)例講解

    這篇文章主要介紹了Golang單元測(cè)試與覆蓋率的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • 一文帶你探索Go語言中的函數(shù)一等公民

    一文帶你探索Go語言中的函數(shù)一等公民

    你是否聽說過?Go?語言中的函數(shù)是一等公民,如果沒有,那么恭喜你,本文將帶你一起揭開這個(gè)神秘的面紗,感興趣的小伙伴快來和小編一起學(xué)習(xí)起來吧
    2023-07-07
  • go 熔斷原理分析與源碼解讀

    go 熔斷原理分析與源碼解讀

    這篇文章主要為大家介紹了go 熔斷原理分析與源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08

最新評(píng)論

大鸡吧插逼逼视频免费看| 亚洲日本一区二区久久久精品| 精品黑人巨大在线一区| 青青青视频自偷自拍38碰| 国产一线二线三线的区别在哪| 精品区一区二区三区四区人妻| 国产免费av一区二区凹凸四季| 99久久中文字幕一本人| 青青草亚洲国产精品视频| 97精品视频在线观看| 人妻久久久精品69系列| 国产精品久久9999| 偷拍自拍亚洲视频在线观看| 日韩伦理短片在线观看| 99视频精品全部15| 国产精品视频欧美一区二区 | 亚洲 人妻 激情 中文| 99热这里只有国产精品6| 天天操天天操天天碰| 国产精品一区二区av国| 成人av免费不卡在线观看| 99国内小视频在现欢看| 天天干天天插天天谢| 日韩a级精品一区二区| 99国内精品永久免费视频| 国产一区二区久久久裸臀| 男人天堂av天天操| 喷水视频在线观看这里只有精品 | 亚洲的电影一区二区三区| 精品一区二区三区欧美| 一区二区在线视频中文字幕| 美女在线观看日本亚洲一区| 亚洲午夜电影在线观看| 91p0rny九色露脸熟女| 91综合久久亚洲综合| 久久久精品欧洲亚洲av| 超碰公开大香蕉97| 天天日夜夜干天天操| 欧美视频不卡一区四区| 国产九色91在线视频| 亚洲天天干 夜夜操| 亚洲中文字字幕乱码| 91人妻精品一区二区在线看| 亚洲护士一区二区三区| 91成人在线观看免费视频| 影音先锋女人av噜噜色| 黄色av网站免费在线| 天天操天天干天天艹| 欧美色呦呦最新网址| 老司机99精品视频在线观看 | 欧美精产国品一二三区| 午夜影院在线观看视频羞羞羞| 欧美黄色录像免费看的| 久久久久久97三级| 国产成人精品一区在线观看 | 欧美亚洲牲夜夜综合久久| 欧美亚洲中文字幕一区二区三区| 国产在线观看免费人成短视频| 欧美3p在线观看一区二区三区| 中文字幕 人妻精品| 天天插天天狠天天操| 亚洲av在线观看尤物| 亚洲成人av在线一区二区| 国产大学生援交正在播放| 亚洲无线观看国产高清在线| 亚洲黄色av网站免费播放| 黄色视频成年人免费观看| 亚洲午夜精品小视频| 777奇米久久精品一区| 91亚洲手机在线视频播放| 亚洲高清国产自产av| 亚洲男人在线天堂网| 国产午夜男女爽爽爽爽爽视频| 在线观看911精品国产 | 日韩人妻丝袜中文字幕| 91在线免费观看成人| 欧美专区第八页一区在线播放 | 中文字幕在线乱码一区二区 | 亚洲午夜高清在线观看| 天堂av在线播放免费| 国产成人自拍视频播放| 男人操女人的逼免费视频| 亚洲乱码中文字幕在线| 免费av岛国天堂网站| 在线新三级黄伊人网| 免费人成黄页网站在线观看国产 | 午夜久久久久久久精品熟女| 国产福利小视频大全| 欲满人妻中文字幕在线| 亚洲伊人色一综合网| 福利一二三在线视频观看 | 97人妻夜夜爽二区欧美极品| 欧美第一页在线免费观看视频| 狠狠操操操操操操操操操| 精品美女在线观看视频在线观看| 97超碰国语国产97超碰| 偷拍3456eee| 日韩美女福利视频网| 少妇高潮一区二区三区| 亚洲 中文字幕在线 日韩| 欧美日本aⅴ免费视频| 亚洲自拍偷拍精品网| 日本免费一级黄色录像| 日韩二区视频一线天婷婷五| 福利在线视频网址导航| 青青色国产视频在线| jul—619中文字幕在线| 国产亚洲精品品视频在线| 婷婷六月天中文字幕| 亚洲av日韩av网站| av大全在线播放免费| 黄色资源视频网站日韩| 啪啪啪啪啪啪啪啪啪啪黄色| 18禁美女黄网站色大片下载| 亚洲欧美国产综合777| 999热精品视频在线| 狠狠的往里顶撞h百合| av中文字幕福利网| 女警官打开双腿沦为性奴| 快点插进来操我逼啊视频| 手机看片福利盒子日韩在线播放| 福利午夜视频在线观看| 在线网站你懂得老司机| 91人妻精品久久久久久久网站| 一区二区三区综合视频| 偷拍3456eee| 欧美日韩v中文在线| 操人妻嗷嗷叫视频一区二区| 日本欧美视频在线观看三区| 欧美亚洲中文字幕一区二区三区| 久久久久国产成人精品亚洲午夜| 国产精品视频一区在线播放| 99久久超碰人妻国产| 亚洲精品av在线观看| 免费av岛国天堂网站| 国产欧美精品一区二区高清 | 伊人综合aⅴ在线网| 午夜精品福利一区二区三区p| 韩国爱爱视频中文字幕| 亚洲高清视频在线不卡| 天天日天天舔天天射进去| 一区二区三区四区视频| 任你操任你干精品在线视频| 婷婷综合亚洲爱久久| 亚洲特黄aaaa片| 任你操视频免费在线观看| 人妻久久久精品69系列| 啊啊啊视频试看人妻| 亚洲国产在线精品国偷产拍| 精品视频一区二区三区四区五区| 欧美精产国品一二三区| 2019av在线视频| 丝袜国产专区在线观看| 国产在线自在拍91国语自产精品 | 欧美精品国产综合久久| 亚洲 人妻 激情 中文| 夏目彩春在线中文字幕| japanese日本熟妇另类| www天堂在线久久| 成人综合亚洲欧美一区| 国产精品久久久久久久久福交| 精品一区二区三四区| 国产又色又刺激在线视频| 日日夜夜大香蕉伊人| 蜜桃视频入口久久久| 最新91精品视频在线| 漂亮 人妻被中出中文| 第一福利视频在线观看| 天天日天天日天天擦| 亚洲 色图 偷拍 欧美| 动色av一区二区三区| a v欧美一区=区三区| 国产精品欧美日韩区二区| 亚洲福利精品福利精品福利| www日韩毛片av| 91人妻人人做人人爽在线| 一区二区三区美女毛片| 欧美aa一级一区三区四区| 亚洲av可乐操首页| 日本黄色三级高清视频| 欧美乱妇无乱码一区二区| 大屁股熟女一区二区三区| 日本精品视频不卡一二三| 日辽宁老肥女在线观看视频| 成人av在线资源网站| 人妻丝袜av在线播放网址| 中国无遮挡白丝袜二区精品| 国产熟妇一区二区三区av| 精品人人人妻人人玩日产欧| 少妇与子乱在线观看| av手机免费在线观看高潮| 久草视频首页在线观看| 人妻另类专区欧美制服| AV天堂一区二区免费试看| 亚洲精品无码久久久久不卡| 5528327男人天堂| av在线shipin| 亚洲国产在线精品国偷产拍| 国产av自拍偷拍盛宴| 一区二区三区另类在线| 韩国爱爱视频中文字幕| 亚洲欧美激情中文字幕| 青青青爽视频在线播放| 色秀欧美视频第一页| 丝袜美腿欧美另类 中文字幕| 日美女屁股黄邑视频| 天堂资源网av中文字幕| 夫妻在线观看视频91| 大骚逼91抽插出水视频| 天天干天天插天天谢| 国产高清在线在线视频| 五月天久久激情视频| 亚洲人人妻一区二区三区| 成年人中文字幕在线观看| 伊人网中文字幕在线视频| 国产超码片内射在线| 欧美中文字幕一区最新网址| 中文字幕无码日韩专区免费| 婷婷六月天中文字幕| 福利视频广场一区二区| 欧美亚洲自偷自拍 在线| 婷婷久久一区二区字幕网址你懂得| 香港三日本三韩国三欧美三级| 18禁网站一区二区三区四区| 欧美一区二区三区激情啪啪啪| 精品一区二区三区三区色爱| 40道精品招牌菜特色| 精品黑人一区二区三区久久国产| 在线 中文字幕 一区| 欧亚乱色一区二区三区| 91国内精品自线在拍白富美| h国产小视频福利在线观看| 在线观看国产免费麻豆| 国产麻豆精品人妻av| 国产1区,2区,3区| 欧美黑人与人妻精品| 四虎永久在线精品免费区二区| 欧美在线精品一区二区三区视频| av天堂中文字幕最新| 亚洲一级特黄特黄黄色录像片| 黄片色呦呦视频免费看| 3337p日本欧洲大胆色噜噜| 日美女屁股黄邑视频| 国产精品精品精品999| weyvv5国产成人精品的视频| 欧美专区第八页一区在线播放| 宅男噜噜噜666国产| 日韩黄色片在线观看网站| 亚洲蜜臀av一区二区三区九色| 一区二区三区精品日本| 国产在线观看黄色视频| 日韩成人性色生活片| 精品人妻每日一部精品| 在线免费91激情四射 | 日本黄色三级高清视频| av在线免费观看亚洲天堂| av无限看熟女人妻另类av| 国产乱子伦一二三区| 中文字幕高清资源站| 国产变态另类在线观看| 日本一道二三区视频久久| 丝袜长腿第一页在线| 激情伦理欧美日韩中文字幕| 亚洲国产精品久久久久蜜桃| 国产亚洲成人免费在线观看| 99久久成人日韩欧美精品| 国产视频网站国产视频| 天天操,天天干,天天射| 亚洲国际青青操综合网站| 55夜色66夜色国产精品站| yy96视频在线观看| av资源中文字幕在线观看| 亚洲av无码成人精品区辽| 欧美专区日韩专区国产专区| 国产美女午夜福利久久| 2022国产精品视频| 日韩近亲视频在线观看| 一区二区三区 自拍偷拍| 狠狠躁夜夜躁人人爽天天天天97| 岛国一区二区三区视频在线| 女警官打开双腿沦为性奴| av线天堂在线观看| 人妻熟女在线一区二区| 亚洲午夜电影之麻豆| 黄色成年网站午夜在线观看| 99久久成人日韩欧美精品| 97人妻无码AV碰碰视频| 国产男女视频在线播放| 瑟瑟视频在线观看免费视频| 在线视频自拍第三页| 亚洲国产成人在线一区| 亚洲熟色妇av日韩熟色妇在线| 超碰公开大香蕉97| 手机看片福利盒子日韩在线播放| 精品av国产一区二区三区四区| 丝袜长腿第一页在线| 早川濑里奈av黑人番号| okirakuhuhu在线观看| 亚洲激情偷拍一区二区| 自拍偷拍日韩欧美亚洲| 91色老99久久九九爱精品| 国产又粗又猛又爽又黄的视频美国| 欧美一区二区三区高清不卡tv| 久久人人做人人妻人人玩精品vr| 91中文字幕最新合集| 成人午夜电影在线观看 久久| 五月精品丁香久久久久福利社| 国产亚洲精品品视频在线| 亚洲成人情色电影在线观看| 免费手机黄页网址大全| 91久久人澡人人添人人爽乱| 三级等保密码要求条款| 亚洲一区二区激情在线| 2012中文字幕在线高清| 国产av欧美精品高潮网站| av欧美网站在线观看| 一区二区三区四区视频| 国产福利小视频免费观看| 日韩欧美国产一区ab| 欧美另类重口味极品在线观看| 五月激情婷婷久久综合网| 新97超碰在线观看| 欧美一区二区三区乱码在线播放| 亚洲熟妇无码一区二区三区| 亚洲综合另类欧美久久| 亚洲熟妇x久久av久久| 日韩av有码一区二区三区4| 亚洲精品欧美日韩在线播放| 日美女屁股黄邑视频| 天天操天天弄天天射| 日本精品美女在线观看| 亚洲图片偷拍自拍区| 日韩欧美一级黄片亚洲| 好男人视频在线免费观看网站| 亚洲天堂成人在线观看视频网站| 狠狠躁夜夜躁人人爽天天天天97| 亚洲一区二区三区精品乱码| 国产av福利网址大全| 任你操视频免费在线观看| 18禁精品网站久久| 国产一区二区火爆视频| 欧美一级视频一区二区| 久久久91蜜桃精品ad| 大陆精品一区二区三区久久| 97黄网站在线观看| 黄色视频成年人免费观看| 亚洲成人av一区在线| 蜜桃专区一区二区在线观看| 免费在线观看视频啪啪| 久久久久久久久久性潮| chinese国产盗摄一区二区| 2022精品久久久久久中文字幕| 老鸭窝在线观看一区| 欧美亚洲免费视频观看| 国产视频一区二区午夜| 扒开腿挺进肉嫩小18禁视频| 啪啪啪啪啪啪啪免费视频| 婷婷久久久久深爱网| av在线播放国产不卡| 18禁网站一区二区三区四区| 亚洲另类综合一区小说| 中文字幕1卡1区2区3区| 五十路熟女人妻一区二| 人妻爱爱 中文字幕| 不卡一区一区三区在线| 亚洲综合在线观看免费| 无码日韩人妻精品久久| 久久精品国产亚洲精品166m| 免费在线看的黄片视频| 婷婷午夜国产精品久久久| 91国产在线免费播放| 成人国产影院在线观看| 少妇人妻100系列| 在线免费视频 自拍| 日本三极片视频网站观看| 国产精品一区二区久久久av| 亚洲va欧美va人人爽3p| 免费无码人妻日韩精品一区二区 | 嫩草aⅴ一区二区三区| 蜜桃久久久久久久人妻| 亚洲av色香蕉一区二区三区 | 成人av在线资源网站| 成人综合亚洲欧美一区| 日本成人一区二区不卡免费在线| 久久h视频在线观看| 欧美va不卡视频在线观看| 大陆精品一区二区三区久久| 青青草成人福利电影| 国产又粗又硬又大视频| 午夜成午夜成年片在线观看 | 都市家庭人妻激情自拍视频| 在线观看亚洲人成免费网址| 五月激情婷婷久久综合网| 天堂女人av一区二区| 亚洲精品午夜久久久久| 社区自拍揄拍尻屁你懂的| 2022国产综合在线干| 精产国品久久一二三产区区别| 中国视频一区二区三区| 偷拍自拍国产在线视频| 最新中文字幕乱码在线| 最新中文字幕免费视频| 日本男女操逼视频免费看| 99精品免费观看视频| 老师让我插进去69AV| 天天操天天爽天天干| 青青社区2国产视频| 免费无毒热热热热热热久| 亚洲国产成人av在线一区| 亚洲av极品精品在线观看| 成人动漫大肉棒插进去视频| jiuse91九色视频| 久久免看30视频口爆视频| 自拍 日韩 欧美激情| 亚洲推理片免费看网站| 青青青视频自偷自拍38碰| 韩国三级aaaaa高清视频| 欧亚乱色一区二区三区| 唐人色亚洲av嫩草| 欧美一区二区三区久久久aaa| 91麻豆精品秘密入口在线观看| 97小视频人妻一区二区| 精品高潮呻吟久久av| 大骚逼91抽插出水视频| 伊人成人综合开心网| free性日本少妇| 国产精品亚洲а∨天堂免| 三上悠亚和黑人665番号| 久久www免费人成一看片| 唐人色亚洲av嫩草| jiuse91九色视频| 成人区人妻精品一区二视频| 中文字幕在线视频一区二区三区 | 五十路息与子猛烈交尾视频| 神马午夜在线观看视频| 亚洲国产欧美一区二区三区久久| 青青青青爽手机在线| 欧美日韩一区二区电影在线观看| 亚洲超碰97人人做人人爱| 欧美偷拍自拍色图片| 亚洲一区二区三区久久午夜| 成人高清在线观看视频| 亚洲码av无色中文| 久久这里只有精品热视频| 中文字幕高清在线免费播放| 欧美精品中文字幕久久二区| 女同性ⅹxx女同h偷拍| 免费在线观看视频啪啪| 国产变态另类在线观看| 啪啪啪操人视频在线播放| 18禁网站一区二区三区四区| 亚洲一级av大片免费观看| 人妻久久久精品69系列| 欧美日韩人妻久久精品高清国产 | 在线国产精品一区二区三区| 成年午夜影片国产片| 欧美专区日韩专区国产专区| 999热精品视频在线| 天码人妻一区二区三区在线看 | 污污小视频91在线观看| 日韩精品激情在线观看| 91片黄在线观看喷潮| 国产精品国产三级麻豆| aaa久久久久久久久| 久久久久久性虐视频| 精品一区二区三区在线观看| 久久久久久9999久久久久| 久久这里只有精彩视频免费| 强行扒开双腿猛烈进入免费版| 18禁美女黄网站色大片下载| 免费看国产又粗又猛又爽又黄视频| 老鸭窝在线观看一区| 国产麻豆国语对白露脸剧情 | 亚洲精品麻豆免费在线观看 | 亚洲综合一区二区精品久久| 国产精品久久久久久久久福交| 日本av高清免费网站| 亚洲人人妻一区二区三区| 北条麻妃av在线免费观看| 免费黄页网站4188| 亚洲精品福利网站图片| 欧美日韩人妻久久精品高清国产 | 五月婷婷在线观看视频免费| 国产精品入口麻豆啊啊啊| 欧洲亚洲欧美日韩综合| 一区二区三区 自拍偷拍| 老熟妇xxxhd老熟女| 久久国产精品精品美女| 日本男女操逼视频免费看| 国产大学生援交正在播放| 久久久久久cao我的性感人妻| gay gay男男瑟瑟在线网站| 成年人黄视频在线观看| 欧美日韩v中文在线| 成人18禁网站在线播放| caoporm超碰国产| 黄色大片免费观看网站| 天天想要天天操天天干| 亚洲欧美综合另类13p| 99精品国产自在现线观看| 亚洲综合在线视频可播放| 亚洲欧美国产麻豆综合| 精彩视频99免费在线| 亚洲成人午夜电影在线观看| 天天干天天操天天插天天日| 91精品免费久久久久久| 熟女视频一区,二区,三区| 天天干天天插天天谢| 国产av福利网址大全| 国产a级毛久久久久精品| 狠狠躁夜夜躁人人爽天天天天97| 久久精品国产亚洲精品166m| 熟妇一区二区三区高清版| 亚洲成高清a人片在线观看| 久久久久久99国产精品| 青草亚洲视频在线观看| 欧美精产国品一二三产品价格| 91精品国产91青青碰| 午夜精品九一唐人麻豆嫩草成人| av中文字幕福利网| 欧美地区一二三专区| 欧美日韩人妻久久精品高清国产| 亚洲熟女综合色一区二区三区四区| 亚洲区美熟妇久久久久| 中文字幕日韩91人妻在线| 国产实拍勾搭女技师av在线| 免费在线黄色观看网站| 国产又粗又硬又大视频| 日韩黄色片在线观看网站| mm131美女午夜爽爽爽| 日本人妻少妇18—xx| 伊人开心婷婷国产av| 国产成人精品福利短视频| 天天做天天干天天舔| 精品亚洲在线免费观看| 人妻素人精油按摩中出| 2025年人妻中文字幕乱码在线| 粉嫩av蜜乳av蜜臀| 少妇与子乱在线观看| 欧美女同性恋免费a| 久草视频在线看免费| 婷婷激情四射在线观看视频| 午夜国产免费福利av| 欧美成人精品在线观看| 97精品人妻一区二区三区精品| 女同性ⅹxx女同hd| 亚洲熟妇无码一区二区三区| 国产黄色大片在线免费播放| 久久艹在线观看视频| 中文字幕成人日韩欧美| 国产极品精品免费视频| jul—619中文字幕在线| 国产伦精品一区二区三区竹菊| 大香蕉福利在线观看| 91在线免费观看成人| 中文字幕亚洲中文字幕| av在线免费资源站| 久久这里只有精彩视频免费| 久久免费看少妇高潮完整版| 手机看片福利盒子日韩在线播放| 一区二区三区另类在线| 97人妻夜夜爽二区欧美极品| 一区二区三区综合视频| 神马午夜在线观看视频| 亚洲一区二区三区精品乱码| 动漫黑丝美女的鸡巴| 日本特级片中文字幕| 91人妻精品一区二区久久| 日本三极片中文字幕| 亚洲av人人澡人人爽人人爱| 亚洲精品国产在线电影| 中文字幕一区二区自拍| 欧美成一区二区三区四区| 91快播视频在线观看| 中文字幕欧美日韩射射一| 天天日天天日天天射天天干| 日韩av大胆在线观看| 亚洲 中文 自拍 无码| 特黄老太婆aa毛毛片| 在线可以看的视频你懂的 | 中文字幕日本人妻中出| 天天干天天操天天爽天天摸| 亚洲中文字幕国产日韩| 亚洲美女高潮喷浆视频| 青青青青青操视频在线观看| 狠狠地躁夜夜躁日日躁| 偷拍美女一区二区三区| 中文字幕在线视频一区二区三区 | 88成人免费av网站| 啊慢点鸡巴太大了啊舒服视频| 中文字幕之无码色多多| 免费一级黄色av网站| 亚洲成人午夜电影在线观看| 经典av尤物一区二区| 超级碰碰在线视频免费观看| 免费一级黄色av网站| 人妻凌辱欧美丰满熟妇| 好男人视频在线免费观看网站| 亚洲午夜电影之麻豆| 熟女视频一区,二区,三区| 国产一区二区神马久久| 老司机在线精品福利视频| 在线免费观看日本伦理| 蜜臀av久久久久久久| 93精品视频在线观看 | 极品性荡少妇一区二区色欲| 夜夜骑夜夜操夜夜奸| 中文字幕第一页国产在线| 年轻的人妻被夫上司侵犯| 中文字幕日本人妻中出| 91精品免费久久久久久| av大全在线播放免费| 国产亚洲精品品视频在线| 亚洲一区制服丝袜美腿| 国产成人精品一区在线观看| 在线观看黄色成年人网站| 淫秽激情视频免费观看| 欧美香蕉人妻精品一区二区| 粉嫩欧美美人妻小视频| 亚洲av一妻不如妾| yellow在线播放av啊啊啊| 国际av大片在线免费观看| 久久久极品久久蜜桃| 国产欧美日韩第三页| av中文字幕福利网| 伊人综合免费在线视频| 久久久久久久99精品| 亚洲av极品精品在线观看| 午夜成午夜成年片在线观看| 成年人该看的视频黄免费| 韩国亚洲欧美超一级在线播放视频| 黄色成人在线中文字幕| 在线观看av2025| 成人av在线资源网站| 韩国三级aaaaa高清视频| 国产亚洲视频在线二区| 2022国产精品视频| 在线观看黄色成年人网站| 在线观看视频污一区| 欧美视频一区免费在线| 婷婷六月天中文字幕| 人妻少妇av在线观看| 在线观看视频污一区| 青青社区2国产视频| 色av色婷婷人妻久久久精品高清| 涩涩的视频在线观看视频| 成人性黑人一级av| 天天日天天舔天天射进去| 色97视频在线播放| 天天做天天爽夜夜做少妇| 91高清成人在线视频| www日韩a级s片av| 99精品国自产在线人| 日本熟女50视频免费| 中国熟女@视频91| 中文字幕在线免费第一页| 国产亚洲欧美视频网站| 天天插天天色天天日| 人人妻人人澡欧美91精品| 91欧美在线免费观看| 久草福利电影在线观看| 伊人综合免费在线视频| 女同性ⅹxx女同h偷拍| 97人妻夜夜爽二区欧美极品| 亚洲色偷偷综合亚洲AV伊人 | 97黄网站在线观看| 男人操女人逼逼视频网站| 黑人大几巴狂插日本少妇| 免费人成黄页网站在线观看国产| 亚洲丝袜老师诱惑在线观看| 97超碰最新免费在线观看| 日韩美av高清在线| 中文字幕在线第一页成人| 在线可以看的视频你懂的 | 中文字幕中文字幕人妻| 毛片一级完整版免费| 午夜福利人人妻人人澡人人爽| 91免费放福利在线观看| 国产精品久久久久国产三级试频| 国产熟妇一区二区三区av | 免费费一级特黄真人片| 国产精品成久久久久三级蜜臀av| 大陆精品一区二区三区久久| 亚洲欧洲av天堂综合| 动漫精品视频在线观看| 久久这里只有精彩视频免费| 免费一级黄色av网站| 日本熟女精品一区二区三区| 成年人该看的视频黄免费| 最新激情中文字幕视频| 99精品视频在线观看婷婷| 国产午夜亚洲精品麻豆| 中国无遮挡白丝袜二区精品| 色哟哟国产精品入口| 国产熟妇乱妇熟色T区| 成年午夜免费无码区| 一区二区三区久久中文字幕| 日韩亚国产欧美三级涩爱| 91麻豆精品传媒国产黄色片| 大陆胖女人与丈夫操b国语高清| 姐姐的朋友2在线观看中文字幕| 免费男阳茎伸入女阳道视频 | 亚洲高清视频在线不卡| xxx日本hd高清| 天天日天天玩天天摸| 99久久久无码国产精品性出奶水 | 特级欧美插插插插插bbbbb| 国产精品黄色的av| 大香蕉大香蕉大香蕉大香蕉大香蕉| 东京干手机福利视频| 午夜青青草原网在线观看| 天天摸天天干天天操科普| 91人妻人人做人人爽在线| 青娱乐蜜桃臀av色| 日韩精品激情在线观看| 天堂资源网av中文字幕| 视频一区 视频二区 视频| 欧美一区二区三区在线资源| 五十路熟女人妻一区二区9933| 亚洲人人妻一区二区三区| 视频二区在线视频观看| 女同互舔一区二区三区| 9久在线视频只有精品| 欧美男人大鸡吧插女人视频| 国产亚洲精品品视频在线| 亚洲成人熟妇一区二区三区| 91桃色成人网络在线观看| 91小伙伴中女熟女高潮| 啪啪啪啪啪啪啪免费视频| 大尺度激情四射网站| 天天想要天天操天天干| av无限看熟女人妻另类av| 一级a看免费观看网站| 一区二区麻豆传媒黄片| 亚洲人人妻一区二区三区| av天堂资源最新版在线看| 免费看国产又粗又猛又爽又黄视频| 天天日天天日天天射天天干 | 黄色中文字幕在线播放| 成人30分钟免费视频| 最新欧美一二三视频| 9l人妻人人爽人人爽| 亚洲国产精品中文字幕网站| 中文字幕之无码色多多| 日韩欧美在线观看不卡一区二区| 国产大学生援交正在播放| 999热精品视频在线| 婷婷久久久综合中文字幕| 91国内精品自线在拍白富美| 无码日韩人妻精品久久| rct470中文字幕在线| 日韩人妻xxxxx| 综合一区二区三区蜜臀| 久久尻中国美女视频| 92福利视频午夜1000看| 日韩三级电影华丽的外出 | 天堂av在线官网中文| 天天操天天射天天操天天天| 国产黄色片在线收看| 狠狠操狠狠操免费视频| 亚洲av日韩精品久久久| 日韩二区视频一线天婷婷五| 黄片三级三级三级在线观看| 亚洲蜜臀av一区二区三区九色| 久草视频在线免播放| 国产午夜福利av导航| 青青青青在线视频免费观看| 亚洲精品成人网久久久久久小说| 99热久久这里只有精品| 精彩视频99免费在线| 97香蕉碰碰人妻国产樱花| 中文字幕日韩无敌亚洲精品| 男生舔女生逼逼的视频| 天天日天天干天天插舔舔| 久久99久久99精品影院| 欧美偷拍自拍色图片| 淫秽激情视频免费观看| 91精品国产高清自在线看香蕉网| 99精品视频之69精品视频| 成人午夜电影在线观看 久久| 在线免费观看黄页视频| 欧美韩国日本国产亚洲| 91国内精品自线在拍白富美| 天天躁夜夜躁日日躁a麻豆| 熟女在线视频一区二区三区| 免费在线观看污污视频网站| 日本女人一级免费片| 一级黄片大鸡巴插入美女| 中文字幕 亚洲av| 99久久久无码国产精品性出奶水 | 日本黄色特一级视频| 少妇人妻二三区视频| 亚洲激情唯美亚洲激情图片| 在线免费观看国产精品黄色| 一区二区视频在线观看免费观看| 漂亮 人妻被中出中文| 日本精品美女在线观看| 亚洲国产精品久久久久久6| 午夜精品福利一区二区三区p | 美女 午夜 在线视频| 欧美女同性恋免费a| 婷婷久久久久深爱网| 在线免费观看亚洲精品电影| 不卡精品视频在线观看| 人妻在线精品录音叫床| 日日摸夜夜添夜夜添毛片性色av| 久久精品36亚洲精品束缚| 久久农村老妇乱69系列| 免费在线播放a级片| 视频啪啪啪免费观看| weyvv5国产成人精品的视频| 久草视频在线免播放| 100%美女蜜桃视频| 亚洲精品色在线观看视频| 超碰97人人澡人人| 国产欧美精品一区二区高清| 色爱av一区二区三区| 久草视频 久草视频2| 直接观看免费黄网站| 欧美日本aⅴ免费视频| 中文字幕+中文字幕| 老司机福利精品免费视频一区二区| 91精品国产麻豆国产| 日韩中文字幕在线播放第二页| 亚洲美女美妇久久字幕组| 2025年人妻中文字幕乱码在线| 黑人巨大的吊bdsm| 99视频精品全部15| yellow在线播放av啊啊啊 | 亚洲图库另类图片区| 青青草精品在线视频观看| 蝴蝶伊人久久中文娱乐网| 国产精品国色综合久久| 国产乱弄免费视频观看| 精品久久久久久久久久久a√国产| 91免费观看国产免费| 51国产成人精品视频| 中文字幕高清资源站| 精品国产成人亚洲午夜| 沙月文乃人妻侵犯中文字幕在线 | 日本熟妇色熟妇在线观看| 亚洲专区激情在线观看视频| 日韩加勒比东京热二区| 亚洲av第国产精品| 黄色资源视频网站日韩| 涩爱综合久久五月蜜臀| 亚洲精品国产综合久久久久久久久| 日韩美在线观看视频黄| 人妻少妇亚洲精品中文字幕| 男人的天堂一区二区在线观看| 国产伦精品一区二区三区竹菊| 大尺度激情四射网站| 中文字幕av男人天堂| 国产福利小视频免费观看| 亚洲最大免费在线观看| 少妇人妻二三区视频| 欧美男人大鸡吧插女人视频| 欧美日韩国产一区二区三区三州| 中文字幕高清在线免费播放| 午夜精彩视频免费一区| eeuss鲁片一区二区三区| 国产日韩精品免费在线| 99精品视频之69精品视频| 农村胖女人操逼视频| 91片黄在线观看喷潮| 99久久激情婷婷综合五月天| 天天干狠狠干天天操| 女人精品内射国产99| 91自产国产精品视频| 99热99re在线播放| 亚洲精品高清自拍av| 99re6热在线精品| 天天日天天舔天天射进去| 国产综合精品久久久久蜜臀| 二区中出在线观看老师| 亚洲激情av一区二区| 亚洲欧美一区二区三区电影| 超碰97人人做人人爱| 亚洲特黄aaaa片| 国产黄色a级三级三级三级| 欧美黑人性猛交xxxxⅹooo| 欧美视频中文一区二区三区| 亚洲熟色妇av日韩熟色妇在线| 久久久久久久久久一区二区三区 | 国产午夜激情福利小视频在线| 欧美精品免费aaaaaa| 1000部国产精品成人观看视频| 亚洲av色香蕉一区二区三区| 日本黄色三级高清视频| 天天日天天鲁天天操| 新97超碰在线观看| 日本韩国亚洲综合日韩欧美国产| 久久久久久cao我的性感人妻| 久久丁香婷婷六月天| 天天日夜夜干天天操| 人妻熟女中文字幕aⅴ在线| 色综合久久五月色婷婷综合| 欧美一区二区三区乱码在线播放| 国产欧美日韩第三页| 成人福利视频免费在线| 91精品视频在线观看免费| 1区2区3区不卡视频| 久久热久久视频在线观看| av在线观看网址av| 最近中文2019年在线看| 国产精品黄大片在线播放| 国产精品国色综合久久| 美女 午夜 在线视频| 日韩激情文学在线视频 | 国产亚洲精品品视频在线| 国产污污污污网站在线 | 国产普通话插插视频| 绝色少妇高潮3在线观看| 国产自拍黄片在线观看| 人妻少妇亚洲精品中文字幕| 欧美一区二区三区久久久aaa| h国产小视频福利在线观看| 九色porny九色9l自拍视频| 欧美一区二区三区高清不卡tv| 人妻熟女中文字幕aⅴ在线| 97人人妻人人澡人人爽人人精品| 亚洲av色香蕉一区二区三区| 久久久久久久一区二区三| 日韩一区二区电国产精品| 美女骚逼日出水来了| 98精产国品一二三产区区别| 偷拍美女一区二区三区| 亚洲精品中文字幕下载| 亚洲精品麻豆免费在线观看| 人妻激情图片视频小说| 亚洲视频在线观看高清| 在线免费观看99视频| 国产妇女自拍区在线观看| 蜜桃臀av蜜桃臀av| 天天色天天操天天透| 在线国产精品一区二区三区| 一区二区三区欧美日韩高清播放| 偷拍自拍 中文字幕| 欧美成人综合视频一区二区| 玩弄人妻熟妇性色av少妇| 超碰公开大香蕉97| 黑人大几巴狂插日本少妇| 护士特殊服务久久久久久久| 中文人妻AV久久人妻水| 国产精品系列在线观看一区二区| 国产真实乱子伦a视频| 亚洲国产精品久久久久久6| 亚洲 清纯 国产com| 玩弄人妻熟妇性色av少妇| 亚洲国产美女一区二区三区软件| 国产美女午夜福利久久| 护士特殊服务久久久久久久| 人人妻人人人操人人人爽| 国产又粗又黄又硬又爽| 久久这里有免费精品| 75国产综合在线视频| 亚洲国产在线精品国偷产拍| 亚洲成人av一区久久| 天天日天天日天天射天天干| 老司机福利精品免费视频一区二区 | tube69日本少妇| 99热99这里精品6国产| 2021天天色天天干| 精品一区二区三区欧美| 中文字幕第一页国产在线| 2021天天色天天干| 亚洲自拍偷拍精品网| 欧美精品中文字幕久久二区| 2022中文字幕在线| 亚洲成人精品女人久久久| 成人在线欧美日韩国产| 91破解版永久免费| 天天操夜夜操天天操天天操| 青青青国产片免费观看视频| 老师啊太大了啊啊啊尻视频| 色97视频在线播放| av日韩在线免费播放| 一区二区三区日本伦理| 天美传媒mv视频在线观看| 蜜桃精品久久久一区二区| 黄色片黄色片wyaa| 国产精品亚洲а∨天堂免| av一区二区三区人妻| 韩国黄色一级二级三级| 成人亚洲国产综合精品| 免费观看成年人视频在线观看| 一色桃子人妻一区二区三区| 大鸡吧插逼逼视频免费看 | 黄色片一级美女黄色片| 亚洲欧美激情人妻偷拍| 青青热久免费精品视频在线观看 | 日本人妻欲求不满中文字幕| 一个色综合男人天堂| 美女小视频网站在线| 欧美亚洲免费视频观看| 黄色成年网站午夜在线观看| 久久久久久久精品成人热| 亚洲一区二区三区久久午夜| 日韩视频一区二区免费观看| 啊啊啊视频试看人妻| 91综合久久亚洲综合| 天天干天天日天天干天天操| 天天干天天爱天天色| 偷偷玩弄新婚人妻h视频| 国产成人精品久久二区91| 日韩三级电影华丽的外出| 国产一区二区久久久裸臀| free性日本少妇| av乱码一区二区三区| 亚洲精品国产综合久久久久久久久 | 曰本无码人妻丰满熟妇啪啪| 免费观看污视频网站| 边摸边做超爽毛片18禁色戒| 五色婷婷综合狠狠爱| 在线观看成人国产电影| 黄色成人在线中文字幕| 偷拍自拍亚洲美腿丝袜| 久草极品美女视频在线观看| 亚洲av色香蕉一区二区三区| 亚洲熟女女同志女同| 日韩熟女系列一区二区三区| 天天干天天插天天谢| 亚洲欧美另类自拍偷拍色图| 91自产国产精品视频| 精品久久久久久久久久久久人妻| 国产亚洲视频在线观看| av亚洲中文天堂字幕网| 五月天久久激情视频| 亚洲公开视频在线观看| 天美传媒mv视频在线观看| 天堂资源网av中文字幕| 熟女人妻在线观看视频| 1000部国产精品成人观看视频 | 啊啊啊视频试看人妻| 老师啊太大了啊啊啊尻视频| 少妇被强干到高潮视频在线观看| 91久久精品色伊人6882| 免费黄页网站4188| 亚洲午夜福利中文乱码字幕| 国产亚洲视频在线观看| 欧美男人大鸡吧插女人视频| 国产亚洲成人免费在线观看 | 自拍偷拍,中文字幕| 一区二区三区四区视频在线播放| 国产妇女自拍区在线观看| 欧美色呦呦最新网址| 91九色porny蝌蚪国产成人| 成人在线欧美日韩国产| 啊用力插好舒服视频| 久久人人做人人妻人人玩精品vr| 日日夜夜狠狠干视频| 国产精品久久综合久久| 久久久久久久久久一区二区三区| 99热久久这里只有精品| sspd152中文字幕在线| 久久美欧人妻少妇一区二区三区| 亚洲综合在线视频可播放| 精品视频中文字幕在线播放| 国产成人一区二区三区电影网站| 亚洲人妻视频在线网| 欧美一级色视频美日韩| 免费费一级特黄真人片| 偷拍自拍国产在线视频| 91精品国产黑色丝袜| 青娱乐在线免费视频盛宴| 国产精品国色综合久久| 老鸭窝在线观看一区| 午夜在线精品偷拍一区二| 天天摸天天亲天天舔天天操天天爽 | 国产亚洲视频在线观看| 亚洲成人国产综合一区| 99人妻视频免费在线| 日本一道二三区视频久久 | 青青青aaaa免费| 欧美亚洲国产成人免费在线| av一区二区三区人妻| 91精品国产91久久自产久强| 国产精品sm调教视频| 在线免费视频 自拍| mm131美女午夜爽爽爽| 欧美另类一区二区视频| 一色桃子人妻一区二区三区| 免费人成黄页网站在线观看国产| 欧美成人一二三在线网| 色综合久久五月色婷婷综合| 边摸边做超爽毛片18禁色戒| rct470中文字幕在线| av线天堂在线观看| 婷婷激情四射在线观看视频| 亚洲精品ww久久久久久| 91精品国产观看免费| 国产内射中出在线观看| 五十路av熟女松本翔子| 国产女孩喷水在线观看| 五十路丰满人妻熟妇| 久草视频首页在线观看 | 亚洲精品乱码久久久久久密桃明 | 日韩av有码一区二区三区4| 日韩成人综艺在线播放| 在线免费观看黄页视频| 99视频精品全部15| 2020av天堂网在线观看| 中文字幕第三十八页久久| 亚洲国产精品久久久久久6| 美女吃鸡巴操逼高潮视频| 女生被男生插的视频网站| 日本啪啪啪啪啪啪啪| 蝴蝶伊人久久中文娱乐网| 亚洲人人妻一区二区三区| 888欧美视频在线| 中文字幕高清资源站| av中文在线天堂精品| 最新国产精品拍在线观看| 91试看福利一分钟| 久久久久国产成人精品亚洲午夜| 日本啪啪啪啪啪啪啪| 欧美一区二区三区乱码在线播放| jul—619中文字幕在线| 国产性生活中老年人视频网站| 久久久久久九九99精品| 综合激情网激情五月天| 亚洲 自拍 色综合图| 日韩在线视频观看有码在线| 蜜桃精品久久久一区二区| 插逼视频双插洞国产操逼插洞| 少妇人妻真实精品视频| 亚洲免费av在线视频| 国产精品3p和黑人大战| 亚洲午夜电影在线观看| 自拍 日韩 欧美激情| 97年大学生大白天操逼| 天天日天天玩天天摸| 天天爽夜夜爽人人爽QC| 久久久久久9999久久久久| 国产亚州色婷婷久久99精品| 韩国黄色一级二级三级| 亚洲人人妻一区二区三区 | 超级av免费观看一区二区三区| 91国偷自产一区二区三区精品| 日本一区二区三区免费小视频| 丰满的继坶3中文在线观看| 亚洲一区二区三区偷拍女厕91| 欧美久久一区二区伊人| 亚洲欧美在线视频第一页| 最近的中文字幕在线mv视频| 懂色av之国产精品| 久久香蕉国产免费天天| 亚洲区欧美区另类最新章节| 人人妻人人爽人人澡人人精品| 自拍偷拍亚洲另类色图| 大鸡巴后入爆操大屁股美女| 午夜久久久久久久99| 国产乱子伦精品视频潮优女| 黄色av网站免费在线| 日韩少妇人妻精品无码专区| 91成人在线观看免费视频| 91精品激情五月婷婷在线| 亚洲少妇人妻无码精品| 欧洲日韩亚洲一区二区三区 | 伊人成人在线综合网| 国产在线91观看免费观看| 97国产福利小视频合集| 亚洲免费视频欧洲免费视频| 免费啪啪啪在线观看视频| 精品日产卡一卡二卡国色天香| 超级av免费观看一区二区三区| 日本女大学生的黄色小视频| 99久久中文字幕一本人| 午夜影院在线观看视频羞羞羞| 在线国产精品一区二区三区| 久久久久久久久久一区二区三区| 午夜在线观看岛国av,com| 国产高清在线在线视频| 51精品视频免费在线观看| 亚洲另类伦春色综合小| 在线观看视频网站麻豆| 亚洲高清国产拍青青草原| www久久久久久久久久久| 偷青青国产精品青青在线观看| 国产va在线观看精品| 亚洲午夜电影在线观看| 精品国产高潮中文字幕| 天天操,天天干,天天射| 在线观看免费岛国av| 午夜精品久久久久久99热| 中文字幕在线乱码一区二区| 春色激情网欧美成人| 超pen在线观看视频公开97| 成人激情文学网人妻| 亚洲av成人免费网站| 小泽玛利亚视频在线观看| 老司机免费福利视频网| 亚洲综合另类精品小说| 欧美性感尤物人妻在线免费看| www,久久久,com| 社区自拍揄拍尻屁你懂的| 日韩a级黄色小视频| 精品黑人巨大在线一区| 国产91嫩草久久成人在线视频| 91久久精品色伊人6882| 五十路熟女人妻一区二| 亚洲av日韩av第一区二区三区| 亚洲午夜福利中文乱码字幕| 日本av在线一区二区三区| 国产熟妇一区二区三区av| 日韩美女福利视频网| 亚洲一区二区三区uij| 天天色天天操天天舔| 91破解版永久免费| 中文字幕高清免费在线人妻| 久久丁香花五月天色婷婷| 玖玖一区二区在线观看| 老有所依在线观看完整版| 婷婷色国产黑丝少妇勾搭AV | 国产高清女主播在线| 自拍偷拍日韩欧美亚洲| 2021年国产精品自拍| 男大肉棒猛烈插女免费视频 | 熟女俱乐部一二三区| 日本裸体熟妇区二区欧美| 中文字幕 码 在线视频| rct470中文字幕在线| 激情五月婷婷免费视频| 久久久久久cao我的性感人妻| 91国内精品久久久久精品一| rct470中文字幕在线| 久久久极品久久蜜桃| 抽查舔水白紧大视频| 精品国产污污免费网站入口自| 精品人妻每日一部精品| 蜜臀av久久久久蜜臀av麻豆| 香港一级特黄大片在线播放| 色综合久久久久久久久中文| 成年人该看的视频黄免费| 国产精品人妻66p| 欧美亚洲国产成人免费在线| 日韩精品中文字幕福利| 国产chinesehd精品麻豆| 亚洲av在线观看尤物| 熟女人妻在线观看视频| 在线免费观看视频一二区| 日韩亚洲高清在线观看| 偷拍自拍亚洲视频在线观看| 欧美va不卡视频在线观看| 在线网站你懂得老司机| 黄工厂精品视频在线观看 | 国产一区二区神马久久| 亚洲成人免费看电影| 中文字幕午夜免费福利视频| 精品高跟鞋丝袜一区二区| 美女吃鸡巴操逼高潮视频| 首之国产AV医生和护士小芳| 香蕉av影视在线观看| 337p日本大胆欧美人| 视频一区 二区 三区 综合| 免费无毒热热热热热热久| 超碰公开大香蕉97| 水蜜桃一区二区三区在线观看视频| 在线观看免费视频网| 日本少妇人妻xxxxxhd| 色哟哟在线网站入口| 老有所依在线观看完整版| 亚洲第一黄色在线观看| 亚洲日本一区二区三区| 国产精选一区在线播放| 亚洲成高清a人片在线观看| 中文字幕人妻av在线观看| 少妇高潮一区二区三区| 亚洲1区2区3区精华液| 久久久久久99国产精品| 国产视频一区在线观看| 韩国三级aaaaa高清视频| 欧美黄片精彩在线免费观看 | 婷婷六月天中文字幕| 青青青视频手机在线观看| 18禁精品网站久久| 国产精品视频男人的天堂| 精品久久婷婷免费视频| 亚洲超碰97人人做人人爱| 1区2区3区不卡视频| 国产使劲操在线播放| 大陆av手机在线观看| 国产丰满熟女成人视频| 亚洲特黄aaaa片| 亚洲精品无码色午夜福利理论片| 亚洲av琪琪男人的天堂| 色秀欧美视频第一页| 天天干天天操天天玩天天射| 2020av天堂网在线观看| 亚洲国产精品黑丝美女| wwwxxx一级黄色片| 18禁美女黄网站色大片下载| 久久艹在线观看视频| 日韩成人免费电影二区| 久久精品亚洲国产av香蕉| 久久久人妻一区二区| 日本熟妇色熟妇在线观看| 天天色天天操天天透| 日本黄色三级高清视频| 沈阳熟妇28厘米大战黑人| aaa久久久久久久久| 免费看高清av的网站| 国产欧美精品免费观看视频| 国产精品人妻熟女毛片av久| 日韩中文字幕在线播放第二页| 涩涩的视频在线观看视频| 99久久中文字幕一本人| 中文字幕综合一区二区| 大鸡巴插入美女黑黑的阴毛| 欧美精产国品一二三区| 夏目彩春在线中文字幕| 亚洲综合乱码一区二区| 大屁股熟女一区二区三区| 91福利在线视频免费观看| 中文字幕一区二区亚洲一区| 亚洲 自拍 色综合图| 热99re69精品8在线播放| 亚洲天堂成人在线观看视频网站| 亚洲精品乱码久久久久久密桃明| yy96视频在线观看| 91人妻人人做人人爽在线| 日韩少妇人妻精品无码专区| 熟女俱乐部一二三区| 日韩精品中文字幕福利| 国产V亚洲V天堂无码欠欠| 欧美怡红院视频在线观看| 欧美一区二区三区久久久aaa| 韩国女主播精品视频网站| 欧美日韩v中文在线| 国产清纯美女al在线| 久久丁香婷婷六月天| 黄色资源视频网站日韩| av日韩在线免费播放| 做爰视频毛片下载蜜桃视频1| 国产高清在线观看1区2区| 国产麻豆国语对白露脸剧情| 日韩精品电影亚洲一区| 9国产精品久久久久老师| 午夜免费体验区在线观看 | 人妻丰满熟妇综合网| 黄色中文字幕在线播放| 99国内精品永久免费视频| 国产又大又黄免费观看| 国产女人露脸高潮对白视频| 在线观看视频网站麻豆| 中文字幕中文字幕人妻| 亚洲一区二区三区五区 | 国产精品久久久久国产三级试频| av天堂中文字幕最新| 热99re69精品8在线播放| 久久久久久久精品成人热| 少妇人妻二三区视频| 在线观看欧美黄片一区二区三区| 少妇人妻久久久久视频黄片| 馒头大胆亚洲一区二区| 国产精品系列在线观看一区二区| 99久久久无码国产精品性出奶水 | 男大肉棒猛烈插女免费视频| 99久久成人日韩欧美精品| 视频在线亚洲一区二区| 天天干天天操天天玩天天射 | 人妻少妇中文有码精品| 搡老熟女一区二区在线观看| 晚上一个人看操B片| 亚洲 欧美 自拍 偷拍 在线| 黑人解禁人妻叶爱071| 亚洲久久午夜av一区二区| av在线免费资源站| 中国熟女@视频91| 爱有来生高清在线中文字幕| 唐人色亚洲av嫩草| 国产亚洲欧美视频网站| 超碰97人人澡人人| 天天日天天日天天擦| 亚洲精品在线资源站| 红杏久久av人妻一区| 一区二区在线观看少妇| 天天做天天干天天舔| 88成人免费av网站| 新97超碰在线观看| 久久人人做人人妻人人玩精品vr| 日本韩国在线观看一区二区| 日本高清撒尿pissing| 男生用鸡操女生视频动漫 | 97青青青手机在线视频| 顶级尤物粉嫩小尤物网站| 国产大学生援交正在播放| 一区二区三区av高清免费| 涩涩的视频在线观看视频| 人妻另类专区欧美制服| 蜜桃专区一区二区在线观看| 亚洲国产精品久久久久蜜桃| 2020av天堂网在线观看| 97精品视频在线观看| 精品久久久久久久久久中文蒉| 免费观看丰满少妇做受| 在线免费91激情四射 | ka0ri在线视频| 国产精品一区二区三区蜜臀av| 久久久久久久精品成人热| caoporm超碰国产| 好了av中文字幕在线| 操人妻嗷嗷叫视频一区二区| 天天干天天搞天天摸| 老司机99精品视频在线观看| 久久久久久久久久久久久97| 超碰公开大香蕉97| 97青青青手机在线视频 | 国产黄色片在线收看| av老司机精品在线观看| 极品粉嫩小泬白浆20p主播| 国产成人精品久久二区91| 天天操天天干天天艹| 2022天天干天天操| 午夜精彩视频免费一区| 国内资源最丰富的网站| 丝袜肉丝一区二区三区四区在线看| 97国产精品97久久| 97国产在线av精品| 婷婷综合亚洲爱久久| 欧洲精品第一页欧洲精品亚洲| 久久麻豆亚洲精品av| 亚洲福利天堂久久久久久| 免费在线看的黄片视频| 真实国模和老外性视频| 99re久久这里都是精品视频| 欧美一区二区三区四区性视频| 国产一区二区神马久久| 青青青视频自偷自拍38碰| 日韩人妻丝袜中文字幕| 亚洲成人av一区久久| 午夜国产免费福利av| 激情图片日韩欧美人妻| 亚洲美女美妇久久字幕组| 快点插进来操我逼啊视频| 色97视频在线播放| 日本黄在免费看视频| 阴茎插到阴道里面的视频| 天天躁日日躁狠狠躁躁欧美av| 成年美女黄网站18禁久久| 五色婷婷综合狠狠爱| 大骚逼91抽插出水视频| 亚洲高清一区二区三区视频在线| 国产成人小视频在线观看无遮挡| 粉嫩av蜜乳av蜜臀| av俺也去在线播放| 五月天色婷婷在线观看视频免费| 一区二区熟女人妻视频| 唐人色亚洲av嫩草| 色哟哟在线网站入口| 91大屁股国产一区二区| 日本三极片视频网站观看| 91国偷自产一区二区三区精品| 最近的中文字幕在线mv视频| 大胆亚洲av日韩av| 欧美怡红院视频在线观看| 99精品视频之69精品视频 | 天堂av在线最新版在线| 在线免费观看黄页视频| 337p日本大胆欧美人| 大鸡吧插入女阴道黄色片| 一区二区三区欧美日韩高清播放| 欧美精产国品一二三产品价格| 久久香蕉国产免费天天| 中文字幕人妻熟女在线电影| 中文字幕一区二区人妻电影冢本 | 日本人妻少妇18—xx| 欧美亚洲中文字幕一区二区三区 | 中文字幕中文字幕人妻| av乱码一区二区三区| 99婷婷在线观看视频| 92福利视频午夜1000看| 后入美女人妻高清在线| 任你操视频免费在线观看| 91综合久久亚洲综合| 日日夜夜精品一二三| 午夜在线观看岛国av,com| 一级黄色片夫妻性生活| 亚洲天天干 夜夜操| 2022国产综合在线干| 大屁股肉感人妻中文字幕在线| 亚洲国产精品中文字幕网站| 日本脱亚入欧是指什么| 任你操视频免费在线观看| 中文字幕日韩无敌亚洲精品| 91九色国产porny蝌蚪| 亚洲欧美激情中文字幕| 日韩熟女系列一区二区三区| 夏目彩春在线中文字幕| 亚洲自拍偷拍综合色| 成人30分钟免费视频| 欧美日韩国产一区二区三区三州| 自拍偷拍亚洲精品第2页| 免费手机黄页网址大全| 偷拍自拍福利视频在线观看| 精品人妻一二三区久久| 久草视频在线免播放| 亚洲熟妇久久无码精品| 大陆胖女人与丈夫操b国语高清| 国产精品免费不卡av| 国产va在线观看精品| 岛国毛片视频免费在线观看| 五月色婷婷综合开心网4438| 2019av在线视频| 韩国黄色一级二级三级| 中文字幕在线一区精品| 久久久久久久久久久久久97| 91‖亚洲‖国产熟女| 欧美一级视频一区二区| 国产使劲操在线播放| 人人妻人人澡人人爽人人dvl| 内射久久久久综合网| 亚洲公开视频在线观看| 欧美地区一二三专区| 国产在线观看免费人成短视频| 久久久久久97三级| 欧美精品免费aaaaaa| 中文字幕人妻一区二区视频| 亚洲一区二区三区av网站| 亚洲熟色妇av日韩熟色妇在线| 黑人3p华裔熟女普通话| 色综合色综合色综合色| 老熟妇凹凸淫老妇女av在线观看| 在线视频自拍第三页| 欧美特色aaa大片| 视频 国产 精品 熟女 | 国产精品人久久久久久| 91亚洲精品干熟女蜜桃频道| 国产中文字幕四区在线观看| 18禁美女黄网站色大片下载| 一区二区三区美女毛片| 夜色福利视频在线观看| 亚洲福利精品福利精品福利| 丝袜亚洲另类欧美变态| av天堂加勒比在线| 中文字幕第一页国产在线| 女同久久精品秋霞网| 国产乱子伦精品视频潮优女| av森泽佳奈在线观看| 久草福利电影在线观看| 成人精品视频99第一页| 首之国产AV医生和护士小芳| 熟妇一区二区三区高清版| 又粗又硬又猛又爽又黄的| 亚洲欧美日韩视频免费观看| 精品suv一区二区69| 婷婷五月亚洲综合在线| 国产精品3p和黑人大战| 男人和女人激情视频| 日本少妇人妻xxxxx18| 偷拍自拍 中文字幕| 女生自摸在线观看一区二区三区| 亚洲av无码成人精品区辽| 人妻熟女中文字幕aⅴ在线| 1024久久国产精品| 日本午夜福利免费视频| 操日韩美女视频在线免费看| 最新国产精品拍在线观看| 黄色片年轻人在线观看| 激情五月婷婷免费视频| 成人区人妻精品一区二视频| 熟女91pooyn熟女| gay gay男男瑟瑟在线网站| 欧亚日韩一区二区三区观看视频 | 日韩美女综合中文字幕pp| 在线观看av2025| mm131美女午夜爽爽爽| 75国产综合在线视频| 深夜男人福利在线观看| 黑人解禁人妻叶爱071| 日本乱人一区二区三区| 日韩无码国产精品强奸乱伦| 成人蜜桃美臀九一一区二区三区| 亚洲午夜在线视频福利| 不卡一区一区三区在线| 水蜜桃国产一区二区三区| 天天日天天鲁天天操| 人人爱人人妻人人澡39| 日本少妇的秘密免费视频| 成人蜜臀午夜久久一区| 精品av久久久久久久| 国产精品女邻居小骚货| 大胸性感美女羞爽操逼毛片| 韩国爱爱视频中文字幕| 2021天天色天天干| eeuss鲁片一区二区三区| 在线观看国产免费麻豆| 亚洲中文字字幕乱码| 成人区人妻精品一区二视频 | 国产福利小视频二区| 综合精品久久久久97| 成年女人免费播放视频| 久久久精品国产亚洲AV一| 视频二区在线视频观看| 欧美亚洲少妇福利视频| 偷拍自拍亚洲视频在线观看| 中文字幕一区二 区二三区四区| 狠狠鲁狠狠操天天晚上干干| 93精品视频在线观看| 一区二区三区久久久91| 亚洲精品久久视频婷婷| 男生舔女生逼逼视频| 日韩精品中文字幕在线| 国产精品久久久久久美女校花| 国产精品中文av在线播放| 日本高清撒尿pissing| 天天干夜夜操天天舔| 在线观看的a站 最新| 女蜜桃臀紧身瑜伽裤| 丝袜美腿视频诱惑亚洲无| 亚洲免费av在线视频| 沙月文乃人妻侵犯中文字幕在线 | 欧美成人精品欧美一级黄色| 亚洲国产欧美一区二区三区久久| 亚洲综合另类欧美久久| 国产激情av网站在线观看| 中文字幕av熟女人妻| 日韩美在线观看视频黄| 成人免费做爰高潮视频| 免费观看成年人视频在线观看| 绯色av蜜臀vs少妇| 免费观看成年人视频在线观看| 日本欧美视频在线观看三区| 91精品资源免费观看| 一区二区三区麻豆福利视频| 精品人妻伦一二三区久| 久草视频中文字幕在线观看| 天天干天天日天天干天天操| 干逼又爽又黄又免费的视频| 亚洲av自拍偷拍综合| 亚洲精品国产在线电影| 粉嫩欧美美人妻小视频| 亚洲 色图 偷拍 欧美| 国产麻豆乱子伦午夜视频观看| 日本免费视频午夜福利视频| mm131美女午夜爽爽爽| 人人人妻人人澡人人| rct470中文字幕在线| 久草视频中文字幕在线观看| 日本黄色特一级视频| 国产综合高清在线观看| 日韩中文字幕福利av| 天天做天天爽夜夜做少妇| 黑人3p华裔熟女普通话| 亚洲成人av在线一区二区| 亚洲视频在线观看高清| 啊啊好大好爽啊啊操我啊啊视频| 精品人妻一二三区久久| 国产精品系列在线观看一区二区 | 国产又色又刺激在线视频 | 日本五十路熟新垣里子| 国产亚洲国产av网站在线| 女生被男生插的视频网站| 青青青青青手机视频| gogo国模私拍视频| 欧美一区二区三区在线资源| 大尺度激情四射网站| 日本一区美女福利视频| 午夜精品九一唐人麻豆嫩草成人| 亚洲天堂av最新网址| 成人24小时免费视频| ka0ri在线视频| 亚洲区欧美区另类最新章节| 国产麻豆乱子伦午夜视频观看| 亚洲国产精品免费在线观看| 亚洲 欧美 自拍 偷拍 在线| 狠狠鲁狠狠操天天晚上干干| 99精品免费久久久久久久久a| 人妻在线精品录音叫床| 精品高跟鞋丝袜一区二区| 天天色天天舔天天射天天爽 | 欧美成人猛片aaaaaaa| 日本中文字幕一二区视频| 少妇人妻真实精品视频| 激情啪啪啪啪一区二区三区| 欧美黑人巨大性xxxxx猛交| 91一区精品在线观看| 亚洲av琪琪男人的天堂| 白白操白白色在线免费视频 | 午夜美女福利小视频| 国产视频网站国产视频| asmr福利视频在线观看| 天天通天天透天天插| 97人妻色免费视频| 在线观看免费视频网| 北条麻妃高跟丝袜啪啪| av中文字幕在线观看第三页| 在线观看视频一区麻豆| 一区二区三区av高清免费| 国产一区二区视频观看| 国产精品午夜国产小视频| 国产成人精品一区在线观看| 中文字幕无码一区二区免费| 亚洲一区二区人妻av| 特大黑人巨大xxxx| 夜夜骑夜夜操夜夜奸| 午夜久久久久久久精品熟女| 欧美在线偷拍视频免费看| aiss午夜免费视频| 欧美日韩情色在线观看| 97人妻色免费视频| 国产福利小视频免费观看| 91久久人澡人人添人人爽乱| 超污视频在线观看污污污| 国产美女精品福利在线| 黄色中文字幕在线播放| 一本久久精品一区二区| 中文字幕在线欧美精品| yellow在线播放av啊啊啊| 在线视频国产欧美日韩| 成人网18免费视频版国产| 任你操任你干精品在线视频| 日韩欧美高清免费在线| 啪啪啪18禁一区二区三区| 亚洲成人国产综合一区| 五月精品丁香久久久久福利社| 亚洲国产在人线放午夜| 国产亚州色婷婷久久99精品| 亚洲av一妻不如妾| 91中文字幕最新合集| 福利视频网久久91| 性感美女高潮视频久久久| 亚洲欧美综合在线探花| 国产无遮挡裸体免费直播视频| 黑人变态深video特大巨大| 男人操女人的逼免费视频| 三级等保密码要求条款| 人妻熟女中文字幕aⅴ在线| 噜噜色噜噜噜久色超碰| 秋霞午夜av福利经典影视| 3337p日本欧洲大胆色噜噜| 国产97在线视频观看| 亚洲国产中文字幕啊啊啊不行了| 91综合久久亚洲综合| 老司机免费视频网站在线看| 成人蜜臀午夜久久一区| 亚洲综合一区二区精品久久| 国产日本精品久久久久久久| 日视频免费在线观看| 日韩一个色综合导航| 日本一区精品视频在线观看| 特黄老太婆aa毛毛片| 亚洲高清国产自产av| 一区二区熟女人妻视频| 国产亚州色婷婷久久99精品| 五月婷婷在线观看视频免费| 天堂女人av一区二区| 香蕉片在线观看av| 伊人综合aⅴ在线网| 亚洲av色图18p| 韩国女主播精品视频网站| 日本后入视频在线观看| 亚洲免费视频欧洲免费视频| 国产第一美女一区二区三区四区| 青青色国产视频在线| 国产91久久精品一区二区字幕| 人妻少妇亚洲一区二区| 国产夫妻视频在线观看免费| 57pao国产一区二区| 亚洲av天堂在线播放| 精品一线二线三线日本| 少妇一区二区三区久久久| 中文字幕成人日韩欧美| 视频一区二区在线免费播放| 天天插天天色天天日| 成人亚洲国产综合精品| 3D动漫精品啪啪一区二区下载| 九一传媒制片厂视频在线免费观看 | 在线免费观看日本伦理| 精品久久久久久久久久久久人妻| 午夜美女少妇福利视频| 日韩二区视频一线天婷婷五| 亚洲久久午夜av一区二区| 午夜福利资源综合激情午夜福利资 | 激情色图一区二区三区| 亚洲av成人网在线观看| 亚洲国产精品美女在线观看| 好吊视频—区二区三区| avjpm亚洲伊人久久| av乱码一区二区三区| 亚洲综合另类欧美久久| 亚洲av日韩精品久久久| 国产亚洲精品欧洲在线观看| 亚洲成人激情视频免费观看了 | 激情综合治理六月婷婷| 国产精品人妻66p| 国产精品视频欧美一区二区| 日本一道二三区视频久久| 国产自拍黄片在线观看| 黑人变态深video特大巨大| 亚洲国产成人av在线一区| 国产一区二区在线欧美| 午夜av一区二区三区| 欧美女同性恋免费a| 91久久人澡人人添人人爽乱| 国产+亚洲+欧美+另类| 欧美精品资源在线观看| 天天艹天天干天天操| 亚洲欧美综合在线探花| 不卡一区一区三区在线| 日本高清成人一区二区三区| 久久久制服丝袜中文字幕| 香蕉片在线观看av| 亚洲午夜电影在线观看| 亚洲高清免费在线观看视频| 日韩av中文在线免费观看| 宅男噜噜噜666国产| 色av色婷婷人妻久久久精品高清| 久久久久久性虐视频| 国产清纯美女al在线| 国产精品视频资源在线播放| 91九色国产porny蝌蚪| 亚洲成a人片777777| 91国内精品自线在拍白富美| 在线免费观看视频一二区| 521精品视频在线观看| 91欧美在线免费观看| 中文字幕一区二区人妻电影冢本| 这里有精品成人国产99| 92福利视频午夜1000看| 一区二区三区av高清免费| 视频二区在线视频观看| 亚洲国产40页第21页| 欧美精品中文字幕久久二区| 美女福利视频网址导航| 无忧传媒在线观看视频| 久久久久五月天丁香社区| 大屁股肉感人妻中文字幕在线| 搡老熟女一区二区在线观看| 成人性黑人一级av| 在线制服丝袜中文字幕| 国产在线观看免费人成短视频| 国产精品视频一区在线播放| 久久香蕉国产免费天天| 欧美在线精品一区二区三区视频| 强行扒开双腿猛烈进入免费版| 精品一区二区亚洲欧美| 亚洲人一区二区中文字幕| 国产精品自偷自拍啪啪啪| 啪啪啪啪啪啪啪免费视频| 天天夜天天日天天日| chinese国产盗摄一区二区| 91精品国产综合久久久蜜| 40道精品招牌菜特色| 99人妻视频免费在线| 成人sm视频在线观看| 蜜桃视频入口久久久| 早川濑里奈av黑人番号| 91九色porny国产在线| 一区二区三区四区中文| 国产精彩对白一区二区三区| 在线网站你懂得老司机| 日韩av熟妇在线观看| 国产福利小视频免费观看| 综合页自拍视频在线播放| 精品视频一区二区三区四区五区| 人妻熟女中文字幕aⅴ在线| 日本av在线一区二区三区| 91社福利《在线观看| 蜜桃臀av蜜桃臀av| av欧美网站在线观看| 污污小视频91在线观看| 9l人妻人人爽人人爽| 东游记中文字幕版哪里可以看到| 不卡日韩av在线观看| 国产91精品拍在线观看| aⅴ精产国品一二三产品| 大香蕉伊人中文字幕| 狠狠操狠狠操免费视频| av完全免费在线观看av| 91老师蜜桃臀大屁股| 中国把吊插入阴蒂的视频| 日本三极片中文字幕| 欧美另类z0z变态| 欧美美女人体视频一区| 精彩视频99免费在线| 色综合久久五月色婷婷综合| 99视频精品全部15| www,久久久,com| 亚洲av无乱一区二区三区性色| 中文字幕国产专区欧美激情| 色综合久久久久久久久中文| 老司机免费福利视频网| 亚洲精品乱码久久久久久密桃明| 中文字幕综合一区二区| 专门看国产熟妇的网站| av亚洲中文天堂字幕网| 在线免费观看日本伦理| 一区二区三区 自拍偷拍| 国产精品久久久久久美女校花| 亚洲一区二区三区久久午夜| 性色蜜臀av一区二区三区| 黄色中文字幕在线播放| 中文字幕av熟女人妻| 欧洲日韩亚洲一区二区三区| 污污小视频91在线观看| 丝袜美腿视频诱惑亚洲无| 欧美中国日韩久久精品| 天天摸天天亲天天舔天天操天天爽| 亚洲午夜伦理视频在线 | 天码人妻一区二区三区在线看| 亚洲超碰97人人做人人爱| 午夜在线观看岛国av,com| 又色又爽又黄又刺激av网站| 免费岛国喷水视频在线观看| av手机在线观播放网站| 91大神福利视频网| 欧美va亚洲va天堂va| 狠狠操狠狠操免费视频| 91she九色精品国产| 亚洲高清国产一区二区三区| 国产精品午夜国产小视频| 国产内射中出在线观看| 亚洲成人黄色一区二区三区| 一区二区三区欧美日韩高清播放| 青青青激情在线观看视频| 亚洲免费av在线视频| 国产精品人久久久久久| 日韩三级黄色片网站| 精品黑人巨大在线一区| 亚洲图库另类图片区| 青青草原网站在线观看| 国产女人露脸高潮对白视频| 91麻豆精品91久久久久同性| 中文字幕日韩精品日本| 久草视频在线一区二区三区资源站| 亚洲成人av一区久久| 人妻自拍视频中国大陆| 久草视频首页在线观看| 精品国产高潮中文字幕| 综合页自拍视频在线播放| 丝袜国产专区在线观看| 亚洲欧美另类自拍偷拍色图| 中文字幕奴隷色的舞台50| 欧洲亚洲欧美日韩综合| 91超碰青青中文字幕| 丝袜长腿第一页在线| 男人的天堂在线黄色| 经典av尤物一区二区| 欧美一级片免费在线成人观看| 午夜国产福利在线观看| 91亚洲精品干熟女蜜桃频道| 丰满少妇人妻xxxxx| 亚洲自拍偷拍综合色| 爱有来生高清在线中文字幕| 精品视频中文字幕在线播放 | 亚洲免费va在线播放| 天天躁日日躁狠狠躁av麻豆| 一区二区三区日本伦理| 国产亚洲四十路五十路| 老司机欧美视频在线看| 日韩成人性色生活片| 日本韩国免费一区二区三区视频| 精品一区二区亚洲欧美| 最新欧美一二三视频| 国产janese在线播放| 不卡一区一区三区在线| 成年午夜免费无码区| 精品欧美一区二区vr在线观看| 男人插女人视频网站| 国产成人精品一区在线观看 | 亚洲老熟妇日本老妇| 91试看福利一分钟| 熟女视频一区,二区,三区 | 18禁美女黄网站色大片下载| 91p0rny九色露脸熟女| 久久这里有免费精品| 免费黄页网站4188| 精品久久久久久久久久久久人妻| 福利片区一区二体验区| 日韩成人免费电影二区| 青青在线视频性感少妇和隔壁黑丝| av日韩在线观看大全| 免费看高清av的网站| 2021最新热播中文字幕| 亚洲一区久久免费视频| 老司机免费福利视频网| 色综合天天综合网国产成人| 自拍 日韩 欧美激情| 日本五十路熟新垣里子| 日韩美在线观看视频黄| 成人福利视频免费在线| 国产性色生活片毛片春晓精品| 日噜噜噜夜夜噜噜噜天天噜噜噜| 成人av电影免费版| 亚洲成人线上免费视频观看| 欧美成人猛片aaaaaaa| 欧美在线精品一区二区三区视频| 国产精品国产精品一区二区| 中文字幕在线免费第一页| 亚洲 欧美 自拍 偷拍 在线| 激情伦理欧美日韩中文字幕| 久久热久久视频在线观看| 大胆亚洲av日韩av| 中文字幕av一区在线观看| 久久丁香花五月天色婷婷| www日韩a级s片av| 免费费一级特黄真人片| 偷拍自拍国产在线视频| 91she九色精品国产| 91精品国产91久久自产久强| 亚洲成人线上免费视频观看| 一区二区三区精品日本| 久久久人妻一区二区| 99精品国自产在线人| 黄色的网站在线免费看| 白白操白白色在线免费视频| 天天日天天鲁天天操| 亚洲va国产va欧美精品88| 传媒在线播放国产精品一区| aⅴ五十路av熟女中出| 成人H精品动漫在线无码播放| 亚洲天堂av最新网址| 四川乱子伦视频国产vip| 亚洲偷自拍高清视频| 日本欧美视频在线观看三区| 宅男噜噜噜666免费观看| 18禁网站一区二区三区四区| 超碰公开大香蕉97| 精品美女在线观看视频在线观看| 久精品人妻一区二区三区| 自拍 日韩 欧美激情| 91国内视频在线观看| 欧美精品中文字幕久久二区| 偷拍美女一区二区三区| 国产1区,2区,3区| 国产激情av网站在线观看| 亚洲熟女综合色一区二区三区四区| 好太好爽好想要免费| 日韩在线视频观看有码在线| 天天操夜夜操天天操天天操| 91久久综合男人天堂| 91啪国自产中文字幕在线| 狠狠操狠狠操免费视频| 91九色国产熟女一区二区| 91九色国产熟女一区二区| 亚洲一区av中文字幕在线观看| 婷婷色中文亚洲网68| 亚洲精品高清自拍av| 国产精品自拍视频大全| 人妻丝袜av在线播放网址| 色呦呦视频在线观看视频| 97国产在线av精品| 97欧洲一区二区精品免费| 久久丁香花五月天色婷婷| 亚洲激情av一区二区| 人妻在线精品录音叫床| 国产成人午夜精品福利| 自拍偷拍日韩欧美亚洲| 色婷婷综合激情五月免费观看| 综合一区二区三区蜜臀| 日韩伦理短片在线观看| 午夜蜜桃一区二区三区| 亚洲区欧美区另类最新章节| 毛片av在线免费看| 国产精品国产三级麻豆| 天天插天天狠天天操| 麻豆精品成人免费视频| 国产综合精品久久久久蜜臀| 国产精品自拍在线视频| www,久久久,com| 午夜免费体验区在线观看| 年轻的人妻被夫上司侵犯| 国产清纯美女al在线| 国产丰满熟女成人视频| 男女第一次视频在线观看| 国产麻豆精品人妻av| 中文字幕亚洲中文字幕| 91桃色成人网络在线观看| 美女小视频网站在线| 久久亚洲天堂中文对白| 伊人综合aⅴ在线网| 91欧美在线免费观看| 日韩不卡中文在线视频网站| 亚洲av日韩高清hd| 最新国产精品拍在线观看| 国产精品成久久久久三级蜜臀av| 不戴胸罩引我诱的隔壁的人妻| 国产精品久久久久久美女校花| 年轻的人妻被夫上司侵犯| 欧美一区二区中文字幕电影 | 91天堂精品一区二区| 韩国三级aaaaa高清视频| 久久久久久久精品老熟妇| 999九九久久久精品| 亚洲va国产va欧美va在线| 亚洲精品国品乱码久久久久| 国产美女一区在线观看| 边摸边做超爽毛片18禁色戒| 只有精品亚洲视频在线观看| 久久久久久久久久久久久97| 美女少妇亚洲精选av| 亚洲一级美女啪啪啪| 一区二区三区麻豆福利视频| 国产精品久久久久久久久福交| 91麻豆精品传媒国产黄色片| 亚洲熟妇无码一区二区三区| 99av国产精品欲麻豆| 免费在线播放a级片| 护士小嫩嫩又紧又爽20p| 99精品视频在线观看婷婷| 东京热男人的av天堂| 91啪国自产中文字幕在线| 日本男女操逼视频免费看| 偷拍自拍国产在线视频| 亚洲综合图片20p| 国产一区二区火爆视频| 熟女俱乐部一二三区| 国产一区二区火爆视频| 中文字幕之无码色多多| 亚洲 欧美 自拍 偷拍 在线| 亚洲精品午夜aaa久久| 国产麻豆91在线视频| 大尺度激情四射网站| 国产视频精品资源网站| 国产1区,2区,3区| 3344免费偷拍视频| 韩国女主播精品视频网站| 亚欧在线视频你懂的| 亚洲成人线上免费视频观看| 亚洲综合另类欧美久久| 亚洲高清一区二区三区视频在线| 91免费观看在线网站| 亚洲视频在线视频看视频在线| 国产极品美女久久久久久| 哥哥姐姐综合激情小说| 538精品在线观看视频| 欧美成一区二区三区四区| 国产精品污污污久久| 亚洲护士一区二区三区| 天天操天天弄天天射| 国产又粗又黄又硬又爽| 久久艹在线观看视频| 国产亚洲精品视频合集| 99re国产在线精品| 97国产精品97久久| 一区二区三区另类在线| 天天躁日日躁狠狠躁av麻豆| 亚洲一级av无码一级久久精品| 熟女人妻在线观看视频| 亚洲av成人免费网站| 亚洲专区激情在线观看视频| 亚洲va欧美va人人爽3p| 丝袜长腿第一页在线| 人妻激情图片视频小说| 一区二区三区的久久的蜜桃的视频 | 11久久久久久久久久久| 欧美va亚洲va天堂va| 国产一级精品综合av| 国产黄色片在线收看| 18禁无翼鸟成人在线| 78色精品一区二区三区| 国产av一区2区3区| 色哟哟国产精品入口| 色吉吉影音天天干天天操| 一区二区三区四区五区性感视频| 欧美交性又色又爽又黄麻豆| 性感美女高潮视频久久久| 和邻居少妇愉情中文字幕| 一级黄片久久久久久久久| 国产午夜无码福利在线看| 中文字幕+中文字幕| 成人av天堂丝袜在线观看| 国产普通话插插视频| 夜夜骑夜夜操夜夜奸| 亚洲 自拍 色综合图| 无码中文字幕波多野不卡| 日本一二三区不卡无| 夜夜嗨av一区二区三区中文字幕| 这里只有精品双飞在线播放| 75国产综合在线视频| 大黑人性xxxxbbbb| 国产在线自在拍91国语自产精品| 日韩北条麻妃一区在线| 99热久久这里只有精品8| 亚洲国产精品美女在线观看 | 337p日本大胆欧美人| 福利在线视频网址导航| 日韩欧美一级黄片亚洲| 91精品综合久久久久3d动漫| 欧美另类一区二区视频| 综合页自拍视频在线播放| 午夜精品一区二区三区更新| 免费在线看的黄网站| 色婷婷精品大在线观看| 99热国产精品666| 中文字幕亚洲久久久| 国语对白xxxx乱大交| 欧美男人大鸡吧插女人视频| 亚洲精品在线资源站| 日视频免费在线观看| 亚洲美女美妇久久字幕组| 综合色区亚洲熟妇shxstz| 亚洲精品 日韩电影| 色狠狠av线不卡香蕉一区二区| 免费黄色成人午夜在线网站| 五十路息与子猛烈交尾视频| 天美传媒mv视频在线观看| 国产精彩福利精品视频| 中国无遮挡白丝袜二区精品 | 扒开让我视频在线观看| 国产在线观看黄色视频| 国产在线免费观看成人| 经典国语激情内射视频| 天天操天天干天天插| 亚洲1区2区3区精华液| 成人乱码一区二区三区av| 国产精品久久9999| 偷拍自拍 中文字幕| 午夜场射精嗯嗯啊啊视频| 东游记中文字幕版哪里可以看到| 成人av在线资源网站| 国产九色91在线视频| 天堂va蜜桃一区入口| 3337p日本欧洲大胆色噜噜| 2022天天干天天操| 男人靠女人的逼视频| 粗大的内捧猛烈进出爽大牛汉子| 红杏久久av人妻一区| 亚洲一区二区三区精品乱码| 欧美精产国品一二三区| 天天操天天干天天日狠狠插| av视屏免费在线播放| 亚洲人成精品久久久久久久| 边摸边做超爽毛片18禁色戒| 中国无遮挡白丝袜二区精品| 欧美地区一二三专区| 国产又色又刺激在线视频| 嫩草aⅴ一区二区三区| 精品欧美一区二区vr在线观看| 天天日天天鲁天天操| 偷拍自拍视频图片免费| 欧美爆乳肉感大码在线观看| 国产揄拍高清国内精品对白| 日韩中文字幕在线播放第二页| 美女视频福利免费看| 少妇ww搡性bbb91| 亚洲图片欧美校园春色| 日韩a级精品一区二区| 99热国产精品666| 蜜臀av久久久久蜜臀av麻豆| 九九热99视频在线观看97| 人妻另类专区欧美制服| 一级黄片大鸡巴插入美女| 57pao国产一区二区| 国产精品成人xxxx| 国产精品自偷自拍啪啪啪| 黑人借宿ntr人妻的沦陷2| 中文人妻AV久久人妻水| 欧美视频不卡一区四区| 欧美成人小视频在线免费看| 女生自摸在线观看一区二区三区| 人妻久久无码中文成人| 欧美一区二区三区久久久aaa| 天天操天天爽天天干| 爆乳骚货内射骚货内射在线| 激情国产小视频在线| 国产三级影院在线观看| 麻豆精品成人免费视频| 这里有精品成人国产99| 黄色av网站免费在线| 热久久只有这里有精品| 丰满少妇人妻xxxxx| 中文字幕视频一区二区在线观看| 国产+亚洲+欧美+另类| 男女啪啪啪啪啪的网站| 亚洲 自拍 色综合图| 夜鲁夜鲁狠鲁天天在线| 97人妻夜夜爽二区欧美极品| 日本丰满熟妇BBXBBXHD| 天天干天天操天天玩天天射 | 亚洲欧美清纯唯美另类| 日本丰满熟妇大屁股久久| 二区中出在线观看老师 | 午夜91一区二区三区| 青青草在观免费国产精品| 日韩欧美国产一区不卡| 97超碰人人搞人人| 不卡一区一区三区在线| 中文字幕一区的人妻欧美日韩| 精品av久久久久久久| 日本熟妇一区二区x x| 亚洲成人av在线一区二区| aaa久久久久久久久| 青青青爽视频在线播放| 丝袜肉丝一区二区三区四区在线| 亚洲av成人网在线观看| 99国内小视频在现欢看| 国产污污污污网站在线| 亚洲综合在线视频可播放| 亚洲国产免费av一区二区三区 | 国产又粗又猛又爽又黄的视频美国| 精品亚洲国产中文自在线| 国产av一区2区3区| 天堂资源网av中文字幕| 久久精品国产999| 亚洲美女美妇久久字幕组| 在线观看av亚洲情色| 亚洲欧美激情中文字幕| 黄片三级三级三级在线观看| 亚洲欧美另类手机在线| 2021天天色天天干| 色在线观看视频免费的| 天堂av在线播放免费| 午夜极品美女福利视频| 美女在线观看日本亚洲一区| 风流唐伯虎电视剧在线观看| 和邻居少妇愉情中文字幕| 亚洲图片欧美校园春色| 日韩少妇人妻精品无码专区| 粉嫩欧美美人妻小视频| 天天摸天天干天天操科普| 亚洲综合另类欧美久久| 色吉吉影音天天干天天操| 天美传媒mv视频在线观看| 成人sm视频在线观看| 在线亚洲天堂色播av电影| 2012中文字幕在线高清| 自拍偷区二区三区麻豆| 天天做天天干天天舔| 亚洲综合另类欧美久久| 日韩精品中文字幕福利| 啊啊好慢点插舔我逼啊啊啊视频| 成年人免费看在线视频| 经典国语激情内射视频| 久久久制服丝袜中文字幕| 国产精品自偷自拍啪啪啪| 久久久人妻一区二区| 视频 国产 精品 熟女 | 日本啪啪啪啪啪啪啪| 男人在床上插女人视频| 又色又爽又黄又刺激av网站| 免费无码人妻日韩精品一区二区| 青青青青爽手机在线| 亚洲另类伦春色综合小| 亚洲视频在线视频看视频在线| 2022中文字幕在线| 久久亚洲天堂中文对白| 水蜜桃一区二区三区在线观看视频| 亚洲av自拍天堂网| 大鸡巴后入爆操大屁股美女| v888av在线观看视频| 欧美韩国日本国产亚洲| 被大鸡吧操的好舒服视频免费| 欧美一区二区三区久久久aaa| 亚洲欧洲一区二区在线观看| 99热久久这里只有精品| 国产日韩欧美美利坚蜜臀懂色| 亚洲国产精品中文字幕网站| 天天操夜夜操天天操天天操| 久久艹在线观看视频| 免费在线观看视频啪啪| 97人妻夜夜爽二区欧美极品| 天天操天天射天天操天天天| 国产成人精品福利短视频| 水蜜桃一区二区三区在线观看视频| av线天堂在线观看| 蜜桃视频入口久久久| 男人操女人的逼免费视频| 午夜av一区二区三区| 白白操白白色在线免费视频| 91chinese在线视频| 色呦呦视频在线观看视频| 天天日天天日天天擦| 国产自拍在线观看成人| 日本熟女精品一区二区三区| 亚洲1区2区3区精华液| av在线免费中文字幕| 亚洲精品ww久久久久久| 国产普通话插插视频| 一区二区三区视频,福利一区二区| 男生舔女生逼逼视频| 40道精品招牌菜特色| 在线制服丝袜中文字幕| 日本阿v视频在线免费观看| 91久久人澡人人添人人爽乱| 天天射夜夜操综合网| 青青青青青操视频在线观看| 黄色av网站免费在线| 亚洲国产免费av一区二区三区| 精品亚洲在线免费观看| 日本精品美女在线观看| 人妻激情图片视频小说| 亚洲福利天堂久久久久久| 亚洲av无硬久久精品蜜桃| 免费一级特黄特色大片在线观看| 午夜dv内射一区区| 国产乱弄免费视频观看| 中国熟女一区二区性xx| 中文人妻AV久久人妻水| 色哟哟国产精品入口| 成人免费公开视频无毒| 久久久人妻一区二区| 中文字幕日韩人妻在线三区| 亚洲欧洲av天堂综合| 亚洲天堂精品福利成人av| 操日韩美女视频在线免费看| 久久艹在线观看视频| 中国产一级黄片免费视频播放| 中文字幕日韩人妻在线三区| 精品久久久久久久久久久99| 国产第一美女一区二区三区四区| 亚洲 中文 自拍 无码| 天码人妻一区二区三区在线看 | 精内国产乱码久久久久久| 99精品亚洲av无码国产另类| 欧美中文字幕一区最新网址| 不卡日韩av在线观看| 免费无码人妻日韩精品一区二区| 黑人大几巴狂插日本少妇| 自拍偷拍日韩欧美亚洲| 亚洲1区2区3区精华液| 亚洲精品乱码久久久久久密桃明| 天天射,天天操,天天说| 亚洲国产第一页在线观看| 亚洲另类伦春色综合小| 精品一区二区三区三区色爱| 精品久久久久久久久久中文蒉| 沈阳熟妇28厘米大战黑人| 青青青青视频在线播放| 啪啪啪操人视频在线播放| 人妻少妇性色欲欧美日韩| 欧美激情精品在线观看| 青青青青青操视频在线观看| 亚洲中文字幕国产日韩| 五十路在线观看完整版| 日韩近亲视频在线观看| 黄色男人的天堂视频| av在线免费资源站|