午夜视频免费看_日韩三级电影网站_国产精品久久一级_亚洲一级在线播放_人妻体内射精一区二区三区_91夜夜揉人人捏人人添红杏_91福利在线导航_国产又粗又猛又黄又爽无遮挡_欧美日韩一区在线播放_中文字幕一区二区三区四区不卡 _日日夜夜精品视频免费观看_欧美韩日一区二区三区

主頁 > 知識庫 > 基于go interface{}==nil 的幾種坑及原理分析

基于go interface{}==nil 的幾種坑及原理分析

熱門標簽:涿州代理外呼系統 excel地圖標注分布數據 壽光微信地圖標注 阿克蘇地圖標注 評價高的400電話辦理 外呼系統顯本地手機號 外呼系統用什么卡 電話機器人軟件免費 百度地圖標注后傳給手機

本文是Go比較有名的一個坑,在以前面試的時候也被問過,為什么想起來寫這個?

因為我們線上就真實出現過這個坑,寫給不了解的人在使用 if err != nil 的時候提高警惕。

Go語言的interface{}在使用過程中有一個特別坑的特性,當你比較一個interface{}類型的值是否是nil的時候,這是需要特別注意避免的問題。

先來看看一個demo:

package main
import "fmt"
type ErrorImpl struct{}
func (e *ErrorImpl) Error() string {
   return ""
}
var ei *ErrorImpl
var e error
func ErrorImplFun() error {
   return ei
}
func main() {
   f := ErrorImplFun()
   fmt.Println(f == nil)
}

輸出:

false

為什么不是true?

想要理解這個問題,首先需要理解interface{}變量的本質。在Go語言中,一個interface{}類型的變量包含了2個指針,一個指針指向值的在編譯時確定的類型,另外一個指針指向實際的值。

// InterfaceStructure 定義了一個interface{}的內部結構
type InterfaceStructure struct {
  pt uintptr // 到值類型的指針
  pv uintptr // 到值內容的指針
}
// asInterfaceStructure 將一個interface{}轉換為InterfaceStructure
func asInterfaceStructure(i interface{}) InterfaceStructure {
  return *(*InterfaceStructure)(unsafe.Pointer(i))
}
func main() {
  var i1, i2 interface{}
  var v1 int = 23
  var v2 int = 23
  i1 = v1
  i2 = v2
  fmt.Printf("sizeof interface{} = %d\n", unsafe.Sizeof(i1))
  fmt.Printf("i1 %v %+v\n", i1, asInterfaceStructure(i1))
  fmt.Printf("i2 %v %+v\n", i2, asInterfaceStructure(i2))
  var nilInterface interface{}
  var str *string
  fmt.Printf("nil interface = %+v\n", asInterfaceStructure(nilInterface))
  fmt.Printf("nil string = %+v\n", asInterfaceStructure(str))
  fmt.Printf("nil = %+v\n", asInterfaceStructure(nil))
}

輸出:

sizeof interface{} = 16

i1 23 {pt:4812032 pv:825741246928}

i2 23 {pt:4812032 pv:825741246936}

nil interface = {pt:0 pv:0}

nil string = {pt:4802400 pv:0}

nil = {pt:0 pv:0}

當我們將一個具體類型的值賦值給一個interface{}類型的變量的時候,就同時把類型和值都賦值給了interface{}里的兩個指針。如果這個具體類型的值是nil的話,interface{}變量依然會存儲對應的類型指針和值指針。

如何解決?

方法一

返回的結果進行非nil檢查,然后再賦值給interface{}變量

type ErrorImpl struct{}
func (e *ErrorImpl) Error() string {
   return ""
}
var ei *ErrorImpl
var e error
func ErrorImplFun() error {
   if ei == nil {
      return nil
   }
   return ei
}
func main() {
   f := ErrorImplFun()
   fmt.Println(f == nil)
}

輸出:

true

方法二

返回具體實現的類型而不是interface{}

package main
import "fmt"
type ErrorImpl struct{}
func (e *ErrorImpl) Error() string {
   return ""
}
var ei *ErrorImpl
var e error
func ErrorImplFun() *ErrorImpl {
   return ei
}
func main() {
   f := ErrorImplFun()
   fmt.Println(f == nil)
}

輸出:

true

解決由于第三方包帶來的坑

由于有的error是第三方包返回的,又自己不想改第三方包,只好接收處理的時候想辦法。

