3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問 生活随笔!

生活随笔

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

编程问答

defer 的前世今生

發布時間:2024/4/11 编程问答 45 豆豆
生活随笔 收集整理的這篇文章主要介紹了 defer 的前世今生 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

延遲語句 defer 在最早期的 Go 語言設計中并不存在,后來才單獨增加了這一特性,由 Robert Griesemer 完成語言規范的編寫 [Griesemer, 2009], 并由 Ken Thompson 完成最早期的實現 [Thompson, 2009],兩人合作完成這一語言特性。

defer 的語義表明,它會在函數返回、產生恐慌或者 runtime.Goexit 時被調用。直覺上看,defer 應該由編譯器直接將需要的函數調用插入到該調用的地方,似乎是一個編譯期特性,不應該存在運行時性能問題,非常類似于 C++ 的 RAII 范式(當離開資源的作用域時,自動執行析構函數)。但實際情況是,由于 defer 并沒有與其依賴資源掛鉤,也允許在條件、循環語句中出現,從而不再是一個作用域相關的概念,這就是使得 defer 的語義變得相對復雜。在一些復雜情況下,無法在編譯期決定存在多少個 defer 調用。

例如,在一個執行次數不確定的 for 循環中,defer 的執行次數是隨機的:

func randomDefers() {rand.Seed(time.Now().UnixNano())for rand.Intn(100) > 42 {defer func() {println("changkun.de/golang")}()} }

因而 defer 并不是免費的午餐,在一個復雜的調用中,當無法直接確定需要的產生的延遲調用的數量時,延遲語句將導致運行性能的下降。本文我們來討論 defer 的實現本質及其對癥下藥的相關性能優化手段。

  • defer 的類型

  • 在堆上分配的 defer

    • 編譯階段

    • 運行階段

  • 在棧上創建 defer

  • 開放編碼式 defer

    • 產生條件

    • 延遲比特

  • defer 的優化之路

  • 小結

  • 進一步閱讀的參考文獻

defer 的類型

延遲語句的文法產生式 DeferStmt -> "defer" Expression 的描述非常的簡單,因而也很容易將其處理為語法樹的形式,但我們這里更關心的其實是它語義背后的中間和目標代碼的形式。

在 《Go 語言原本》Go 程序編譯流程 一節中我們提到過,在進行中間代碼生成階段,會通過 compileSSA 先調用 buildssa 為函數體生成 SSA 形式的函數,而后調用 genssa 將函數的 SSA 中間表示轉換為具體的指令。

Go 語言的語句在執行 buildssa 階段中,會由 state.stmt 完成函數中各個語句的 SSA 處理。

// src/cmd/compile/internal/gc/ssa.go func buildssa(fn *Node, worker int) *ssa.Func {var s state...s.stmtList(fn.Nbody)... } func (s *state) stmtList(l Nodes) {for _, n := range l.Slice() { s.stmt(n) } }

對于延遲語句而言,其中間表示會產生三種不同的延遲形式, 第一種是最一般情況下的在堆上分配的延遲語句,第二種是允許在棧上分配的延遲語句,最后一種則是**開放編碼式(Open-coded)**的延遲語句。

// src/cmd/compile/internal/gc/ssa.go func (s *state) stmt(n *Node) {...switch n.Op {case ODEFER:// 開放編碼式 deferif s.hasOpenDefers {s.openDeferRecord(n.Left)} else {// 堆上分配的 deferd := callDeferif n.Esc == EscNever {// 棧上分配的 deferd = callDeferStack}s.call(n.Left, d)}case ...}... }

在堆上分配的 defer

我們先來討論最簡單的在堆上分配的 defer 這種形式。在堆上分配的原因是 defer 語句出現在了循環語句里,或者無法執行更高階的編譯器優化導致的。

如果一個與 defer 出現在循環語句中,則可執行的次數可能無法在編譯期決定;如果一個調用中 defer 由于數量過多等原因,不能被編譯器進行開放編碼,則也會在堆上分配 defer。

總之,由于這種不確定性的存在,在堆上分配的 defer 需要最多的運行時支持,因而產生的運行時開銷也最大。

編譯階段

為了使延遲語句的功能滿足語言規范,該語句在編譯的 SSA 階段會被翻譯為兩個主體,其中第一個主體是被延遲的函數本身,另一個主體則是函數結束時需要執行所記錄 defer 的代碼塊。

state.call 調用會生成用于記錄延遲調用參數的指令,并創建一個 deferproc 的調用指令;而后 state.exit 調用在函數返回前插入 deferreturn 調用的指令。

// src/cmd/compile/internal/gc/ssa.go func (s *state) call(n *Node, k callKind) *ssa.Value {...var call *ssa.Valueif k == callDeferStack {...} else {// 在堆上創建 deferargStart := Ctxt.FixedFrameSize()// Defer 參數if k != callNormal {// 記錄 deferproc 的參數argsize := s.constInt32(types.Types[TUINT32], int32(stksize))addr := s.constOffPtrSP(s.f.Config.Types.UInt32Ptr, argStart)s.store(types.Types[TUINT32], addr, argsize) // 保存參數大小 sizaddr = s.constOffPtrSP(s.f.Config.Types.UintptrPtr, argStart+int64(Widthptr))s.store(types.Types[TUINTPTR], addr, closure) // 保存函數地址 fnstksize += 2 * int64(Widthptr)argStart += 2 * int64(Widthptr)}...// 創建 deferproc 調用switch {case k == callDefer:call = s.newValue1A(ssa.OpStaticCall, types.TypeMem, deferproc, s.mem())...}...}...// 結束 defer 塊if k == callDefer || k == callDeferStack {s.exit()...}... } func (s *state) exit() *ssa.Block {if s.hasdefer {if s.hasOpenDefers {...} else {// 調用 deferreturns.rtcall(Deferreturn, true, nil)}}... }

例如,對于一個純粹的 defer 調用而言:

package mainfunc foo() {return }func main() {defer foo()return }

如果我們將其強制編譯為在堆上分配的形式,可以觀察到如下的匯編代碼。其中 defer foo()被轉化為了 deferproc 調用,并在函數返回前,調用了 deferreturn:

TEXT main.foo(SB) /Users/changkun/Desktop/defer/ssa/main.goreturn0x104ea20 c3 RET TEXT main.main(SB) /Users/changkun/Desktop/defer/ssa/main.go func main() {...// 將 defer foo() { ... }() 轉化為一個 deferproc 調用// 在調用 deferproc 前完成參數的準備工作,這個例子中沒有參數0x104ea4d c7042400000000 MOVL $0x0, 0(SP) 0x104ea54 488d0585290200 LEAQ go.func.*+60(SB), AX 0x104ea5b 4889442408 MOVQ AX, 0x8(SP) 0x104ea60 e8bb31fdff CALL runtime.deferproc(SB) ...// 函數返回指令 RET 前插入的 deferreturn 語句0x104ea7b 90 NOPL 0x104ea7c e82f3afdff CALL runtime.deferreturn(SB) 0x104ea81 488b6c2410 MOVQ 0x10(SP), BP 0x104ea86 4883c418 ADDQ $0x18, SP 0x104ea8a c3 RET // 函數的尾聲0x104ea8b e8d084ffff CALL runtime.morestack_noctxt(SB) 0x104ea90 eb9e JMP main.main(SB)

運行階段

一個函數中的延遲語句會被保存為一個 _defer 記錄的鏈表,附著在一個 Goroutine 上。_defer 記錄的具體結構也非常簡單,主要包含了參與調用的參數大小、當前 defer 語句所在函數的 PC 和 SP 寄存器、被 defer 的函數的入口地址以及串聯多個 defer 的 link 鏈表,該鏈表指向下一個需要執行的 defer,如圖 9.2.1 所示。

// src/runtime/panic.go type _defer struct {siz int32heap boolsp uintptrpc uintptrfn *funcvallink *_defer... } // src/runtime/runtime2.go type g struct {..._defer *_defer... }
附著在 Goroutine 上的 _defer 記錄的鏈表

現在我們知道,一個在堆上分配的延遲語句被編譯為了 deferproc,用于記錄被延遲的函數調用;在函數的尾聲,會插入 deferreturn 調用,用于執行被延遲的調用。

下面我們就來詳細看看這兩個調用具體發生了什么事情。

我們先看創建 defer 的第一種形式 deferproc。這個調用很簡單,僅僅只是將需要被 defer 調用的函數做了一次記錄:

//go:nosplit func deferproc(siz int32, fn *funcval) {...sp := getcallersp()argp := uintptr(unsafe.Pointer(&fn)) + unsafe.Sizeof(fn)callerpc := getcallerpc()d := newdefer(siz)d.fn = fnd.pc = callerpcd.sp = sp// 將參數保存到 _defer 記錄中switch siz {case 0: // 什么也不做case sys.PtrSize:*(*uintptr)(deferArgs(d)) = *(*uintptr)(unsafe.Pointer(argp))default:memmove(deferArgs(d), unsafe.Pointer(argp), uintptr(siz))}return0() }

這段代碼中,本質上只是在做一些簡單參數處理,比如 fn 保存了 defer 所調用函數的調用地址,siz 確定了其參數的大小。并且通過 newdefer 來創建一個新的 _defer 實例,然后由 fn、callerpc 和 sp 來保存調用該 defer 的 Goroutine 上下文。

注意,在這里我們看到了一個對參數進行拷貝的操作。這個操作也是我們在實踐過程中經歷過的,defer 調用被記錄時,并不會對參數進行求值,而是會對參數完成一次拷貝。這么做原因是由于語義上的考慮。直覺上講,defer 的參數應當在它所寫的位置對傳入的參數進行求值,而不是將求值步驟推遲,因為延后的參數可能發生變化,導致 defer 的語義發生意料之外的錯誤。

例如,f, _ := os.Open("file.txt") 后立刻指定 defer f.Close(),倘若隨后的語句修改了 f 的值,那么將導致 f 無法被正常關閉。

出于性能考慮,newdefer 通過 P 或者調度器 sched 上的本地或全局 defer 池來復用已經在堆上分配的內存。defer 的資源池會根據被延遲的調用所需的參數來決定 defer 記錄的大小等級,每 16 個字節分一個等級。此做法的動機與運行時內存分配器針對不同大小對象的分配思路雷同,這里不再做深入討論。

// src/runtime/runtime2.go type p struct {...// 不同大小的本地 defer 池deferpool [5][]*_deferdeferpoolbuf [5][32]*_defer... } type schedt struct {...// 不同大小的全局 defer 池deferlock mutexdeferpool [5]*_defer... }

對于新建的 _defer 實例而言,會將其加入到 Goroutine 所保留的 defer 鏈表上,通過 link 字段串聯。

// src/runtime/panic.go//go:nosplit func newdefer(siz int32) *_defer {var d *_defersc := deferclass(uintptr(siz))gp := getg()// 檢查 defer 參數的大小是否從 p 的 deferpool 直接分配if sc < uintptr(len(p{}.deferpool)) {pp := gp.m.p.ptr()// 如果 p 本地無法分配,則從全局池中獲取一半 defer,來填充 P 的本地資源池if len(pp.deferpool[sc]) == 0 && sched.deferpool[sc] != nil {// 出于性能考慮,如果發生棧的增長,則會調用 morestack,// 進一步降低 defer 的性能。因此切換到系統棧上執行,進而不會發生棧的增長。systemstack(func() {lock(&sched.deferlock)for len(pp.deferpool[sc]) < cap(pp.deferpool[sc])/2 && sched.deferpool[sc] != nil {d := sched.deferpool[sc]sched.deferpool[sc] = d.linkd.link = nilpp.deferpool[sc] = append(pp.deferpool[sc], d)}unlock(&sched.deferlock)})}// 從 P 本地進行分配if n := len(pp.deferpool[sc]); n > 0 {d = pp.deferpool[sc][n-1]pp.deferpool[sc][n-1] = nilpp.deferpool[sc] = pp.deferpool[sc][:n-1]}}// 沒有可用的緩存,直接從堆上分配新的 defer 和 argsif d == nil {systemstack(func() {total := roundupsize(totaldefersize(uintptr(siz)))d = (*_defer)(mallocgc(total, deferType, true))})}// 將 _defer 實例添加到 Goroutine 的 _defer 鏈表上。d.siz = sizd.heap = trued.link = gp._defergp._defer = dreturn d }

deferreturn 被編譯器插入到函數末尾,當跳轉到它時,會將需要被 defer 的入口地址取出,然后跳轉并執行:

// src/runtime/panic.go//go:nosplit func deferreturn(arg0 uintptr) {gp := getg()d := gp._deferif d == nil {return}// 確定 defer 的調用方是不是當前 deferreturn 的調用方sp := getcallersp()if d.sp != sp {return}...// 將參數復制出 _defer 記錄外switch d.siz {case 0: // 什么也不做case sys.PtrSize:*(*uintptr)(unsafe.Pointer(&arg0)) = *(*uintptr)(deferArgs(d))default:memmove(unsafe.Pointer(&arg0), deferArgs(d), uintptr(d.siz))}// 獲得被延遲的調用 fn 的入口地址,并隨后立即將 _defer 釋放掉fn := d.fnd.fn = nilgp._defer = d.linkfreedefer(d)// 調用,并跳轉到下一個 deferjmpdefer(fn, uintptr(unsafe.Pointer(&arg0))) }

在這個函數中,會在需要時對 defer 的參數再次進行拷貝,多個 defer 函數以 jmpdefer 尾調用形式被實現。在跳轉到 fn 之前,_defer 實例被釋放歸還,jmpdefer 真正需要的僅僅只是函數的入口地址和參數,以及它的調用方 deferreturn 的 SP:

// src/runtime/asm_amd64.s// func jmpdefer(fv *funcval, argp uintptr) TEXT runtime·jmpdefer(SB), NOSPLIT, $0-16MOVQ fv+0(FP), DX // DX = fnMOVQ argp+8(FP), BX // 調用方 SPLEAQ -8(BX), SP // CALL 后的調用方 SPMOVQ -8(SP), BP // 恢復 BP,好像 deferreturn 返回SUBQ $5, (SP) // 再次返回到 CALLMOVQ 0(DX), BX // BX = DXJMP BX // 最后才運行被 defer 的函數

這個 jmpdefer 巧妙的地方在于,它通過調用方 SP 來推算了 deferreturn 的入口地址,從而在完成某個 defer 調用后,由于被 defer 的函數返回時會出棧,會再次回到 deferreturn 的初始位置,進而繼續反復調用,從而模擬 deferreturn 不斷地對自己進行尾遞歸的假象。

釋放操作非常普通,只是簡單地將其歸還到 P 的 deferpool 中, 并在本地池已滿時將其歸還到全局資源池:

// src/runtime/panic.go//go:nosplit func freedefer(d *_defer) {...sc := deferclass(uintptr(d.siz))if sc >= uintptr(len(p{}.deferpool)) {return}pp := getg().m.p.ptr()// 如果 P 本地池已滿,則將一半資源放入全局池,同樣也是出于性能考慮// 操作會切換到系統棧上執行。if len(pp.deferpool[sc]) == cap(pp.deferpool[sc]) {systemstack(func() {var first, last *_deferfor len(pp.deferpool[sc]) > cap(pp.deferpool[sc])/2 {n := len(pp.deferpool[sc])d := pp.deferpool[sc][n-1]pp.deferpool[sc][n-1] = nilpp.deferpool[sc] = pp.deferpool[sc][:n-1]if first == nil {first = d} else {last.link = d}last = d}lock(&sched.deferlock)last.link = sched.deferpool[sc]sched.deferpool[sc] = firstunlock(&sched.deferlock)})}// 恢復 _defer 的零值,即 *d = _defer{}d.siz = 0...d.sp = 0d.pc = 0d.framepc = 0...d.link = nil// 放入 P 本地資源池pp.deferpool[sc] = append(pp.deferpool[sc], d) }

在棧上創建 defer

defer 還可以直接在棧上進行分配,也就是第二種記錄 defer 的形式 deferprocStack。在棧上分配 defer 的好處在于函數返回后 _defer 便已得到釋放,不再需要考慮內存分配時產生的性能開銷,只需要適當地維護 _defer 的鏈表即可。

在 SSA 階段與在堆上分配的區別在于,在棧上創建 defer, 需要直接在函數調用幀上使用編譯器來初始化 _defer 記錄,并作為參數傳遞給 deferprocStack:

// src/cmd/compile/internal/gc/ssa.go func (s *state) call(n *Node, k callKind) *ssa.Value {...var call *ssa.Valueif k == callDeferStack {// 直接在棧上創建 defer 記錄t := deferstruct(stksize) // 從編譯器角度構造 _defer 結構d := tempAt(n.Pos, s.curfn, t)s.vars[&memVar] = s.newValue1A(ssa.OpVarDef, types.TypeMem, d, s.mem())addr := s.addr(d, false)// 在棧上預留記錄 _defer 的各個字段的空間s.store(types.Types[TUINT32],s.newValue1I(ssa.OpOffPtr, types.Types[TUINT32].PtrTo(), t.FieldOff(0), addr),s.constInt32(types.Types[TUINT32], int32(stksize)))s.store(closure.Type,s.newValue1I(ssa.OpOffPtr, closure.Type.PtrTo(), t.FieldOff(6), addr),closure)// 記錄參與 defer 調用的函數參數ft := fn.Typeoff := t.FieldOff(12)args := n.Rlist.Slice()// 調用 deferprocStack,以 _defer 記錄的指針作為參數傳遞arg0 := s.constOffPtrSP(types.Types[TUINTPTR], Ctxt.FixedFrameSize())s.store(types.Types[TUINTPTR], arg0, addr)call = s.newValue1A(ssa.OpStaticCall, types.TypeMem, deferprocStack, s.mem())...} else { ... }// 函數尾聲與堆上分配的棧一樣,調用 deferreturnif k == callDefer || k == callDeferStack {...s.exit()}... }

可見,在編譯階段,一個 _defer 記錄的空間已經在棧上得到保留,deferprocStack 的作用就僅僅承擔了運行時對該記錄的初始化這一功能:

// src/runtime/panic.go//go:nosplit func deferprocStack(d *_defer) {gp := getg()// 注意,siz 和 fn 已經在編譯階段完成設置,這里只初始化了其他字段d.started = falsed.heap = false // 可見此時 defer 被標記為不在堆上分配d.openDefer = falsed.sp = getcallersp()d.pc = getcallerpc()...// 盡管在棧上進行分配,仍然需要將多個 _defer 記錄通過鏈表進行串聯,// 以便在 deferreturn 中找到被延遲的函數的入口地址:// d.link = gp._defer// gp._defer = d*(*uintptr)(unsafe.Pointer(&d.link)) = uintptr(unsafe.Pointer(gp._defer))*(*uintptr)(unsafe.Pointer(&gp._defer)) = uintptr(unsafe.Pointer(d))return0() }

至于函數尾聲的行為,與在堆上進行分配的操作同樣是調用 deferreturn,我們就不再重復說明了。當然,里面涉及的 freedefer 調用由于不需要釋放任何內存,也就早早返回了:

// src/runtime/panic.go func freedefer(d *_defer) {if !d.heap { return }... }

開放編碼式 defer

正如本文最初所描述的那樣,defer 給我們的第一感覺其實是一個編譯期特性。前面我們討論了為什么 defer 會需要運行時的支持,以及需要運行時的 defer 是如何工作的。現在我們來探究一下什么情況下能夠讓 defer 進化為一個僅編譯期特性,即在函數末尾直接對延遲函數進行調用,做到幾乎不需要額外的開銷。這類幾乎不需要額外運行時性能開銷的 defer,正是開放編碼式 defer。這類 defer 與直接調用產生的性能差異有多大呢?我們不妨編寫兩個性能測試:

func call() { func() {}() } func callDefer() { defer func() {}() } func BenchmarkDefer(b *testing.B) {for i := 0; i < b.N; i++ {call() // 第二次運行時替換為 callDefer} }

在 Go 1.14 版本下,讀者可以獲得類似下方的性能估計,其中使用 callDefer 后,性能損耗大約為 1 ns。這種納秒級的性能損耗不到一個 CPU 時鐘周期,我們已經可以認為開放編碼式 defer 幾乎沒有了性能開銷:

name old time/op new time/op delta Defer-12 1.24ns ± 1% 2.23ns ± 1% +80.06% (p=0.000 n=10+9)

我們再來觀察一下開放編碼式 defer 最終被編譯的形式:

$ go build -gcflags "-l" -ldflags=-compressdwarf=false -o main.out main.go $ go tool objdump -S main.out > main.s

對于如下形式的函數調用:

var mu sync.Mutex func callDefer() {mu.Lock()defer mu.Unlock() }

整個調用最終編譯結果既沒有 deferproc 或者 deferprocStack,也沒有了 deferreturn。延遲語句被直接插入到了函數的末尾:

TEXT main.callDefer(SB) /Users/changkun/Desktop/defer/main.go func callDefer() {...mu.Lock()0x105794a 488d05071f0a00 LEAQ main.mu(SB), AX 0x1057951 48890424 MOVQ AX, 0(SP) 0x1057955 e8f6f8ffff CALL sync.(*Mutex).Lock(SB) defer mu.Unlock()0x105795a 488d057f110200 LEAQ go.func.*+1064(SB), AX 0x1057961 4889442418 MOVQ AX, 0x18(SP) 0x1057966 488d05eb1e0a00 LEAQ main.mu(SB), AX 0x105796d 4889442410 MOVQ AX, 0x10(SP) }0x1057972 c644240f00 MOVB $0x0, 0xf(SP) 0x1057977 488b442410 MOVQ 0x10(SP), AX 0x105797c 48890424 MOVQ AX, 0(SP) 0x1057980 e8ebfbffff CALL sync.(*Mutex).Unlock(SB) 0x1057985 488b6c2420 MOVQ 0x20(SP), BP 0x105798a 4883c428 ADDQ $0x28, SP 0x105798e c3 RET ...

那么開放編碼式 defer 是怎么實現的?所有的 defer 都是開放編碼式的嗎?什么情況下,開放編碼式 defer 會退化為一個依賴運行時的特性?

產生條件

我們先來看開放編碼式 defer 的產生條件。在 SSA 的構建階段 buildssa,我們有:

// src/cmd/compile/internal/gc/ssa.go const maxOpenDefers = 8 func walkstmt(n *Node) *Node {...switch n.Op {case ODEFER:Curfn.Func.SetHasDefer(true)Curfn.Func.numDefers++// 超過 8 個 defer 時,禁用對 defer 進行開放編碼if Curfn.Func.numDefers > maxOpenDefers {Curfn.Func.SetOpenCodedDeferDisallowed(true)}// 存在循環語句中的 defer,禁用對 defer 進行開放編碼。// 是否有 defer 發生在循環語句內,會在 SSA 之前的逃逸分析中進行判斷,// 逃逸分析會檢查是否存在循環(loopDepth):// if where.Op == ODEFER && e.loopDepth == 1 {// where.Esc = EscNever// ...// }if n.Esc != EscNever {Curfn.Func.SetOpenCodedDeferDisallowed(true)}case ...}... }func buildssa(fn *Node, worker int) *ssa.Func {...var s state...s.hasdefer = fn.Func.HasDefer()...// 可以對 defer 進行開放編碼的條件s.hasOpenDefers = Debug['N'] == 0 && s.hasdefer && !s.curfn.Func.OpenCodedDeferDisallowed()if s.hasOpenDefers &&s.curfn.Func.numReturns*s.curfn.Func.numDefers > 15 {s.hasOpenDefers = false}... }

這樣,我們得到了允許進行 defer 的開放編碼的主要條件(此處略去了一些常見生產環境無關的條件,例如啟用競爭檢查時也不能對 defer 進行開放編碼):

  • 沒有禁用編譯器優化,即沒有設置 -gcflags "-N"

  • 存在 defer 調用

  • 函數內 defer 的數量不超過 8 個、且返回語句與延遲語句個數的乘積不超過 15

  • 沒有 defer 發生在循環語句中

  • 延遲比特

    當然,正常編寫的 defer 可以直接被編譯器分析得出,但是如本文開頭提到的,如果一個 defer 發生在一個條件語句中,而這個條件必須等到運行時才能確定:

    if rand.Intn(100) < 42 {defer fmt.Println("meaning-of-life") }

    那么如何才能使用最小的成本,讓插入到函數末尾的延遲語句,在條件成立時候被正確執行呢?這便需要一種機制,能夠記錄存在延遲語句的條件分支是否被執行,這種機制在 Go 中利用了延遲比特(defer bit)。這種做法非常巧妙,但原理卻非常簡單。

    對于下面的代碼而言:

    defer f1(a1) if cond {defer f2(a2) } ...

    使用延遲比特的核心思想可以用下面的偽代碼來概括。在創建延遲調用的階段,首先通過延遲比特的特定位置記錄哪些帶條件的 defer 被觸發。這個延遲比特是一個長度為 8 位的二進制碼(也是硬件架構里最小、最通用的情況),以每一位是否被設置為 1,來判斷延遲語句是否在運行時被設置,如果設置,則發生調用。否則則不調用:

    deferBits = 0 // 初始值 00000000 deferBits |= 1 << 0 // 遇到第一個 defer,設置為 00000001 _f1 = f1 _a1 = a1 if cond {// 如果第二個 defer 被設置,則設置為 00000011,否則依然為 00000001deferBits |= 1 << 1_f2 = f2_a2 = a2 }

    在退出位置,再重新根據被標記的延遲比特,反向推導哪些位置的 defer 需要被觸發,從而執行延遲調用:

    exit: // 按順序倒序檢查延遲比特。如果第二個 defer 被設置,則 // 00000011 & 00000010 == 00000010,即延遲比特不為零,應該調用 f2。 // 如果第二個 defer 沒有被設置,則 // 00000001 & 00000010 == 00000000,即延遲比特為零,不應該調用 f2。 if deferBits & 1 << 1 != 0 { // 00000011 & 00000010 != 0deferBits &^= 1<<1 // 00000001_f2(_a2) } // 同理,由于 00000001 & 00000001 == 00000001,因此延遲比特不為零,應該調用 f1 if deferBits && 1 << 0 != 0 {deferBits &^= 1<<0_f1(_a1) }

    在實際的實現中,可以看到,當可以設置開放編碼式 defer 時,buildssa 會首先創建一個長度位 8 位的臨時變量:

    // src/cmd/compile/internal/gc/ssa.go func buildssa(fn *Node, worker int) *ssa.Func {...if s.hasOpenDefers {// 創建 deferBits 臨時變量deferBitsTemp := tempAt(src.NoXPos, s.curfn, types.Types[TUINT8])s.deferBitsTemp = deferBitsTemp// deferBits 被設計為 8 位二進制,因此可以被開放編碼的 defer 數量不能超過 8 個// 此處還將起始 deferBits 設置為零startDeferBits := s.entryNewValue0(ssa.OpConst8, types.Types[TUINT8])s.vars[&deferBitsVar] = startDeferBitss.deferBitsAddr = s.addr(deferBitsTemp, false)s.store(types.Types[TUINT8], s.deferBitsAddr, startDeferBits)...}...s.stmtList(fn.Nbody) // 調用 s.stmt... }

    隨后針對出現 defer 的語句,進行編碼:

    // src/cmd/compile/internal/gc/ssa.go func (s *state) stmt(n *Node) {...switch n.Op {case ODEFER:// 開放編碼式 deferif s.hasOpenDefers {s.openDeferRecord(n.Left)} else { ... }case ...}... }// 存儲一個 defer 調用的相關信息,例如所在的語法樹結點、被延遲的調用、參數等等 type openDeferInfo struct {n *Nodeclosure *ssa.ValueclosureNode *Node...argVals []*ssa.ValueargNodes []*Node } func (s *state) openDeferRecord(n *Node) {...var args []*ssa.Valuevar argNodes []*Node// 記錄與 defer 相關的入口地址與參數信息opendefer := &openDeferInfo{n: n}fn := n.Left// 記錄函數入口地址if n.Op == OCALLFUNC {closureVal := s.expr(fn)closure := s.openDeferSave(nil, fn.Type, closureVal)opendefer.closureNode = closure.Aux.(*Node)if !(fn.Op == ONAME && fn.Class() == PFUNC) {opendefer.closure = closure}} else {...}// 記錄需要立即求值的的參數for _, argn := range n.Rlist.Slice() {var v *ssa.Valueif canSSAType(argn.Type) {v = s.openDeferSave(nil, argn.Type, s.expr(argn))} else {v = s.openDeferSave(argn, argn.Type, nil)}args = append(args, v)argNodes = append(argNodes, v.Aux.(*Node))}opendefer.argVals = argsopendefer.argNodes = argNodes// 每多出現一個 defer,len(defers) 會增加,進而 // 延遲比特 deferBits |= 1<<len(defers) 被設置在不同的位上index := len(s.openDefers)s.openDefers = append(s.openDefers, opendefer)bitvalue := s.constInt8(types.Types[TUINT8], 1<<uint(index))newDeferBits := s.newValue2(ssa.OpOr8, types.Types[TUINT8], s.variable(&deferBitsVar, types.Types[TUINT8]), bitvalue)s.vars[&deferBitsVar] = newDeferBitss.store(types.Types[TUINT8], s.deferBitsAddr, newDeferBits) }

    在函數返回退出前,state 的 exit 函數會依次倒序創建對延遲比特的檢查代碼,從而順序調用被延遲的函數調用:

    // src/cmd/compile/internal/gc/ssa.go func (s *state) exit() *ssa.Block {if s.hasdefer {if s.hasOpenDefers {...s.openDeferExit()} else {...}}... }func (s *state) openDeferExit() {deferExit := s.f.NewBlock(ssa.BlockPlain)s.endBlock().AddEdgeTo(deferExit)s.startBlock(deferExit)s.lastDeferExit = deferExits.lastDeferCount = len(s.openDefers)zeroval := s.constInt8(types.Types[TUINT8], 0)// 倒序檢查 deferfor i := len(s.openDefers) - 1; i >= 0; i-- {r := s.openDefers[i]bCond := s.f.NewBlock(ssa.BlockPlain)bEnd := s.f.NewBlock(ssa.BlockPlain)// 檢查 deferBitsdeferBits := s.variable(&deferBitsVar, types.Types[TUINT8])// 創建 if deferBits & 1 << len(defer) != 0 { ... }bitval := s.constInt8(types.Types[TUINT8], 1<<uint(i))andval := s.newValue2(ssa.OpAnd8, types.Types[TUINT8], deferBits, bitval)eqVal := s.newValue2(ssa.OpEq8, types.Types[TBOOL], andval, zeroval)b := s.endBlock()b.Kind = ssa.BlockIfb.SetControl(eqVal)b.AddEdgeTo(bEnd)b.AddEdgeTo(bCond)bCond.AddEdgeTo(bEnd)s.startBlock(bCond)// 如果創建的條件分支被觸發,則清空當前的延遲比特: deferBits &^= 1 << len(defers)nbitval := s.newValue1(ssa.OpCom8, types.Types[TUINT8], bitval)maskedval := s.newValue2(ssa.OpAnd8, types.Types[TUINT8], deferBits, nbitval)s.store(types.Types[TUINT8], s.deferBitsAddr, maskedval)s.vars[&deferBitsVar] = maskedval// 處理被延遲的函數調用,取出保存的入口地址、參數信息argStart := Ctxt.FixedFrameSize()fn := r.n.Leftstksize := fn.Type.ArgWidth()...for j, argAddrVal := range r.argVals {f := getParam(r.n, j)pt := types.NewPtr(f.Type)addr := s.constOffPtrSP(pt, argStart+f.Offset)if !canSSAType(f.Type) {s.move(f.Type, addr, argAddrVal)} else {argVal := s.load(f.Type, argAddrVal)s.storeType(f.Type, addr, argVal, 0, false)}}// 調用var call *ssa.Value...call = s.newValue1A(ssa.OpStaticCall, types.TypeMem, fn.Sym.Linksym(), s.mem())call.AuxInt = stksizes.vars[&memVar] = call...s.endBlock()s.startBlock(bEnd)} }

    從整個過程中我們可以看到,開放編碼式 defer 并不是絕對的零成本,盡管編譯器能夠做到將延遲調用直接插入返回語句之前,但出于語義的考慮,需要在棧上對參與延遲調用的參數進行一次求值;同時出于條件語句中可能存在的 defer,還額外需要通過延遲比特來記錄一個延遲語句是否在運行時被設置。因此,開放編碼式 defer 的成本體現在非常少量的指令和位運算來配合在運行時判斷是否存在需要被延遲調用的 defer。

    defer 的優化之路

    我們最后來回顧一下延遲語句的整個演進過程。

    defer 的早期實現其實是非常的粗糙的。每當出現一個 defer 調用,都會在堆上分配 defer 記錄,并對參與調用的參數實施一次拷貝操作,然后將其加入到 defer 鏈表上;當函數返回需要觸發 defer 調用時,依次將 defer 從鏈表中取出,完成調用。當然最初的實現并不需要完美,未來總是可以迭代其性能問題。

    在 Go 1.1 的開發階段,defer 獲得了它的第一次優化 [Cox, 2011]。Russ Cox 意識到 defer 性能問題的根源是當產生多個 defer 調用時,造成的過多的內存分配與拷貝操作,進而提出將 defer 的分配和釋放過程在每個 Goroutine 內進行批量處理。當時 Dmitry Vyukov 則提議在棧上分配會更加有效,但 Russ Cox 錯誤的認為在執行棧上分配 defer 記錄與在其他地方進行分配并沒有帶來太多收益,最終實現了 per-G 批量式分配的 defer 機制。

    由于后續調度器的改進,工作竊取調度的引入,運行時開始支持 per-P 的局部資源池,defer 作為發生在 Goroutine 內的調用,所需的內存自然也是一類可以被視作局部持有的資源。因此分配和釋放 defer 的資源在 Go 1.3 時得到優化 [Vyukov, 2014],Dmitry Vyukov 將 per-G 分配的 defer 改為了從 per-P 資源池分配的機制。

    由于分配延遲記錄 _defer 的調用 newdefer 可能存在本地資源池、全局資源池均不存在可復用的內存,進而導致棧分裂,更糟糕的情況下甚至可能發生搶占,導致 M/P 解綁與綁定等額外的調度開銷。因此,Austin Clements 對 defer 做的一個優化 [Clements, 2016] 是在每個 deferproc 和 deferreturn 中都切換至系統棧,從而阻止了搶占和棧增長的發生,也就優化消除了搶占帶來的 M/P 綁定所帶來的開銷。除此之外,對于每次產生記錄時,無論參數大小如何都涉及 memmove 系統調用,從而產生一次 memmove 的調用成本,Austin 的優化中還特地針對沒有參數和指針大小參數的這兩種情況進行了判斷,從而跳過了這些特殊情況下情況下 memmove 帶來的開銷。

    后來,Keith Randall 終于實現了 [Randall, 2013] 很早之前 Dmitry Vyukov 就已經提出的在棧上分配 defer 的優化 [Cox, 2011],簡單情況下不再需要使用運行時對延遲記錄的內存管理。為 Go 1.13 進一步提升了 defer 的性能。

    在 Go 1.14 中,Dan Scales 作為 Go 團隊的新成員,defer 的優化成為了他的第一個項目。他提出開放式編碼 defer [Scales, 2019],通過編譯器輔助信息和延遲比特在函數末尾處直接獲取調用函數及參數,完成了近乎零成本的 defer 調用,成為了 Go 1.14 中幾個出色的運行時性能優化之一。

    至此,defer 的優化之路正式告一段落。

    版本內容作者
    1.0 及之前制定 defer 的語言規范,首次實現,在堆上分配Robert Griesemer, Ken Thompson
    1.1將 defer 的分配與釋放方式改為 per-G 批量處理Russ Cox
    1.3將 defer 的分配與釋放方式改為 per-P 池化處理Dmitry Vyukov
    1.8將 defer 的執行過程切換到系統棧中,阻止搶占和棧增長帶來的成本Austin Clements
    1.13實現在執行棧上分配 defer,消除了常見的簡單情況下堆上分配帶來的開銷Keith Randall
    1.14實現開放式編碼 defer,支持在函數末尾處直接插入 defer 調用,引入幾乎零成本 deferDan Scales

    小結

    我們最后來總結一下 defer 的基本工作原理以及三種 defer 的性能取舍,如下圖:

    不同類型 defer 的編譯與運行時成本之間的取舍
  • 對于開放編碼式 defer 而言:

    • 編譯器會直接將所需的參數進行存儲,并在返回語句的末尾插入被延遲的調用;

    • 當整個調用中邏輯上會執行的 defer 不超過 15 個(例如 7 個 defer 作用在 2 個返回語句)、總 defer 數量不超過 8 個、且沒有出現在循環語句中時,會激活使用此類 defer;

    • 此類 defer 的唯一的運行時成本就是存儲參與延遲調用的相關信息,運行時性能最好。

    • 對于棧上分配的 defer 而言:

      • 編譯器會直接在棧上記錄一個 _defer 記錄,該記錄不涉及內存分配,并將其作為參數,傳入被翻譯為 deferprocStack 的延遲語句,在延遲調用的位置將 _defer 壓入 Goroutine 對應的延遲調用鏈表中;

      • 在函數末尾處,通過編譯器的配合,在調用被 defer 的函數前,調用 deferreturn,將被延遲的調用出棧并執行;

      • 此類 defer 的唯一運行時成本是從 _defer 記錄中將參數復制出,以及從延遲調用記錄鏈表出棧的成本,運行時性能其次。

    • 對于堆上分配的 defer 而言:

      • 編譯器首先會將延遲語句翻譯為一個 deferproc 調用,進而從運行時分配一個用于記錄被延遲調用的 _defer 記錄,并將被延遲的調用的入口地址及其參數復制保存,入棧到 Goroutine 對應的延遲調用鏈表中;

      • 在函數末尾處,通過編譯器的配合,在調用被 defer 的函數前,調用 deferreturn,從而將 _defer 實例歸還到資源池,而后通過模擬尾遞歸的方式來對需要 defer 的函數進行調用。

      • 此類 defer 的主要性能問題存在于每個 defer 語句產生記錄時的內存分配,記錄參數和完成調用時的參數移動時的系統調用,運行時性能最差。

      進一步閱讀的參考文獻

      • [Griesemer, 2009] Robert Griesemer. defer statement. Jan 27, 2009. https://github.com/golang/go/commit/4a903e0b32be5a590880ceb7379e68790602c29d

      • [Thompson, 2009] Ken Thompson. defer. Jan 27, 2009. https://github.com/golang/go/commit/1e1cc4eb570aa6fec645ff4faf13431847b99db8

      • [Cox, 2011] Russ Cox. runtime: aggregate defer. Oct, 2011. https://github.com/golang/go/issues/2364

      • [Clements, 2016] Austin Clements. runtime: optimize defer code. Sep, 2016. https://github.com/golang/go/commit/4c308188cc05d6c26f2a2eb30631f9a368aaa737

      • [Ma, 2016] Minux Ma. runtime: defer is slow. Mar, 2016. https://github.com/golang/go/issues/14939

      • [Randall, 2013] Keith Randall. cmd/compile: allocate some defers in stack frames. Dec, 2013. https://github.com/golang/go/issues/6980

      • [Vyukov, 2014] Dmitry Vyukov. runtime: per-P defer pool. Jan, 2014. https://github.com/golang/go/commit/1ba04c171a3c3a1ea0e5157e8340b606ec9d8949

      • [Scales, 2019] Dan Scales, Keith Randall, and Austin Clements. Proposal: Low-cost defers through inline code, and extra funcdata to manage the panic case. Sep, 2019. https://go.googlesource.com/proposal/+/refs/heads/master/design/34481-opencoded-defers.md

    總結

    以上是生活随笔為你收集整理的defer 的前世今生的全部內容,希望文章能夠幫你解決所遇到的問題。

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

    日本肉体xxxx裸交 | 久久久久99精品国产片 | 性欧美熟妇videofreesex | 影音先锋中文字幕无码 | 亚洲熟女一区二区三区 | 国产激情精品一区二区三区 | 免费人成在线观看网站 | 欧美日韩色另类综合 | 久久精品人妻少妇一区二区三区 | 国产av一区二区三区最新精品 | 人妻aⅴ无码一区二区三区 | 国产成人一区二区三区别 | 国产香蕉97碰碰久久人人 | 精品无码国产自产拍在线观看蜜 | 狠狠色色综合网站 | 日本护士xxxxhd少妇 | 免费无码av一区二区 | 国产肉丝袜在线观看 | 亲嘴扒胸摸屁股激烈网站 | 精品欧洲av无码一区二区三区 | 国产乱人伦偷精品视频 | 日本一区二区三区免费高清 | 久久久精品国产sm最大网站 | 99视频精品全部免费免费观看 | 国产亚洲人成在线播放 | 激情内射日本一区二区三区 | 国产情侣作爱视频免费观看 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 任你躁国产自任一区二区三区 | 99精品国产综合久久久久五月天 | 人人爽人人爽人人片av亚洲 | 最新国产麻豆aⅴ精品无码 | 久久久久人妻一区精品色欧美 | 牛和人交xxxx欧美 | 亚洲男人av香蕉爽爽爽爽 | 国产精品a成v人在线播放 | 成人无码视频免费播放 | 国产亚洲视频中文字幕97精品 | 国产深夜福利视频在线 | 人人妻人人澡人人爽欧美一区 | 久久婷婷五月综合色国产香蕉 | 免费观看又污又黄的网站 | 欧美成人高清在线播放 | 久久久亚洲欧洲日产国码αv | 97久久精品无码一区二区 | 午夜熟女插插xx免费视频 | 欧美成人午夜精品久久久 | 国产舌乚八伦偷品w中 | 中国女人内谢69xxxxxa片 | 亚洲色无码一区二区三区 | 少妇无码一区二区二三区 | 熟妇女人妻丰满少妇中文字幕 | 亚洲国产高清在线观看视频 | 国产熟妇另类久久久久 | 国产人成高清在线视频99最全资源 | 蜜臀aⅴ国产精品久久久国产老师 | 久久久久久久女国产乱让韩 | 国内精品久久毛片一区二区 | 国产精品无码久久av | 国产精品成人av在线观看 | 在教室伦流澡到高潮hnp视频 | 精品一二三区久久aaa片 | 黑人巨大精品欧美一区二区 | 欧美 日韩 亚洲 在线 | 国产成人午夜福利在线播放 | 四十如虎的丰满熟妇啪啪 | 国产成人无码区免费内射一片色欲 | 国产精品无码永久免费888 | 久久国产精品_国产精品 | 成人欧美一区二区三区黑人 | 亚洲の无码国产の无码影院 | 中文无码成人免费视频在线观看 | 国产午夜福利100集发布 | 日日摸夜夜摸狠狠摸婷婷 | 狂野欧美性猛xxxx乱大交 | 亚洲国产av精品一区二区蜜芽 | 野外少妇愉情中文字幕 | 伊人色综合久久天天小片 | 伊人久久大香线蕉亚洲 | 巨爆乳无码视频在线观看 | 无码福利日韩神码福利片 | 成熟人妻av无码专区 | 国产亚洲视频中文字幕97精品 | 亚洲第一无码av无码专区 | 麻豆成人精品国产免费 | 噜噜噜亚洲色成人网站 | 噜噜噜亚洲色成人网站 | 午夜精品一区二区三区的区别 | 成人免费无码大片a毛片 | 超碰97人人做人人爱少妇 | 日本xxxx色视频在线观看免费 | 久久亚洲a片com人成 | 国内精品久久毛片一区二区 | 300部国产真实乱 | 成人性做爰aaa片免费看不忠 | 久久精品成人欧美大片 | 国产精品久久久久9999小说 | 特级做a爰片毛片免费69 | 亚洲日本va中文字幕 | 国产精品99久久精品爆乳 | 久久午夜无码鲁丝片午夜精品 | 日本www一道久久久免费榴莲 | 美女极度色诱视频国产 | 久久精品女人的天堂av | 国产一区二区三区精品视频 | 国产综合久久久久鬼色 | 中国大陆精品视频xxxx | 最近免费中文字幕中文高清百度 | 国精品人妻无码一区二区三区蜜柚 | 国产两女互慰高潮视频在线观看 | 亚洲午夜久久久影院 | 亚洲爆乳精品无码一区二区三区 | 欧美日韩久久久精品a片 | 成人无码影片精品久久久 | 精品aⅴ一区二区三区 | 久久久精品人妻久久影视 | 麻花豆传媒剧国产免费mv在线 | 婷婷丁香六月激情综合啪 | 爆乳一区二区三区无码 | 在线亚洲高清揄拍自拍一品区 | 亚洲欧美日韩国产精品一区二区 | 美女毛片一区二区三区四区 | 无码人妻久久一区二区三区不卡 | 日本精品少妇一区二区三区 | 久久亚洲日韩精品一区二区三区 | 国产一区二区三区精品视频 | 欧美阿v高清资源不卡在线播放 | 久久国产劲爆∧v内射 | 永久免费观看美女裸体的网站 | 亚洲精品午夜国产va久久成人 | 鲁一鲁av2019在线 | 国产熟妇另类久久久久 | 国产精品嫩草久久久久 | 欧美日韩一区二区免费视频 | 欧美人与善在线com | 在线播放无码字幕亚洲 | 99久久久无码国产aaa精品 | 日韩av激情在线观看 | 国产av剧情md精品麻豆 | 亚洲天堂2017无码中文 | 日韩精品乱码av一区二区 | 成人精品一区二区三区中文字幕 | 天天躁夜夜躁狠狠是什么心态 | 国产免费久久久久久无码 | 亚洲综合无码久久精品综合 | 97无码免费人妻超级碰碰夜夜 | av在线亚洲欧洲日产一区二区 | 又湿又紧又大又爽a视频国产 | 亚洲a无码综合a国产av中文 | 国产精品人人爽人人做我的可爱 | 免费看男女做好爽好硬视频 | 98国产精品综合一区二区三区 | 国产成人一区二区三区别 | 99精品久久毛片a片 | 欧美丰满老熟妇xxxxx性 | 少妇太爽了在线观看 | 女人和拘做爰正片视频 | 国产性生大片免费观看性 | 波多野结衣一区二区三区av免费 | 中文字幕人妻丝袜二区 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 久久国产精品偷任你爽任你 | 国产av无码专区亚洲awww | 精品久久久无码中文字幕 | 国模大胆一区二区三区 | 久久久久久亚洲精品a片成人 | 性欧美牲交xxxxx视频 | 亚洲娇小与黑人巨大交 | 婷婷六月久久综合丁香 | 亚洲日本一区二区三区在线 | 久久国产自偷自偷免费一区调 | 日韩无码专区 | 欧美丰满熟妇xxxx | 精品无人国产偷自产在线 | 扒开双腿吃奶呻吟做受视频 | 久久99精品国产.久久久久 | av在线亚洲欧洲日产一区二区 | 正在播放东北夫妻内射 | 国产成人无码专区 | 亚洲日韩av一区二区三区中文 | 日本精品高清一区二区 | 国产成人无码a区在线观看视频app | 色五月丁香五月综合五月 | 亚洲色欲久久久综合网东京热 | 色婷婷av一区二区三区之红樱桃 | 国产免费无码一区二区视频 | 精品久久综合1区2区3区激情 | 久久久久亚洲精品男人的天堂 | 久久精品国产日本波多野结衣 | 国产成人精品一区二区在线小狼 | 国产亚洲精品久久久久久久久动漫 | 欧美高清在线精品一区 | 亚洲爆乳无码专区 | 黑人玩弄人妻中文在线 | 国产亚洲人成a在线v网站 | 亚洲国产av美女网站 | 亚洲男人av香蕉爽爽爽爽 | 亚洲乱码中文字幕在线 | 久久综合九色综合欧美狠狠 | 国产内射爽爽大片视频社区在线 | 亚洲国产精品无码久久久久高潮 | 亚洲日本一区二区三区在线 | 中国大陆精品视频xxxx | 巨爆乳无码视频在线观看 | 国产成人av免费观看 | 国产亚洲精品久久久久久国模美 | 欧美午夜特黄aaaaaa片 | 永久免费观看美女裸体的网站 | 久久人人爽人人爽人人片ⅴ | 亚洲精品久久久久久一区二区 | 中文精品久久久久人妻不卡 | 国产亚洲精品久久久久久久久动漫 | 一二三四在线观看免费视频 | 色狠狠av一区二区三区 | 大乳丰满人妻中文字幕日本 | 激情综合激情五月俺也去 | 十八禁真人啪啪免费网站 | 国产香蕉尹人综合在线观看 | 水蜜桃色314在线观看 | 天天躁夜夜躁狠狠是什么心态 | 欧洲熟妇色 欧美 | 亚洲国产av精品一区二区蜜芽 | 牛和人交xxxx欧美 | 少妇久久久久久人妻无码 | 性开放的女人aaa片 | 精品国产成人一区二区三区 | 亚洲日本va午夜在线电影 | 大肉大捧一进一出视频出来呀 | 97夜夜澡人人双人人人喊 | 少妇性l交大片欧洲热妇乱xxx | 一个人免费观看的www视频 | 99久久精品国产一区二区蜜芽 | 亚洲国产午夜精品理论片 | 理论片87福利理论电影 | 精品国产aⅴ无码一区二区 | 中文精品无码中文字幕无码专区 | 精品少妇爆乳无码av无码专区 | 男女猛烈xx00免费视频试看 | 日本xxxx色视频在线观看免费 | 色一情一乱一伦一视频免费看 | 麻豆md0077饥渴少妇 | 人妻尝试又大又粗久久 | 久久久久久九九精品久 | 色婷婷综合中文久久一本 | 丰满人妻一区二区三区免费视频 | 国产精品久久久一区二区三区 | 日韩精品成人一区二区三区 | 亚洲欧美日韩成人高清在线一区 | 成熟女人特级毛片www免费 | 免费中文字幕日韩欧美 | 国产精品18久久久久久麻辣 | 国产欧美熟妇另类久久久 | 国产欧美精品一区二区三区 | 亚洲日本va中文字幕 | 成人亚洲精品久久久久 | 鲁大师影院在线观看 | 亚洲精品一区二区三区在线 | 亚洲精品国产a久久久久久 | 性欧美疯狂xxxxbbbb | 亚洲 高清 成人 动漫 | 中文字幕无码免费久久99 | 天天爽夜夜爽夜夜爽 | 国产成人精品一区二区在线小狼 | 99精品无人区乱码1区2区3区 | 日韩欧美中文字幕在线三区 | 色五月丁香五月综合五月 | 色综合久久久久综合一本到桃花网 | 老子影院午夜精品无码 | 国产精品爱久久久久久久 | 国产精品国产三级国产专播 | 领导边摸边吃奶边做爽在线观看 | 爱做久久久久久 | 女人被男人躁得好爽免费视频 | 久久 国产 尿 小便 嘘嘘 | 国产色在线 | 国产 | 毛片内射-百度 | 乱码av麻豆丝袜熟女系列 | 国产亚洲美女精品久久久2020 | 激情亚洲一区国产精品 | 曰韩无码二三区中文字幕 | 久久aⅴ免费观看 | 国产精品久免费的黄网站 | 成人无码精品一区二区三区 | 人人妻人人澡人人爽欧美一区九九 | 国产精品办公室沙发 | 国产在热线精品视频 | 国产疯狂伦交大片 | 免费国产黄网站在线观看 | 丰满人妻翻云覆雨呻吟视频 | 国产精品亚洲专区无码不卡 | 玩弄人妻少妇500系列视频 | 强奷人妻日本中文字幕 | 欧美变态另类xxxx | 无码纯肉视频在线观看 | 亚洲欧美精品伊人久久 | 久久99久久99精品中文字幕 | 国产亚洲精品久久久闺蜜 | 无码人妻av免费一区二区三区 | 国产一区二区三区日韩精品 | 亚洲欧洲中文日韩av乱码 | 亚洲欧美日韩国产精品一区二区 | 欧美真人作爱免费视频 | 色情久久久av熟女人妻网站 | 97夜夜澡人人爽人人喊中国片 | 久久99久久99精品中文字幕 | 无码毛片视频一区二区本码 | 又粗又大又硬又长又爽 | 一本久道久久综合狠狠爱 | 中文字幕乱码中文乱码51精品 | 装睡被陌生人摸出水好爽 | 精品无码一区二区三区爱欲 | 99精品国产综合久久久久五月天 | 亚洲国产成人a精品不卡在线 | 欧美精品免费观看二区 | 97无码免费人妻超级碰碰夜夜 | 久久 国产 尿 小便 嘘嘘 | 欧美人与善在线com | 日产精品99久久久久久 | а√天堂www在线天堂小说 | 2020最新国产自产精品 | 久久国产精品萌白酱免费 | 六十路熟妇乱子伦 | 中文字幕人成乱码熟女app | 亚洲成熟女人毛毛耸耸多 | 欧美日韩人成综合在线播放 | 亚洲区小说区激情区图片区 | 少女韩国电视剧在线观看完整 | 欧美三级不卡在线观看 | 双乳奶水饱满少妇呻吟 | 在线成人www免费观看视频 | 天下第一社区视频www日本 | 国产亚洲精品久久久ai换 | 丝袜人妻一区二区三区 | 九九久久精品国产免费看小说 | 精品一二三区久久aaa片 | 色窝窝无码一区二区三区色欲 | 欧美 丝袜 自拍 制服 另类 | 少妇久久久久久人妻无码 | 扒开双腿吃奶呻吟做受视频 | 一本精品99久久精品77 | 久久人人97超碰a片精品 | 一本一道久久综合久久 | 欧美人与动性行为视频 | 一二三四在线观看免费视频 | 露脸叫床粗话东北少妇 | 综合网日日天干夜夜久久 | 精品成在人线av无码免费看 | 日韩精品无码一区二区中文字幕 | 欧洲熟妇精品视频 | 99久久亚洲精品无码毛片 | 亚洲高清偷拍一区二区三区 | 亚洲狠狠色丁香婷婷综合 | 岛国片人妻三上悠亚 | 国产欧美熟妇另类久久久 | 国产国语老龄妇女a片 | 亚洲精品国产精品乱码不卡 | 男人和女人高潮免费网站 | 精品一二三区久久aaa片 | 色一情一乱一伦 | 人人爽人人澡人人人妻 | 乱人伦中文视频在线观看 | 国产乱子伦视频在线播放 | 国产一区二区三区影院 | 日本熟妇人妻xxxxx人hd | 婷婷六月久久综合丁香 | 国精品人妻无码一区二区三区蜜柚 | 国产成人精品必看 | 久青草影院在线观看国产 | 学生妹亚洲一区二区 | 亚洲国产精品久久久久久 | www国产亚洲精品久久久日本 | 精品久久久久久人妻无码中文字幕 | 欧洲vodafone精品性 | 波多野结衣aⅴ在线 | 又粗又大又硬毛片免费看 | 午夜成人1000部免费视频 | 图片小说视频一区二区 | 少妇高潮一区二区三区99 | 亚洲一区二区三区国产精华液 | 无码精品国产va在线观看dvd | 波多野结衣乳巨码无在线观看 | 粉嫩少妇内射浓精videos | 国产绳艺sm调教室论坛 | 日本精品久久久久中文字幕 | 在线а√天堂中文官网 | 一本久道久久综合婷婷五月 | 国产午夜视频在线观看 | 日本又色又爽又黄的a片18禁 | 欧美日韩在线亚洲综合国产人 | 久青草影院在线观看国产 | 国产精品久久久av久久久 | 玩弄中年熟妇正在播放 | 国产精品无码久久av | 国产成人久久精品流白浆 | 天堂在线观看www | 久久久久久久女国产乱让韩 | 久久久久av无码免费网 | 无码av最新清无码专区吞精 | 午夜男女很黄的视频 | 激情亚洲一区国产精品 | 无码人妻少妇伦在线电影 | 久久久精品456亚洲影院 | 亚洲日本一区二区三区在线 | 婷婷丁香六月激情综合啪 | 丰满护士巨好爽好大乳 | 少妇无码av无码专区在线观看 | 欧美xxxxx精品 | 欧美老人巨大xxxx做受 | 欧美老妇交乱视频在线观看 | 国产超碰人人爽人人做人人添 | 国产成人综合美国十次 | 亚洲国产综合无码一区 | 国产激情艳情在线看视频 | 亚洲国产午夜精品理论片 | 国产成人无码一二三区视频 | 国产猛烈高潮尖叫视频免费 | 全球成人中文在线 | 特大黑人娇小亚洲女 | 亚洲精品国偷拍自产在线观看蜜桃 | 国产精品久久久久7777 | av无码电影一区二区三区 | 国产超级va在线观看视频 | 亚洲日韩av片在线观看 | 天天躁日日躁狠狠躁免费麻豆 | 国产精品亚洲lv粉色 | 成人欧美一区二区三区黑人免费 | 色欲久久久天天天综合网精品 | 欧美日本精品一区二区三区 | 日韩av无码中文无码电影 | 色综合天天综合狠狠爱 | 中文无码伦av中文字幕 | 亚洲成a人片在线观看无码3d | 国产一区二区三区日韩精品 | 国产明星裸体无码xxxx视频 | 人人妻人人藻人人爽欧美一区 | 国产亚洲精品久久久闺蜜 | 国产亚洲精品久久久闺蜜 | 97色伦图片97综合影院 | 欧美人与牲动交xxxx | 76少妇精品导航 | 午夜精品久久久内射近拍高清 | 成人欧美一区二区三区 | 欧美喷潮久久久xxxxx | 亚洲春色在线视频 | 一本久道久久综合婷婷五月 | 国产精品第一区揄拍无码 | 97夜夜澡人人爽人人喊中国片 | 久久久精品人妻久久影视 | 午夜免费福利小电影 | 樱花草在线社区www | 国产三级久久久精品麻豆三级 | 97夜夜澡人人爽人人喊中国片 | 在线成人www免费观看视频 | 国产精品二区一区二区aⅴ污介绍 | 国产成人午夜福利在线播放 | 中文字幕无码av激情不卡 | 久久精品国产亚洲精品 | 国精产品一区二区三区 | 欧美日韩视频无码一区二区三 | 国产精品沙发午睡系列 | 婷婷六月久久综合丁香 | 国产亚洲日韩欧美另类第八页 | 女人和拘做爰正片视频 | 久久人人爽人人爽人人片av高清 | 骚片av蜜桃精品一区 | 国产精品无码永久免费888 | 欧美性生交活xxxxxdddd | 啦啦啦www在线观看免费视频 | 午夜丰满少妇性开放视频 | 成 人 网 站国产免费观看 | 丰满人妻一区二区三区免费视频 | 妺妺窝人体色www婷婷 | 无码午夜成人1000部免费视频 | 国产一区二区三区四区五区加勒比 | 亚洲精品综合五月久久小说 | 在线亚洲高清揄拍自拍一品区 | 无码帝国www无码专区色综合 | 国产性生交xxxxx无码 | 在线看片无码永久免费视频 | 中文字幕乱码中文乱码51精品 | 国产精品久久久久久亚洲毛片 | 久久久亚洲欧洲日产国码αv | 国产精品美女久久久网av | 日韩精品无码免费一区二区三区 | 欧美放荡的少妇 | 国产成人无码区免费内射一片色欲 | 久久亚洲国产成人精品性色 | 少妇被粗大的猛进出69影院 | 亚洲午夜无码久久 | 熟妇激情内射com | 欧美阿v高清资源不卡在线播放 | 久久精品女人的天堂av | 精品熟女少妇av免费观看 | 日本一区二区三区免费高清 | 性欧美熟妇videofreesex | 精品夜夜澡人妻无码av蜜桃 | 国产欧美亚洲精品a | 亚洲午夜福利在线观看 | 久久婷婷五月综合色国产香蕉 | 丰腴饱满的极品熟妇 | 思思久久99热只有频精品66 | 天天做天天爱天天爽综合网 | 极品嫩模高潮叫床 | 国产成人无码午夜视频在线观看 | 玩弄少妇高潮ⅹxxxyw | 国产午夜福利100集发布 | 国产午夜精品一区二区三区嫩草 | 久久亚洲国产成人精品性色 | 超碰97人人做人人爱少妇 | 乌克兰少妇xxxx做受 | 精品日本一区二区三区在线观看 | 男女猛烈xx00免费视频试看 | 又湿又紧又大又爽a视频国产 | 精品厕所偷拍各类美女tp嘘嘘 | 久久精品一区二区三区四区 | 97夜夜澡人人爽人人喊中国片 | 国产亚洲精品久久久久久大师 | 国产特级毛片aaaaaa高潮流水 | 欧美性黑人极品hd | 日韩精品无码一区二区中文字幕 | 久久久国产一区二区三区 | 夜先锋av资源网站 | 久久久中文字幕日本无吗 | 亚洲一区二区三区四区 | 波多野42部无码喷潮在线 | 国产午夜亚洲精品不卡 | 无码人妻丰满熟妇区五十路百度 | 在线欧美精品一区二区三区 | 4hu四虎永久在线观看 | 亚洲无人区午夜福利码高清完整版 | 中文字幕人妻无码一区二区三区 | 亚洲精品成a人在线观看 | 成人欧美一区二区三区黑人免费 | 欧美国产日产一区二区 | 久久久精品456亚洲影院 | 国产sm调教视频在线观看 | 成人影院yy111111在线观看 | 欧美喷潮久久久xxxxx | 人妻夜夜爽天天爽三区 | 51国偷自产一区二区三区 | 久久综合狠狠综合久久综合88 | 亚洲中文字幕av在天堂 | 午夜精品久久久内射近拍高清 | 捆绑白丝粉色jk震动捧喷白浆 | 日韩亚洲欧美中文高清在线 | 少妇激情av一区二区 | 国产精品高潮呻吟av久久4虎 | 亚洲国产精品无码久久久久高潮 | 国产乱人伦偷精品视频 | 国产精品久久久久无码av色戒 | 对白脏话肉麻粗话av | 少妇性l交大片欧洲热妇乱xxx | 激情国产av做激情国产爱 | 99久久精品午夜一区二区 | 狠狠综合久久久久综合网 | 国产熟妇高潮叫床视频播放 | 国产精品久久久一区二区三区 | 少妇太爽了在线观看 | 欧美高清在线精品一区 | 日韩精品乱码av一区二区 | 国产精品内射视频免费 | 国产精品18久久久久久麻辣 | 乱人伦人妻中文字幕无码久久网 | 图片区 小说区 区 亚洲五月 | 综合激情五月综合激情五月激情1 | 内射老妇bbwx0c0ck | 麻豆果冻传媒2021精品传媒一区下载 | 国产女主播喷水视频在线观看 | a在线观看免费网站大全 | 亚洲精品国偷拍自产在线麻豆 | 国语自产偷拍精品视频偷 | 久久久精品人妻久久影视 | 午夜嘿嘿嘿影院 | 国产口爆吞精在线视频 | av无码久久久久不卡免费网站 | 欧美兽交xxxx×视频 | 台湾无码一区二区 | 久久久久久亚洲精品a片成人 | 欧美成人午夜精品久久久 | 亚洲 日韩 欧美 成人 在线观看 | 国产美女精品一区二区三区 | 国产成人一区二区三区在线观看 | 亚洲欧美中文字幕5发布 | 久久zyz资源站无码中文动漫 | 精品欧美一区二区三区久久久 | а√天堂www在线天堂小说 | 国产疯狂伦交大片 | 97人妻精品一区二区三区 | 午夜男女很黄的视频 | 一本久久a久久精品vr综合 | 国产亚洲精品久久久久久大师 | 日韩精品a片一区二区三区妖精 | 国产精品美女久久久久av爽李琼 | 人妻熟女一区 | 国产精品高潮呻吟av久久4虎 | 亚洲国产精品无码久久久久高潮 | 国产九九九九九九九a片 | 久久久婷婷五月亚洲97号色 | 97se亚洲精品一区 | 午夜理论片yy44880影院 | 国产亚洲精品久久久闺蜜 | 成人试看120秒体验区 | 日日碰狠狠躁久久躁蜜桃 | 国产超碰人人爽人人做人人添 | 老子影院午夜伦不卡 | 人妻无码久久精品人妻 | 亚洲乱亚洲乱妇50p | 久久久精品欧美一区二区免费 | 久久国内精品自在自线 | 国产亚洲美女精品久久久2020 | 色窝窝无码一区二区三区色欲 | 黑人玩弄人妻中文在线 | 欧美高清在线精品一区 | 久久综合久久自在自线精品自 | 国产午夜亚洲精品不卡下载 | 欧美成人午夜精品久久久 | 婷婷色婷婷开心五月四房播播 | 久久婷婷五月综合色国产香蕉 | 国语自产偷拍精品视频偷 | 成人女人看片免费视频放人 | 国产无套内射久久久国产 | 曰韩无码二三区中文字幕 | 欧美三级不卡在线观看 | 国产精品免费大片 | 中文字幕无码日韩专区 | 色婷婷香蕉在线一区二区 | 久久天天躁狠狠躁夜夜免费观看 | 日产精品99久久久久久 | 乱码av麻豆丝袜熟女系列 | 国产人妻人伦精品1国产丝袜 | 亚洲区小说区激情区图片区 | 日日干夜夜干 | 久久精品中文字幕一区 | 最新国产乱人伦偷精品免费网站 | 精品乱子伦一区二区三区 | 亚洲精品综合五月久久小说 | 九月婷婷人人澡人人添人人爽 | 久久国产自偷自偷免费一区调 | 久久人人爽人人人人片 | yw尤物av无码国产在线观看 | 香港三级日本三级妇三级 | 欧美日韩综合一区二区三区 | 欧美日韩综合一区二区三区 | 日本一区二区三区免费高清 | 亚洲一区二区三区含羞草 | 鲁鲁鲁爽爽爽在线视频观看 | 欧美高清在线精品一区 | 秋霞成人午夜鲁丝一区二区三区 | 久久国产自偷自偷免费一区调 | 国产片av国语在线观看 | 熟妇人妻无码xxx视频 | 久久精品国产日本波多野结衣 | 国产乱人伦av在线无码 | 国产精品福利视频导航 | 亚洲综合无码一区二区三区 | 蜜臀aⅴ国产精品久久久国产老师 | 男女性色大片免费网站 | 亚洲精品鲁一鲁一区二区三区 | 中文毛片无遮挡高清免费 | 成人三级无码视频在线观看 | 无码一区二区三区在线观看 | 亚洲精品久久久久久久久久久 | 日韩成人一区二区三区在线观看 | 欧美日韩一区二区免费视频 | 国产亚洲人成a在线v网站 | 全球成人中文在线 | 久久这里只有精品视频9 | 国精产品一品二品国精品69xx | 中文字幕亚洲情99在线 | 精品亚洲韩国一区二区三区 | 国产高清不卡无码视频 | 国产亚洲视频中文字幕97精品 | 天天av天天av天天透 | 日本饥渴人妻欲求不满 | 午夜无码区在线观看 | 亚洲色偷偷男人的天堂 | 激情人妻另类人妻伦 | 一个人看的www免费视频在线观看 | 精品无人国产偷自产在线 | 亚洲s色大片在线观看 | 精品无码国产自产拍在线观看蜜 | 国产 精品 自在自线 | 俺去俺来也www色官网 | 1000部啪啪未满十八勿入下载 | 久久久精品人妻久久影视 | 成人无码视频在线观看网站 | 荫蒂添的好舒服视频囗交 | 国产情侣作爱视频免费观看 | 正在播放老肥熟妇露脸 | 国产精品内射视频免费 | 欧美丰满熟妇xxxx性ppx人交 | 国产极品视觉盛宴 | 亚洲爆乳无码专区 | 鲁鲁鲁爽爽爽在线视频观看 | 亚洲小说图区综合在线 | 99久久精品日本一区二区免费 | 麻豆md0077饥渴少妇 | 无码帝国www无码专区色综合 | 无码乱肉视频免费大全合集 | 亚洲欧美日韩综合久久久 | 色综合久久久久综合一本到桃花网 | 欧美熟妇另类久久久久久不卡 | 日本又色又爽又黄的a片18禁 | 无码人妻丰满熟妇区五十路百度 | 国产明星裸体无码xxxx视频 | 无码午夜成人1000部免费视频 | 水蜜桃亚洲一二三四在线 | 大地资源网第二页免费观看 | 亚洲天堂2017无码中文 | 精品成在人线av无码免费看 | 99久久精品无码一区二区毛片 | 精品国精品国产自在久国产87 | 中文字幕无码人妻少妇免费 | 国产又爽又猛又粗的视频a片 | 中文字幕乱码人妻二区三区 | av无码久久久久不卡免费网站 | 精品夜夜澡人妻无码av蜜桃 | 漂亮人妻洗澡被公强 日日躁 | 亚洲一区二区三区无码久久 | 精品乱码久久久久久久 | √天堂资源地址中文在线 | 任你躁在线精品免费 | 日本肉体xxxx裸交 | 在线精品国产一区二区三区 | 内射后入在线观看一区 | 99在线 | 亚洲 | 夜精品a片一区二区三区无码白浆 | 奇米影视888欧美在线观看 | 欧美丰满老熟妇xxxxx性 | 亚洲aⅴ无码成人网站国产app | 一本色道久久综合亚洲精品不卡 | 日韩精品无码一区二区中文字幕 | 又大又黄又粗又爽的免费视频 | 日本熟妇乱子伦xxxx | 精品国产福利一区二区 | 欧美人与牲动交xxxx | 欧美xxxx黑人又粗又长 | 国产精品毛片一区二区 | 嫩b人妻精品一区二区三区 | 色五月丁香五月综合五月 | 国产熟女一区二区三区四区五区 | 麻豆蜜桃av蜜臀av色欲av | 日本大乳高潮视频在线观看 | 亚洲成在人网站无码天堂 | 日韩视频 中文字幕 视频一区 | 熟妇女人妻丰满少妇中文字幕 | 亚洲国产午夜精品理论片 | 大地资源中文第3页 | 久久熟妇人妻午夜寂寞影院 | 亚洲中文字幕无码中字 | 思思久久99热只有频精品66 | 97夜夜澡人人爽人人喊中国片 | 99久久精品日本一区二区免费 | 国产精品久久久久久久9999 | 国产99久久精品一区二区 | 久久综合网欧美色妞网 | 图片小说视频一区二区 | 亚洲国产一区二区三区在线观看 | 欧美日韩一区二区三区自拍 | 99riav国产精品视频 | 欧美成人高清在线播放 | 亚洲国产综合无码一区 | 全球成人中文在线 | 亚洲自偷精品视频自拍 | 55夜色66夜色国产精品视频 | 亚洲区小说区激情区图片区 | 色欲av亚洲一区无码少妇 | 国产办公室秘书无码精品99 | 人人爽人人澡人人人妻 | 免费观看又污又黄的网站 | 亚洲娇小与黑人巨大交 | 高清不卡一区二区三区 | 在线天堂新版最新版在线8 | 国精产品一区二区三区 | 一区二区三区乱码在线 | 欧洲 | 欧美成人高清在线播放 | 久久国产精品_国产精品 | 国产深夜福利视频在线 | 亚洲精品欧美二区三区中文字幕 | 亚洲小说图区综合在线 | 国产在线精品一区二区三区直播 | 国产成人精品必看 | 精品人妻人人做人人爽夜夜爽 | 精品欧洲av无码一区二区三区 | 中文字幕乱码人妻无码久久 | 妺妺窝人体色www婷婷 | 精品国产一区二区三区av 性色 | 成人精品视频一区二区三区尤物 | 国产精品亚洲а∨无码播放麻豆 | 任你躁国产自任一区二区三区 | 欧美人与善在线com | 综合网日日天干夜夜久久 | 欧美野外疯狂做受xxxx高潮 | 国产乱人偷精品人妻a片 | 人人妻人人澡人人爽人人精品浪潮 | 人人妻在人人 | 国产精品人人爽人人做我的可爱 | 成在人线av无码免观看麻豆 | 性欧美牲交在线视频 | a在线观看免费网站大全 | 18精品久久久无码午夜福利 | 免费男性肉肉影院 | 欧美丰满熟妇xxxx性ppx人交 | 日本www一道久久久免费榴莲 | 乱人伦人妻中文字幕无码久久网 | 人妻人人添人妻人人爱 | 中文字幕av伊人av无码av | 全黄性性激高免费视频 | 无码人妻精品一区二区三区不卡 | 伊在人天堂亚洲香蕉精品区 | 欧洲欧美人成视频在线 | 波多野结衣aⅴ在线 | 久久综合给合久久狠狠狠97色 | 精品人妻人人做人人爽夜夜爽 | 在线亚洲高清揄拍自拍一品区 | 女人被男人躁得好爽免费视频 | 国产三级精品三级男人的天堂 | 欧美丰满少妇xxxx性 | 日本熟妇乱子伦xxxx | 成人欧美一区二区三区黑人免费 | 国产人妻大战黑人第1集 | 国产成人无码av片在线观看不卡 | 日日摸夜夜摸狠狠摸婷婷 | 国产区女主播在线观看 | 国产办公室秘书无码精品99 | www成人国产高清内射 | 一本色道久久综合亚洲精品不卡 | 国产成人精品无码播放 | 久久久久亚洲精品中文字幕 | 一本久道久久综合婷婷五月 | 无码任你躁久久久久久久 | 妺妺窝人体色www婷婷 | 黑人粗大猛烈进出高潮视频 | 国语精品一区二区三区 | 国产电影无码午夜在线播放 | 人妻体内射精一区二区三四 | 亚洲欧美国产精品久久 | 国产小呦泬泬99精品 | 99久久精品午夜一区二区 | 国产精品高潮呻吟av久久 | 欧美性黑人极品hd | 日韩成人一区二区三区在线观看 | 真人与拘做受免费视频一 | 国产午夜亚洲精品不卡 | 亚洲精品午夜国产va久久成人 | 久久精品人妻少妇一区二区三区 | 久久婷婷五月综合色国产香蕉 | 久久久久久九九精品久 | 亚洲の无码国产の无码步美 | 学生妹亚洲一区二区 | 狠狠色噜噜狠狠狠7777奇米 | 麻豆md0077饥渴少妇 | 精品日本一区二区三区在线观看 | 少妇性荡欲午夜性开放视频剧场 | 九九久久精品国产免费看小说 | 自拍偷自拍亚洲精品被多人伦好爽 | 国产精品无套呻吟在线 | 国产亚洲精品久久久ai换 | 久久国语露脸国产精品电影 | 亚洲第一无码av无码专区 | 国产精品内射视频免费 | 人妻少妇精品视频专区 | 欧美丰满老熟妇xxxxx性 | 精品少妇爆乳无码av无码专区 | 天天爽夜夜爽夜夜爽 | 国产网红无码精品视频 | 男女下面进入的视频免费午夜 | 乱人伦中文视频在线观看 | 正在播放东北夫妻内射 | 亚洲精品综合一区二区三区在线 | 亚洲人成网站免费播放 | 国产精品免费大片 | 久久亚洲a片com人成 | 色综合久久久无码网中文 | 国产精品亚洲综合色区韩国 | 麻花豆传媒剧国产免费mv在线 | 99精品久久毛片a片 | 亚洲成熟女人毛毛耸耸多 | 国产精品-区区久久久狼 | 无人区乱码一区二区三区 | 色欲人妻aaaaaaa无码 | 亚洲精品美女久久久久久久 | 最新版天堂资源中文官网 | 大乳丰满人妻中文字幕日本 | 精品国产青草久久久久福利 | 亚洲天堂2017无码中文 | 最近免费中文字幕中文高清百度 | 青青久在线视频免费观看 | 久久久国产精品无码免费专区 | 午夜福利一区二区三区在线观看 | 西西人体www44rt大胆高清 | a在线观看免费网站大全 | 九九在线中文字幕无码 | 伊人久久婷婷五月综合97色 | 亚洲精品午夜国产va久久成人 | 日本护士xxxxhd少妇 | 亚洲色成人中文字幕网站 | 国产成人无码一二三区视频 | 麻豆精品国产精华精华液好用吗 | 国产综合久久久久鬼色 | 亚洲午夜福利在线观看 | 国产成人无码av片在线观看不卡 | 国产亚洲精品久久久久久久 | 国产精品a成v人在线播放 | 国产区女主播在线观看 | 天天燥日日燥 | 少妇久久久久久人妻无码 | 娇妻被黑人粗大高潮白浆 | 国产午夜视频在线观看 | 色噜噜亚洲男人的天堂 | 嫩b人妻精品一区二区三区 | 亚洲 欧美 激情 小说 另类 | 亚拍精品一区二区三区探花 | 全黄性性激高免费视频 | 国产精品人妻一区二区三区四 | 精品人妻人人做人人爽夜夜爽 | 色婷婷欧美在线播放内射 | 国产人成高清在线视频99最全资源 | 1000部夫妻午夜免费 | 久久国产精品_国产精品 | 性欧美疯狂xxxxbbbb | 国产午夜视频在线观看 | 亚洲色成人中文字幕网站 | 日韩欧美群交p片內射中文 | 一本无码人妻在中文字幕免费 | 麻豆国产人妻欲求不满谁演的 | 亚洲码国产精品高潮在线 | 色综合久久网 | 日韩精品无码一本二本三本色 | 少妇愉情理伦片bd | 久久人人爽人人爽人人片av高清 | 国产极品美女高潮无套在线观看 | 人妻无码αv中文字幕久久琪琪布 | 麻豆果冻传媒2021精品传媒一区下载 | 国产精品对白交换视频 | 国精品人妻无码一区二区三区蜜柚 | 久久婷婷五月综合色国产香蕉 | 国产女主播喷水视频在线观看 | 亚洲中文字幕在线无码一区二区 | 人妻熟女一区 | 国产精品久久久一区二区三区 | 4hu四虎永久在线观看 | av香港经典三级级 在线 | 亚洲一区二区三区无码久久 | 色一情一乱一伦一区二区三欧美 | 日本又色又爽又黄的a片18禁 | 中文字幕无码日韩专区 | 日日碰狠狠躁久久躁蜜桃 | 奇米影视7777久久精品 | 台湾无码一区二区 | 国产香蕉尹人综合在线观看 | 伊人色综合久久天天小片 | 思思久久99热只有频精品66 | 国产精品无码永久免费888 | 国产成人无码午夜视频在线观看 | 久久精品99久久香蕉国产色戒 | 国产精品第一国产精品 | 国产精品亚洲综合色区韩国 | 免费播放一区二区三区 | 性做久久久久久久免费看 | 国产亚洲tv在线观看 | 一个人看的视频www在线 | 亚洲中文无码av永久不收费 | 午夜理论片yy44880影院 | 黑人粗大猛烈进出高潮视频 | 国产成人综合在线女婷五月99播放 | 欧美丰满熟妇xxxx性ppx人交 | 亚洲精品国产第一综合99久久 | 国产成人亚洲综合无码 | 无遮无挡爽爽免费视频 | 国产精品va在线观看无码 | 亚洲国产成人av在线观看 | 香港三级日本三级妇三级 | 东京一本一道一二三区 | 国产午夜视频在线观看 | 亚洲综合另类小说色区 | 大肉大捧一进一出好爽视频 | 亚洲最大成人网站 | 少女韩国电视剧在线观看完整 | 女人被男人爽到呻吟的视频 | 高潮喷水的毛片 | 在线精品亚洲一区二区 | 伊人久久大香线蕉av一区二区 | 少妇无码一区二区二三区 | 亚洲 激情 小说 另类 欧美 | 人妻少妇精品久久 | 玩弄少妇高潮ⅹxxxyw | 亚洲色大成网站www国产 | 俺去俺来也www色官网 | 久久97精品久久久久久久不卡 | 小泽玛莉亚一区二区视频在线 | 国产无遮挡又黄又爽又色 | 51国偷自产一区二区三区 | 国产乱人伦av在线无码 | 国产成人午夜福利在线播放 | 丰满岳乱妇在线观看中字无码 | 色综合久久久久综合一本到桃花网 | 久久精品99久久香蕉国产色戒 | 国产莉萝无码av在线播放 | 在线看片无码永久免费视频 | 国产精品手机免费 | 亚洲国产精品无码久久久久高潮 | 成人一区二区免费视频 | 久久精品中文字幕大胸 | 中文字幕乱码中文乱码51精品 | 欧美一区二区三区视频在线观看 | 国产一区二区三区日韩精品 | 在线播放亚洲第一字幕 | 日本精品人妻无码免费大全 | 国产午夜手机精彩视频 | 精品国产av色一区二区深夜久久 | 久久99国产综合精品 | 亚洲国产精品毛片av不卡在线 | 久久婷婷五月综合色国产香蕉 | 一本久道久久综合狠狠爱 | 国产熟女一区二区三区四区五区 | 国产亚洲人成在线播放 | 国产精品人人妻人人爽 | 免费人成在线观看网站 | 久久国产精品萌白酱免费 | 日本免费一区二区三区最新 | 国产97色在线 | 免 | 色噜噜亚洲男人的天堂 | 亚拍精品一区二区三区探花 | 夜夜高潮次次欢爽av女 | 精品乱码久久久久久久 | 伊在人天堂亚洲香蕉精品区 | 在线а√天堂中文官网 | 国产亚洲欧美在线专区 | 日本免费一区二区三区最新 | 女人高潮内射99精品 | 国产精品亚洲综合色区韩国 | 亚洲精品国偷拍自产在线麻豆 | 色综合久久久久综合一本到桃花网 | 成人一区二区免费视频 | 国产另类ts人妖一区二区 | 扒开双腿疯狂进出爽爽爽视频 | 中文字幕无码乱人伦 | 欧美变态另类xxxx | 精品无码一区二区三区的天堂 | 精品国产av色一区二区深夜久久 | 久久亚洲国产成人精品性色 | 在线观看欧美一区二区三区 | 国产精品久免费的黄网站 | 国产av剧情md精品麻豆 | 亚洲乱亚洲乱妇50p | 97人妻精品一区二区三区 | 精品乱码久久久久久久 | 国产农村乱对白刺激视频 | 日韩av激情在线观看 | 国产精品久久久久久久9999 | 成在人线av无码免费 | 日韩欧美中文字幕在线三区 | 国产亚洲欧美在线专区 | 国产人妻人伦精品1国产丝袜 | 中文精品无码中文字幕无码专区 | 国产精品多人p群无码 | 欧美猛少妇色xxxxx | v一区无码内射国产 | 在线观看免费人成视频 | 国产香蕉97碰碰久久人人 | 亚洲色无码一区二区三区 | 久久久久久久久888 | 国产超级va在线观看视频 | а天堂中文在线官网 | 亚洲一区二区三区国产精华液 | 精品欧洲av无码一区二区三区 | 超碰97人人做人人爱少妇 | 久久国产36精品色熟妇 | 麻豆精产国品 | 久久99精品国产麻豆 | 亚洲国产精品久久久天堂 | 欧美大屁股xxxxhd黑色 | 久久亚洲中文字幕精品一区 | 成 人 免费观看网站 | 一本久道高清无码视频 | 99er热精品视频 | 欧美老妇交乱视频在线观看 | 给我免费的视频在线观看 | 成人精品天堂一区二区三区 | 中文字幕无码视频专区 | 免费视频欧美无人区码 | 丝袜 中出 制服 人妻 美腿 | 亚洲国产精品久久久久久 | 中文字幕日韩精品一区二区三区 | 熟妇人妻中文av无码 | 中国女人内谢69xxxxxa片 | 国产成人精品一区二区在线小狼 | 少妇一晚三次一区二区三区 | 老熟女乱子伦 | 日本一区二区三区免费播放 | 小泽玛莉亚一区二区视频在线 | 97人妻精品一区二区三区 | 捆绑白丝粉色jk震动捧喷白浆 | 亚洲第一网站男人都懂 | 免费男性肉肉影院 | 草草网站影院白丝内射 | 99国产精品白浆在线观看免费 | 日日摸天天摸爽爽狠狠97 | 久久久精品国产sm最大网站 | 青青久在线视频免费观看 | 亚洲精品久久久久久一区二区 | 国产午夜亚洲精品不卡下载 | 无码毛片视频一区二区本码 | 国产人妻人伦精品1国产丝袜 | 国产免费观看黄av片 | 最新版天堂资源中文官网 | 亚洲综合久久一区二区 | 波多野结衣av在线观看 | 国产欧美精品一区二区三区 | 久久99精品国产麻豆 | 国产精品igao视频网 | 精品国产精品久久一区免费式 | 亚洲国产精品一区二区第一页 | 男人扒开女人内裤强吻桶进去 | 国产精品免费大片 | 欧美变态另类xxxx | 夜精品a片一区二区三区无码白浆 | 黄网在线观看免费网站 | 欧美性猛交内射兽交老熟妇 | 亚洲午夜无码久久 | 99久久精品日本一区二区免费 | 国产精品亚洲综合色区韩国 | 国产精品福利视频导航 | 精品无码国产一区二区三区av | www国产亚洲精品久久网站 | 国产真人无遮挡作爱免费视频 | 国产xxx69麻豆国语对白 | 久久亚洲日韩精品一区二区三区 | 国产精品香蕉在线观看 | 亚洲人交乣女bbw | 国产午夜福利亚洲第一 | 国产色在线 | 国产 | 色综合久久88色综合天天 | 成人无码视频在线观看网站 | 免费看少妇作爱视频 | 国产av剧情md精品麻豆 | 中文字幕无码乱人伦 | 亚洲国产精品一区二区美利坚 | 亚洲无人区一区二区三区 | 亚洲国产av精品一区二区蜜芽 | 成人三级无码视频在线观看 | 内射巨臀欧美在线视频 | 国产亚洲精品久久久久久久久动漫 | 少妇愉情理伦片bd | 亚洲色大成网站www | 性生交片免费无码看人 | 国产成人无码午夜视频在线观看 | 国产精品自产拍在线观看 | 国产精品高潮呻吟av久久4虎 | 成人免费视频一区二区 | 性做久久久久久久久 | 久久精品国产日本波多野结衣 | 日本乱人伦片中文三区 | 无套内射视频囯产 | 久久久国产精品无码免费专区 | 成人试看120秒体验区 | 亚洲精品久久久久中文第一幕 | 娇妻被黑人粗大高潮白浆 | 无码人妻黑人中文字幕 | 国产情侣作爱视频免费观看 | 色综合视频一区二区三区 | 久久午夜无码鲁丝片秋霞 | 国产69精品久久久久app下载 | 色综合久久久久综合一本到桃花网 | 初尝人妻少妇中文字幕 | 成人一区二区免费视频 | 久久精品国产日本波多野结衣 | 少妇性l交大片欧洲热妇乱xxx | 久久午夜无码鲁丝片午夜精品 | 久久久久成人片免费观看蜜芽 | 国产麻豆精品一区二区三区v视界 | 欧美变态另类xxxx | 中文精品无码中文字幕无码专区 | 又大又硬又黄的免费视频 | 日韩精品无码免费一区二区三区 | 国内精品九九久久久精品 | 领导边摸边吃奶边做爽在线观看 | 色狠狠av一区二区三区 | 激情内射日本一区二区三区 | 亚洲精品综合五月久久小说 | 激情综合激情五月俺也去 | 日本熟妇人妻xxxxx人hd | 精品厕所偷拍各类美女tp嘘嘘 | 在线a亚洲视频播放在线观看 | 国产高潮视频在线观看 | 国产片av国语在线观看 | 欧美性猛交xxxx富婆 | 丰满少妇熟乱xxxxx视频 | 久久五月精品中文字幕 | 九月婷婷人人澡人人添人人爽 | 亚洲乱码国产乱码精品精 | 国产超级va在线观看视频 | 窝窝午夜理论片影院 | 99国产欧美久久久精品 | 伦伦影院午夜理论片 | 精品久久综合1区2区3区激情 | 精品国精品国产自在久国产87 | 日本饥渴人妻欲求不满 | 久久综合九色综合欧美狠狠 | 精品一区二区三区波多野结衣 | √天堂中文官网8在线 | 麻豆国产人妻欲求不满谁演的 | 久久精品人妻少妇一区二区三区 | 国产精品-区区久久久狼 | 亚洲色无码一区二区三区 | 欧美人妻一区二区三区 | 国产乱子伦视频在线播放 | 领导边摸边吃奶边做爽在线观看 | 高潮毛片无遮挡高清免费 | 国语精品一区二区三区 | 67194成是人免费无码 | 国产午夜亚洲精品不卡 | 88国产精品欧美一区二区三区 | 中文字幕无码日韩欧毛 | 亚洲熟悉妇女xxx妇女av | a国产一区二区免费入口 | 免费无码av一区二区 | 日本精品久久久久中文字幕 | 国产真实乱对白精彩久久 | 国产成人精品三级麻豆 | 综合人妻久久一区二区精品 | 日本精品少妇一区二区三区 | 国产精品-区区久久久狼 | 日本一卡2卡3卡四卡精品网站 | 一本色道久久综合狠狠躁 | 十八禁视频网站在线观看 | 国产av人人夜夜澡人人爽麻豆 | 老子影院午夜精品无码 | 国产精品18久久久久久麻辣 | 国产人成高清在线视频99最全资源 | 色婷婷综合中文久久一本 | 樱花草在线播放免费中文 | 东京热无码av男人的天堂 | 欧美 日韩 亚洲 在线 | 狂野欧美性猛交免费视频 | 亚洲综合无码久久精品综合 | 久久久久久久女国产乱让韩 | 国产一精品一av一免费 | 欧美高清在线精品一区 | 亚洲欧洲中文日韩av乱码 | 久久久无码中文字幕久... | 日韩亚洲欧美中文高清在线 | 日韩av无码中文无码电影 | 在线欧美精品一区二区三区 | 东北女人啪啪对白 | av无码电影一区二区三区 | 精品久久8x国产免费观看 | 人妻少妇精品久久 | 中文字幕无码av波多野吉衣 | 一个人看的www免费视频在线观看 | 精品国产成人一区二区三区 | 亚洲人成影院在线观看 | 国产精品理论片在线观看 | 日日鲁鲁鲁夜夜爽爽狠狠 | 强开小婷嫩苞又嫩又紧视频 | 中文字幕 亚洲精品 第1页 | 亚洲精品综合五月久久小说 | 中文字幕无码人妻少妇免费 | 性欧美大战久久久久久久 | 亚洲精品一区三区三区在线观看 | 中文字幕乱码人妻无码久久 | 亚洲色偷偷偷综合网 | 亚洲精品中文字幕久久久久 | 国产亚洲精品久久久久久 | 亚洲午夜无码久久 | 夫妻免费无码v看片 | 国产午夜无码视频在线观看 | 天堂а√在线中文在线 | 久久99精品国产.久久久久 | 麻花豆传媒剧国产免费mv在线 | 日韩精品a片一区二区三区妖精 | 日韩精品一区二区av在线 | 亚洲 激情 小说 另类 欧美 | 伊人色综合久久天天小片 | 18禁止看的免费污网站 | 成人无码视频免费播放 | 天海翼激烈高潮到腰振不止 | 欧美日韩亚洲国产精品 | 国产偷国产偷精品高清尤物 | 成人欧美一区二区三区 | 欧美日韩一区二区免费视频 | 欧美精品一区二区精品久久 | 99久久人妻精品免费二区 | 人妻与老人中文字幕 | 欧美黑人乱大交 | 精品乱子伦一区二区三区 | 国产精品-区区久久久狼 | 狠狠综合久久久久综合网 | 麻豆av传媒蜜桃天美传媒 | аⅴ资源天堂资源库在线 | 高潮毛片无遮挡高清免费 | 国产成人一区二区三区在线观看 | 欧美日韩久久久精品a片 | 香蕉久久久久久av成人 | 国产成人一区二区三区在线观看 | 天天躁夜夜躁狠狠是什么心态 | 国产成人无码av片在线观看不卡 | 国产69精品久久久久app下载 | 动漫av网站免费观看 | 超碰97人人射妻 | 国产精品沙发午睡系列 | 少妇一晚三次一区二区三区 | 国产深夜福利视频在线 | 在线精品亚洲一区二区 | 国产精品久久久久久亚洲毛片 | 波多野结衣一区二区三区av免费 | v一区无码内射国产 | 露脸叫床粗话东北少妇 | 日本一区二区三区免费播放 | 精品国产精品久久一区免费式 | 国产97色在线 | 免 | 国内老熟妇对白xxxxhd | 精品一二三区久久aaa片 | 久久国产精品偷任你爽任你 | 国产精品久久国产三级国 | 大屁股大乳丰满人妻 | 国产精品18久久久久久麻辣 | 扒开双腿吃奶呻吟做受视频 | 国产日产欧产精品精品app | 欧美自拍另类欧美综合图片区 | 人人妻人人澡人人爽人人精品 | 国产激情综合五月久久 | 亚洲精品欧美二区三区中文字幕 | 日本乱人伦片中文三区 | 麻豆av传媒蜜桃天美传媒 | 天堂亚洲2017在线观看 | 在线观看欧美一区二区三区 | 亚洲精品国产精品乱码不卡 | 日日碰狠狠躁久久躁蜜桃 | 欧美人妻一区二区三区 | 人妻尝试又大又粗久久 | 亚洲色成人中文字幕网站 | 人妻aⅴ无码一区二区三区 | 亚洲国产精华液网站w | 亚洲天堂2017无码中文 | 2019nv天堂香蕉在线观看 | 亚洲综合无码久久精品综合 | 一本一道久久综合久久 | 免费人成在线视频无码 | 国产在线一区二区三区四区五区 | 无码精品国产va在线观看dvd | 国产办公室秘书无码精品99 | 成熟妇人a片免费看网站 | 日日碰狠狠丁香久燥 | 国内揄拍国内精品少妇国语 | 全黄性性激高免费视频 | 久久久久成人片免费观看蜜芽 | 丰满护士巨好爽好大乳 | 噜噜噜亚洲色成人网站 | 婷婷六月久久综合丁香 | 色综合天天综合狠狠爱 | 久久无码专区国产精品s | 2019nv天堂香蕉在线观看 | 成人精品一区二区三区中文字幕 | 国产口爆吞精在线视频 | 九九久久精品国产免费看小说 | 亚洲 a v无 码免 费 成 人 a v | 少妇无码av无码专区在线观看 | 超碰97人人做人人爱少妇 | 久久综合九色综合欧美狠狠 | 人人妻人人澡人人爽欧美精品 | 国产精品-区区久久久狼 | 人妻人人添人妻人人爱 | 综合网日日天干夜夜久久 | 日韩少妇内射免费播放 | 永久免费精品精品永久-夜色 | 久久www免费人成人片 | 亚洲中文字幕乱码av波多ji | 99久久久国产精品无码免费 | 国产成人精品一区二区在线小狼 | 自拍偷自拍亚洲精品被多人伦好爽 | 黑森林福利视频导航 | 欧美 日韩 亚洲 在线 | 疯狂三人交性欧美 | 国产精品久久久久7777 | 免费人成在线视频无码 | 人人爽人人澡人人高潮 | 欧美乱妇无乱码大黄a片 | 亚洲综合另类小说色区 | 老头边吃奶边弄进去呻吟 | 国产偷自视频区视频 | 亚洲乱码日产精品bd | 巨爆乳无码视频在线观看 | 3d动漫精品啪啪一区二区中 | 国产一区二区三区四区五区加勒比 | 无遮无挡爽爽免费视频 | 亚洲人亚洲人成电影网站色 | 午夜福利试看120秒体验区 | 亚洲中文字幕乱码av波多ji | 婷婷五月综合激情中文字幕 | 久久久久国色av免费观看性色 | 天天爽夜夜爽夜夜爽 | www成人国产高清内射 | 无码乱肉视频免费大全合集 | 99久久亚洲精品无码毛片 | 亚洲国产精品美女久久久久 | 午夜精品久久久久久久久 | 欧美人与禽zoz0性伦交 | 美女黄网站人色视频免费国产 | 亚洲人交乣女bbw | 亚洲人成网站免费播放 | 理论片87福利理论电影 | 久久精品国产99精品亚洲 | 一个人看的视频www在线 | 国产精品igao视频网 | 中文精品无码中文字幕无码专区 | 精品熟女少妇av免费观看 | 国产亚洲精品久久久久久 | 国产精品igao视频网 | 55夜色66夜色国产精品视频 | 国产精品香蕉在线观看 | 亚洲国产精品久久久久久 | 99久久精品无码一区二区毛片 | 亚洲高清偷拍一区二区三区 | 亚洲中文字幕乱码av波多ji | 亚洲国产综合无码一区 | a在线观看免费网站大全 | 免费无码午夜福利片69 | 国产精品亚洲а∨无码播放麻豆 | 国产成人综合在线女婷五月99播放 | 国产av无码专区亚洲a∨毛片 | 精品少妇爆乳无码av无码专区 | 日韩亚洲欧美精品综合 | 99久久精品无码一区二区毛片 | 无码av免费一区二区三区试看 | 国产三级精品三级男人的天堂 | 精品一二三区久久aaa片 | 免费人成在线视频无码 | 日本熟妇人妻xxxxx人hd | 欧美乱妇无乱码大黄a片 | 亚洲熟妇自偷自拍另类 | 亚洲国产精品久久久久久 | 国产在线无码精品电影网 | 久久久久久久女国产乱让韩 | 国产精品-区区久久久狼 | 99久久人妻精品免费一区 | 人妻无码αv中文字幕久久琪琪布 | 精品偷拍一区二区三区在线看 | 国产无遮挡又黄又爽又色 | 天天摸天天透天天添 | 无套内谢的新婚少妇国语播放 | 四虎永久在线精品免费网址 | 免费播放一区二区三区 | 国产精品自产拍在线观看 | 亚洲一区二区三区偷拍女厕 | 欧美亚洲国产一区二区三区 | 午夜精品一区二区三区的区别 | 国产av久久久久精东av | 亚洲精品午夜无码电影网 | 成人精品一区二区三区中文字幕 | 图片区 小说区 区 亚洲五月 | 亚洲综合久久一区二区 | 奇米影视7777久久精品人人爽 | 性色av无码免费一区二区三区 | 亚洲熟悉妇女xxx妇女av | 国产网红无码精品视频 | 18无码粉嫩小泬无套在线观看 | 麻豆国产人妻欲求不满 | 国产农村乱对白刺激视频 | аⅴ资源天堂资源库在线 | 少妇无码一区二区二三区 | 日韩欧美成人免费观看 | 小泽玛莉亚一区二区视频在线 | 免费观看又污又黄的网站 | 无码任你躁久久久久久久 | 2019午夜福利不卡片在线 | 青春草在线视频免费观看 | 乱人伦人妻中文字幕无码久久网 | 日本一卡2卡3卡四卡精品网站 | 日本乱偷人妻中文字幕 | 国产麻豆精品一区二区三区v视界 | 亚洲 激情 小说 另类 欧美 | 特大黑人娇小亚洲女 | 色婷婷综合激情综在线播放 | 日本大乳高潮视频在线观看 | 色情久久久av熟女人妻网站 | 网友自拍区视频精品 | 激情内射亚州一区二区三区爱妻 | 色一情一乱一伦一区二区三欧美 | 久久久无码中文字幕久... | 亚洲国产精华液网站w | 欧美熟妇另类久久久久久不卡 | 爆乳一区二区三区无码 | 亚洲日本va午夜在线电影 | 亚洲区欧美区综合区自拍区 | 夜夜夜高潮夜夜爽夜夜爰爰 | 欧美 丝袜 自拍 制服 另类 | 中文精品无码中文字幕无码专区 | 亚洲综合在线一区二区三区 | 免费看少妇作爱视频 | 成 人影片 免费观看 | 精品熟女少妇av免费观看 | 精品亚洲成av人在线观看 | 国产午夜手机精彩视频 | а√天堂www在线天堂小说 | 丝袜 中出 制服 人妻 美腿 | 精品偷拍一区二区三区在线看 | 在线观看国产午夜福利片 | 粗大的内捧猛烈进出视频 | 九九热爱视频精品 | 国产三级久久久精品麻豆三级 | 色诱久久久久综合网ywww | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 久久综合九色综合欧美狠狠 | 少妇被粗大的猛进出69影院 | 色综合视频一区二区三区 | 精品久久久久久亚洲精品 | 人妻aⅴ无码一区二区三区 | 久激情内射婷内射蜜桃人妖 | 亚洲精品午夜国产va久久成人 | 爱做久久久久久 | 2020久久香蕉国产线看观看 | 欧美日韩一区二区三区自拍 | 国产亚洲视频中文字幕97精品 | 欧美日本免费一区二区三区 | av无码电影一区二区三区 | 亚洲日韩中文字幕在线播放 | 亚洲色无码一区二区三区 | 天天av天天av天天透 | 久久人人爽人人爽人人片ⅴ | 久久精品国产一区二区三区 | 久久人妻内射无码一区三区 | 国产高清av在线播放 | 久久无码专区国产精品s | 影音先锋中文字幕无码 | 久久久成人毛片无码 | 性欧美疯狂xxxxbbbb | 欧美成人免费全部网站 | 少妇性荡欲午夜性开放视频剧场 | 午夜熟女插插xx免费视频 | 激情内射亚州一区二区三区爱妻 | 国产婷婷色一区二区三区在线 | 内射欧美老妇wbb | 免费国产成人高清在线观看网站 | 性欧美疯狂xxxxbbbb | 男女性色大片免费网站 | 亚洲第一无码av无码专区 | 国产人妻精品一区二区三区不卡 | 真人与拘做受免费视频一 | 麻豆蜜桃av蜜臀av色欲av | 欧美日韩一区二区三区自拍 | 久久精品国产一区二区三区肥胖 | 国产精品久久久久9999小说 | 无码av免费一区二区三区试看 | 亚洲国产日韩a在线播放 | 亲嘴扒胸摸屁股激烈网站 | 性生交大片免费看l | 樱花草在线播放免费中文 | 色一情一乱一伦一区二区三欧美 | 免费观看黄网站 | 午夜无码人妻av大片色欲 | 国产成人精品必看 | 免费无码av一区二区 | 蜜桃无码一区二区三区 | 5858s亚洲色大成网站www | 国产莉萝无码av在线播放 | 久久精品中文闷骚内射 | 国产区女主播在线观看 | 亚洲国产精品无码一区二区三区 | 婷婷色婷婷开心五月四房播播 | 欧美日韩视频无码一区二区三 | 亚洲人成网站免费播放 | 麻豆av传媒蜜桃天美传媒 | 久久久精品成人免费观看 | 18黄暴禁片在线观看 | 久久精品国产99精品亚洲 | 精品人妻人人做人人爽夜夜爽 | 宝宝好涨水快流出来免费视频 | 天堂亚洲2017在线观看 | 国产av人人夜夜澡人人爽麻豆 | 麻豆国产丝袜白领秘书在线观看 | 亚洲色偷偷男人的天堂 | 精品欧美一区二区三区久久久 | 少妇无码吹潮 | 国产精品内射视频免费 | 国产激情艳情在线看视频 | 又大又硬又爽免费视频 | 影音先锋中文字幕无码 | 成人精品视频一区二区三区尤物 | 美女极度色诱视频国产 | 亚洲精品www久久久 | 亚洲中文字幕在线无码一区二区 | 亚洲自偷自拍另类第1页 | 国产av无码专区亚洲awww | www一区二区www免费 | 中文字幕无码乱人伦 | 色婷婷久久一区二区三区麻豆 | 亚洲日韩一区二区 | 精品无码国产自产拍在线观看蜜 | 国产电影无码午夜在线播放 | 亚洲精品中文字幕乱码 | 色老头在线一区二区三区 | 人人爽人人澡人人高潮 | 女人和拘做爰正片视频 | 波多野结衣av在线观看 | 亚洲狠狠婷婷综合久久 | 成熟女人特级毛片www免费 | 色婷婷久久一区二区三区麻豆 | 3d动漫精品啪啪一区二区中 | 国内揄拍国内精品少妇国语 | 国产亚洲精品精品国产亚洲综合 | 欧美性猛交xxxx富婆 | 正在播放老肥熟妇露脸 | 大肉大捧一进一出好爽视频 | 国产一区二区三区四区五区加勒比 | 性史性农村dvd毛片 | 国产两女互慰高潮视频在线观看 | 亚洲第一网站男人都懂 | 97久久精品无码一区二区 | 无码国产色欲xxxxx视频 | 成人毛片一区二区 | 人人妻人人澡人人爽欧美一区九九 | 国产精品久久久午夜夜伦鲁鲁 | 日韩精品无码一区二区中文字幕 | 少妇性俱乐部纵欲狂欢电影 | 久久精品一区二区三区四区 | 国产婷婷色一区二区三区在线 | 久久久久久国产精品无码下载 | 欧美猛少妇色xxxxx | 亚洲熟女一区二区三区 | 亚洲综合无码一区二区三区 | 精品久久久无码人妻字幂 | 欧美性生交xxxxx久久久 | 暴力强奷在线播放无码 | 精品国产乱码久久久久乱码 | 国内少妇偷人精品视频 | 亚洲乱亚洲乱妇50p | 午夜无码区在线观看 | 亚洲天堂2017无码 | 国产福利视频一区二区 | 欧美亚洲国产一区二区三区 | 亚洲精品www久久久 | 国产九九九九九九九a片 | 水蜜桃亚洲一二三四在线 | 国产精品无码永久免费888 | 99视频精品全部免费免费观看 | 18黄暴禁片在线观看 | 久久熟妇人妻午夜寂寞影院 | 三上悠亚人妻中文字幕在线 | 自拍偷自拍亚洲精品被多人伦好爽 | 欧美黑人乱大交 | 国产精品理论片在线观看 | 国产精品二区一区二区aⅴ污介绍 | 伊人久久大香线焦av综合影院 | 亚洲综合另类小说色区 | 强伦人妻一区二区三区视频18 | 少妇高潮喷潮久久久影院 | 日韩精品一区二区av在线 | 成人免费视频视频在线观看 免费 | 久久精品视频在线看15 | 国产精品永久免费视频 | 亚洲熟妇自偷自拍另类 | 亚洲春色在线视频 | 国产高潮视频在线观看 | 妺妺窝人体色www婷婷 | 亚洲精品国产品国语在线观看 | 国产成人精品久久亚洲高清不卡 | 毛片内射-百度 | 丰满少妇人妻久久久久久 | 久久视频在线观看精品 | 鲁大师影院在线观看 | 国精产品一区二区三区 | 日日摸日日碰夜夜爽av | 国产成人无码区免费内射一片色欲 | 午夜不卡av免费 一本久久a久久精品vr综合 | 无码午夜成人1000部免费视频 | 给我免费的视频在线观看 | 亚洲成av人影院在线观看 | 亚洲一区二区三区含羞草 | 日韩精品无码免费一区二区三区 | 国产成人综合在线女婷五月99播放 | 精品国偷自产在线视频 | 国产亚洲精品久久久久久久久动漫 | 女人被男人躁得好爽免费视频 | 丰满人妻精品国产99aⅴ |