方法一

利用interface{}原理

 is:=*(*InterfaceStructure)(unsafe.Pointer(i))
 if is.pt==0  is.pv==0 {
     //is nil do something
 }

將底層指向值和指向值的類型的指針打印出來如果都是0,表示是nil

方法二

利用斷言,斷言出來具體類型再判斷非空

type ErrorImpl struct{}
func (e ErrorImpl) Error() string {
   return "demo"
}
var ei *ErrorImpl
var e error
func ErrorImplFun() error {
   //ei = ErrorImpl{}
   return ei
}
func main() {
   f := ErrorImplFun()
   //當然error實現類型較多的話使用  
 //switch case方式斷言更清晰
   res, ok := f.(*ErrorImpl)
   fmt.Printf("ok:%v,f:%v,res:%v", 
   ok, f == nil, res == nil)
}

輸出:

ok:true,f:false,res:true

方法三

利用反射

type ErrorImpl struct{}
func (e ErrorImpl) Error() string {
   return "demo"
}
var ei *ErrorImpl
var e error
func ErrorImplFun() error {
   //ei = ErrorImpl{}
   return ei
}
func main() {
   f := ErrorImplFun()
   rv := reflect.ValueOf(f)
   fmt.Printf("%v", rv.IsNil())
}

輸出:

true

注意⚠:

斷言和反射性能不是特別好,如果不得已再使用,控制使用有助于提升程序性能。

由于函數接收類型導致的panic:

type ErrorImpl struct{}
func (e ErrorImpl) Error() string {
   return "demo"
}
var ei *ErrorImpl
var e error
func ErrorImplFun() error {
   return ei
}
func main() {
   f := ErrorImplFun()
   fmt.Printf(f.Error())
}

輸出:

panic: value method main.ErrorImpl.Error called using nil *ErrorImpl pointer

解決:

func (e *ErrorImpl) Error() string {
   return "demo"
}

輸出:

demo

可以發現將接收類型變成指針類型就可以了。

以上就是 nil 相關的坑,希望大家可以牢記,如果 ”幸運“ 的遇到了,可以想到這些可能性。

補充:go 語言 interface{} 的易錯點

如果說 goroutine 和 channel 是 go 語言并發的兩大基石,那 interface 就是 go 語言類型抽象的關鍵。

在實際項目中,幾乎所有的數據結構最底層都是接口類型。

說起 C++ 語言,我們立即能想到是三個名詞:封裝、繼承、多態。go 語言雖然沒有嚴格意義上的對象,但通過 interface,可以說是實現了多態性。(由以組合結構體實現了封裝、繼承的特性)

package main
type animal interface {
    Move()
}
type bird struct{}
func (self *bird) Move() {
    println("bird move")
}
type beast struct{}
func (self *beast) Move() {
    println("beast move")
}
func animalMove(v animal) {
    v.Move()
}
func main() {
    var a *bird
    var b *beast
    animalMove(a) // bird move
    animalMove(b) // beast move
}

go 語言中支持將 method、struct、struct 中成員定義為 interface 類型,使用 struct 舉一個簡單的栗子

使用 go 語言的 interface 特性,就能實現多態性,進行泛型編程。

二,interface 原理

如果沒有充分了解 interface 的本質,就直接使用,那最終肯定會踩到很深的坑,要用就先要了解,先來看看 interface 源碼

 type eface struct {
     _type *_type
     data  unsafe.Pointer
 }  
 type _type struct {
     size       uintptr // type size
     ptrdata    uintptr // size of memory prefix holding all pointers
     hash       uint32  // hash of type; avoids computation in hash tables
     tflag      tflag   // extra type information flags
     align      uint8   // alignment of variable with this type
     fieldalign uint8   // alignment of struct field with this type
     kind       uint8   // enumeration for C
     alg        *typeAlg  // algorithm table
     gcdata    *byte    // garbage collection data
     str       nameOff  // string form
     ptrToThis typeOff  // type for pointer to this type, may be zero
 }

可以看到 interface 變量之所以可以接收任何類型變量,是因為其本質是一個對象,并記錄其類型和數據塊的指針。(其實 interface 的源碼還包含函數結構和內存分布,由于不是本文重點,有興趣的同學可以自行了解)

三,interface 判空的坑

對于一個空對象,我們往往通過 if v == nil 的條件語句判斷其是否為空,但在代碼中充斥著 interface 類型的情況下,很多時候判空都并不是我們想要的結果(其實了解或聰明的同學從上述 interface 的本質是對象已經知道我想要說的是什么)

package main 
 type animal interface {
     Move()
 } 
 type bird struct{} 
 func (self *bird) Move() {
     println("bird move")
 } 
 type beast struct{} 
 func (self *beast) Move() {
     println("beast move")
 } 
 func animalMove(v animal) {
     if v == nil {
         println("nil animal")
     }
     v.Move()
 } 
 func main() {
     var a *bird   // nil
     var b *beast  // nil
     animalMove(a) // bird move
     animalMove(b) // beast move
 }

還是剛才的栗子,其實在 go 語言中 var a *bird 這種寫法,a 只是聲明了其類型,但并沒有申請一塊空間,所以這時候 a 本質還是指向空指針,但我們在 aminalMove 函數進行判空是失敗的,并且下面的 v.Move() 的調用也是成功的,本質的原因就是因為 interface 是一個對象,在進行函數調用的時候,就會將 bird 類型的空指針進行隱式轉換,轉換成實例的 interface animal 對象,所以這時候 v 其實并不是空,而是其 data 變量指向了空。

這時候看著執行都正常,那什么情況下坑才會絆倒我們呢?只需要加一段代碼

package main 
 type animal interface {
     Move()
 } 
 type bird struct {
    name string
 } 
 func (self *bird) Move() {
     println("bird move %s", self.name) // panic
 } 
 type beast struct {
     name string
 } 
 func (self *beast) Move() {
     println("beast move %s", self.name) // panic
 } 
 func animalMove(v animal) {
     if v == nil {
         println("nil animal")
     }
     v.Move()
 } 
 func main() {
     var a *bird   // nil
     var b *beast  // nil
     animalMove(a) // panic
     animalMove(b) // panic
 }

在代碼中,我們給派生類添加 name 變量,并在函數的實現中進行調用,就會發生 panic,這時候的 self 其實是 nil 指針。所以這里坑就出來了。

有些人覺得這類錯誤謹慎一些還是可以避免的,那是因為我們是正向思維去代入接口,但如果反向編程就容易造成很難發現的 bug

package main 
 type animal interface {
     Move()
 } 
 type bird struct {
     name string
 } 
 func (self *bird) Move() {
     println("bird move %s", self.name)
 } 
 type beast struct {
     name string
 } 
 func (self *beast) Move() {
     println("beast move %s", self.name)
 } 
 func animalMove(v animal) {
     if v == nil {
         println("nil animal")
     }
     v.Move()
 } 
 func getBirdAnimal(name string) *bird {
     if name != "" {
         return bird{name: name}
     }
     return nil
 } 
 func main() {
     var a animal
     var b animal
     a = getBirdAnimal("big bird")
     b = getBirdAnimal("") // return interface{data:nil}
     animalMove(a) // bird move big bird
     animalMove(b) // panic
 }

這里我們看到通過函數返回實例類型指針,當返回 nil 時,因為接收的變量為接口類型,所以進行了隱性轉換再次導致了 panic(這類反向轉換很難發現)。

那我們如何處理上述這類問題呢。我這邊整理了三個點

1,充分了解 interface 原理,使用過程中需要謹慎小心

2,謹慎使用泛型編程,接收變量使用接口類型,也需要保證接口返回為接口類型,而不應該是實例類型

3,判空是使用反射 typeOf 和 valueOf 轉換成實例對象后再進行判空

您可能感興趣的文章:
  • Golang中interface{}轉為數組的操作
  • 淺談Golang 嵌套 interface 的賦值問題
  • Golang 實現interface類型轉string類型
  • 解決golang 反射interface{}做零值判斷的一個重大坑
  • golang interface判斷為空nil的實現代碼
  • 詳解Golang語言中的interface
  • 使用go的interface案例實現多態范式操作
  • go 類型轉換方式(interface 類型的轉換)

標簽:重慶 銅川 梅河口 吐魯番 蘭州 汕頭 欽州 雞西

巨人網絡通訊聲明:本文標題《基于go interface{}==nil 的幾種坑及原理分析》,本文關鍵詞  基于,interface,nil,的,幾種,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《基于go interface{}==nil 的幾種坑及原理分析》相關的同類信息!
  • 本頁收集關于基于go interface{}==nil 的幾種坑及原理分析的相關信息資訊供網民參考!
  • 推薦文章
    99在线国产| 亚洲一区二区欧美| 一区二区在线免费观看视频| 欧美黑人性猛交| 国产不卡视频在线播放| 国产乱色国产精品免费视频| 日韩欧美色视频| 国产日韩av在线| 偷拍日韩校园综合在线| 91久久精品国产91性色69| 女人天堂av手机在线| 久久亚洲国产精品一区二区| 精品国产一区二区三区在线| 在线视频国产一区| 国产精品suv一区二区| 天天做天天爱天天高潮| 欧美精品在线免费播放| 黄色精品一区二区| 久色成人在线| 国产精品酒店视频| 欧美二区三区| 亚洲女在线观看| 国产精品久久久久婷婷| 一级视频在线播放| 超碰97在线资源站| 久久涩涩网站| 欧美成人免费小视频| 性感美女久久精品| 99re成人在线| japanese国产在线观看| 一级黄色在线播放| 亚洲巨乳在线观看| 在线成人中文字幕| 成人一区在线观看| 九九热在线免费观看| 中文字幕黄色片| 国产免费黄色网址| 2022国产精品| 亚洲国产天堂网精品网站| 久久66热re国产| 国产精品白浆一区二小说| 免费日韩视频在线观看| 国产精品自拍小视频| 6080日韩午夜伦伦午夜伦| 国产一区亚洲一区| 久久久久久久久久久97| 日本黄大片在线观看| 久久久视频精品| 欧美视频中文字幕在线| 国产一区二区成人久久免费影院| 欧美性x x x| 精品国产一区二区三区无码| 国产成人精品视频在线观看| 在线播放欧美女士性生活| 岛国精品在线播放| 久久久久精彩视频| 欧类av怡春院| 中文字幕无码精品亚洲资源网久久| 欧美在线视频一区| 亚洲黄色在线观看| 中文字幕一区二区三区av| 五月婷婷六月丁香| 欧美激情精品久久| 亚洲成a人在线观看| 91网址在线播放| 91精品久久久久久久久久另类 | 欧美自拍视频在线| 欧美色综合网站| 91丨九色丨蝌蚪富婆spa| 波多野结衣一区二区在线| 亚洲一区二区三区四区精品| 中文字幕一区二区三区四区五区| 欧美与欧洲交xxxx免费观看| 亚洲高清福利视频| 亚洲国产cao| av午夜一区麻豆| 五月婷婷狠狠干| 四虎永久在线精品| 国产呦小j女精品视频| 欧美专区一二三| 国产精品观看在线亚洲人成网| 亚洲精品mp4| 在线观看欧美日本| 一区二区中文字幕在线| 久久aⅴ国产欧美74aaa| 中文字幕一区2区3区| 在线观看天堂av| 国产精品一区二区在线免费观看| 97超碰在线视| 亚洲wwwav| 中文字幕欧美人与畜| 精品视频一区在线视频| 欧美专区日韩专区| 99热99精品| 国产成人精品三级麻豆| 久久中文欧美| 国产三级aaa| 国产精品无码一区二区三区| 手机免费av片| 男女爽爽爽视频| 国产九九九九九| 欧美日韩在线一二三| 成人欧美一区二区三区黑人免费| www.日韩视频| 亚洲人成电影网站色xx| 日韩精品在线视频| 精品少妇一区二区三区视频免付费 | 中文字幕在线2018| 国产三级av片| www.欧美色| 免费无码国产精品| 一级片在线免费播放| 精品久久久久久久久久久久久久久久久久 | 亚洲色图丝袜美腿| 亚洲欧美aⅴ...| 色偷偷成人一区二区三区91 | 亚洲欧美日韩偷拍| 久久久国产一级片| 国产91av视频| 一级黄色大毛片| 亚洲三级中文字幕| 99麻豆久久久国产精品免费| 中文字幕免费观看一区| www久久久久| 亚洲欧美日韩国产手机在线| 成人欧美一区二区三区| 亚洲欧洲99久久| 一区二区三区四区激情| 亚洲成人免费电影| 欧美精品久久一区| 欧美成人福利视频| 久久精品视频一| 国产xxx69麻豆国语对白| 国产美女精品免费电影| 国产综合色一区二区三区| 亚洲精品日韩在线观看| 青青青青草视频| 午夜免费高清视频| 91日韩视频在线观看| 天堂va欧美va亚洲va老司机| 成年人午夜久久久| 神马午夜精品91| 日韩精品手机在线| 韩国av免费在线| 国产成人午夜视频| 亚洲欧洲日韩av| 欧美三级在线播放| 日韩欧美激情在线| 久久99国产综合精品女同| 国产精品视频久| 亚洲国产日韩欧美| 欧美大尺度做爰床戏| 免费看污黄网站在线观看| 91插插插插插插| 久久综合加勒比| 免费精品一区二区| 麻豆精品视频在线观看免费| 久久精品免视看| 欧美性一级生活| 精品精品国产国产自在线| 成人美女免费网站视频| 老司机午夜网站| 在线免费观看av的网站| 强制高潮抽搐sm调教高h| 草草视频在线播放| 91免费在线看| 欧美精品粉嫩高潮一区二区| 久久亚洲国产精品| 国产免费高清一区| 亚洲国产精品久久久久爰色欲| 精品人体无码一区二区三区| 午夜精品久久久久久久96蜜桃| 91丨九色丨国产丨porny| 欧美一区二区日韩| 欧美在线性爱视频 | 亚洲大尺度视频| 中文字幕免费不卡在线| 亚洲精品久久久久久久久| 91亚洲精品一区二区| 国产精品va无码一区二区| 亚洲精品久久久久久国| av在线综合网| 日韩精品中文字幕在线| 久久草.com| 色婷婷在线影院| 麻豆精品国产传媒mv男同| 精品国产一区二区三区久久影院 | 国产精品美女免费视频| 毛片毛片毛片毛片毛| 国产综合视频在线| 欧美日韩国产色站一区二区三区| 92裸体在线视频网站| 色婷婷免费视频| 成人av免费观看| 日韩的一区二区| 午夜精品短视频| 免费看日本黄色片| 成人深夜在线观看| 欧美va亚洲va国产综合| 国产精品电影久久久久电影网| 婷婷免费在线观看| 国产综合视频在线| 欧美日本在线观看| 精品视频一区在线| 艳妇荡乳欲伦69影片| 不卡视频一二三| 正在播放亚洲1区| 成人区一区二区| 久草视频在线免费| 在线观看亚洲a| 国产精品美女久久久久久免费| 韩国av中国字幕| 久久精品国产亚洲a| 亚洲欧美激情一区| 亚洲啊啊啊啊啊| 中文av免费观看| 欧美性猛片xxxx免费看久爱| 精品乱色一区二区中文字幕| 精品午夜福利视频| 亚洲欧美日韩中文字幕一区二区三区 | 欧美色图12p| 久久99欧美| 丁香六月婷婷综合| 欧美日韩免费在线观看| 狠狠色噜噜狠狠狠狠色吗综合| 永久久久久久久| 一区二区三区 在线观看视频| 91免费精品视频| 国产亚洲女人久久久久毛片| 国产成人小视频在线观看| 99国产精品免费视频| 久久久精品tv| 久久久水蜜桃| 国产美女免费看| 国产一区二区三区在线观看网站 | 91久久久一线二线三线品牌| 久久久久久久久久91| 午夜精品123| 黄色污污在线观看| 蜜臀久久久久久久| 欧美亚洲激情视频| 国产精品第一页在线观看| 欧美性色黄大片| 国产精品视频黄色| 久久中文娱乐网| 国产日韩欧美亚洲一区| 精品国产亚洲一区二区麻豆| 日韩视频免费在线观看| 久久精品—区二区三区舞蹈| 欧美日韩国产精品一区二区不卡中文 | 热re99久久精品国产66热| 在线看的片片片免费| 7777精品伊人久久久大香线蕉最新版| 精品视频一区二区在线| 国产亚洲欧美日韩日本| 色一情一乱一伦一区二区三区 | 99久久99久久精品免费观看| 午夜在线电影亚洲一区| 高清在线视频日韩欧美| 国产第一页浮力| 日韩欧美福利视频| 久久人人爽人人人人片| 伊人一区二区三区| 欧美久久在线观看| 国产jizzjizz一区二区| 成人观看高清在线观看免费| 久久综合加勒比| 欧美xxxx18国产| 国产精品成人av久久| 福利精品视频在线| 欧美精品123| 99热这里精品| 亚洲在线免费视频| 国产乱码字幕精品高清av | 91精品天堂| 视频一区在线播放| 久久久国产综合精品女国产盗摄| 国产一区二区三区黄| 91福利国产成人精品照片| 国产成人精品av在线观| 国产素人在线观看| 亚洲网址你懂得| 99在线精品视频| 国产调教在线观看| 免费h精品视频在线播放| 91精品在线观看入口| 日韩经典一区二区| 亚洲妇熟xx妇色黄蜜桃| 色久欧美在线视频观看| 国产精品99久久久久久似苏梦涵 | 亚洲成人网av| 粉嫩av一区二区夜夜嗨| 又大又硬又爽免费视频| 亚洲成人网在线| 久草视频在线资源站| 亚洲aa中文字幕| 日韩一区二区麻豆国产| 国产日产欧产精品推荐色| www.国产一区二区| 蜜桃视频无码区在线观看| 国产精品v欧美精品∨日韩| 51午夜精品国产| 99久久久久久久| 亚洲在线欧美| 亚洲精品在线观看视频| 亚洲色成人www永久网站| 国产 日韩 欧美在线| 亚洲视频在线免费看| 日韩电影一区二区三区| 欧美 日韩 国产 成人 在线观看| 欧美高清视频免费观看| 亚洲图片有声小说| 日本亚洲免费观看| 少妇一级淫免费放| 欧美日韩在线观看一区| 久久99这里只有精品| 黄色一级在线视频| 日韩电影中文字幕av| 午夜老司机福利| 777av视频| 日韩精品中文字幕有码专区| 日韩欧美在线观看免费| 亚洲电影一二三区| 亚洲精品水蜜桃| 毛片aaaaaa| 99在线首页视频| 黑人狂躁日本妞一区二区三区| 久久久www成人免费毛片| 91久久精品国产91久久| 精品福利在线看| 国产精品久久久久久久久久久久久久久久久久| 一级二级三级欧美| 亚洲国产精品系列| 国产高清不卡一区二区| 亚洲天堂伊人网| 国产精品视频色| 欧美视频中文在线看| 亚洲AV无码乱码国产精品牛牛| 91淫黄看大片| 国内精品久久久久久| 中文字幕一区二区三区不卡| 中文字幕亚洲精品一区| 97视频久久久| 日韩中文字幕在线观看| 国产欧美一区二区三区在线看蜜臀 | av网站中文字幕| 亚洲第一区中文99精品| 精品深夜av无码一区二区老年| 欧美日韩一区二区三| 亚洲另类激情图| 99久久国产免费看| 国产在线综合网| 亚洲综合日韩欧美| 成人精品一区二区三区电影免费| 国产成人精品免高潮在线观看| 亚洲性猛交xxxx乱大交| 91视频国产一区| 福利视频第一区| 色婷婷av一区二区三区之红樱桃| 国产高清视频网站| 国产日本欧美在线观看| 疯狂做受xxxx高潮欧美日本| 亚洲爱情岛论坛永久| 日日碰狠狠丁香久燥| 久久久久久久一| 亚洲成人久久影院| 曰批又黄又爽免费视频| 日韩国产一级片| 色综合中文字幕| 性欧美videos| 国产免费毛卡片| 日韩av电影国产| 777久久久精品| 全国精品久久少妇| 欧美第一页在线观看| 天堂8在线天堂资源bt| 欧美老女人性生活| 国产蜜臀97一区二区三区| 97精品人妻一区二区三区在线| 亚洲精品久久视频| 日本精品久久久久| 亚洲第一成人网站| 日产精品一线二线三线芒果| 精品久久久久av影院| 久久精品视频免费| 在线观看日韩一区二区| 黄色高清无遮挡| 欧美一区二区视频在线观看2022| 无码人妻精品一区二区50| 成人免费黄色av| 一区二区三区四区五区精品| 欧美激情乱人伦| 在线观看日产精品| 亚洲色图都市小说| 波多野结衣视频免费观看| 亚欧在线免费观看| 日韩精品欧美专区| 国产精品一区二区在线| 精品99999| 欧美日韩精品在线播放| 国产98色在线|日韩| 亚洲一线在线观看| 无套内谢大学处破女www小说| 亚洲国产精品综合| 国产精品一区二区三区毛片淫片 | 欧美乱大交做爰xxxⅹ小说| 五十路熟女丰满大屁股| 一本一本a久久| 国产精品yjizz| 成人激情视频免费在线|