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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

C++ 多继承和虚继承的内存布局

發布時間:2025/6/15 c/c++ 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C++ 多继承和虚继承的内存布局 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

原文鏈接:https://www.oschina.net/translate/cpp-virtual-inheritance

警告. 本文有點技術難度,需要讀者了解C++和一些匯編語言知識。

在本文中,我們解釋由gcc編譯器實現多繼承和虛繼承的對象的布局。雖然在理想的C++程序中不需要知道這些編譯器內部細節,但不幸的是多重繼承(特別是虛擬繼承)的實現方式有各種各樣的不太明確的結論(尤其是,關于向下轉型指針,使用指向指針的指針,還有虛擬基類的構造方法的調用命令)。 如果你了解多重繼承是如何實現的,你就能預見到這些結論并運用到你的代碼中。而且,如果你關心性能,理解虛擬繼承的開銷也是非常有用的。最后,這很有趣。 :-)

多重繼承

首先我們考慮一個(非虛擬)多重繼承的相對簡單的例子。看看下面的C++類層次結構。

class Top { public: int a; }; class Left : public Top { public: int b; }; class Right : public Top { public: int c; }; class Bottom : public Left, public Right { public: int d; };使用UML圖,我們可以把這個層次結構表示為:

注意Top被繼承了兩次(在Eiffel語言中這被稱作重復繼承)。這意味著類型Bottom的一個實例bottom將有兩個叫做a的元素(分別為bottom.Left::a和bottom.Right::a)。

Left、Right和Bottom在內存中是如何布局的?讓我們先看一個簡單的例子。Left和Right擁有如下的結構:

Left
Top::a
Left::b
? ?Right
????Top::a
????Right::c

請注意第一個屬性是從Top繼承下來的。這意味著在下面兩條語句后

Left* left = new Left(); Top* top = left;left和top指向了同一地址,我們可以把Left Object當成Top Object來使用(很明顯,Right與此也類似)。那Buttom呢?GCC的建議如下:Bottom????????
Left::Top::a
Left::b
Right::Top::a
Right::c
Bottom::d

如果我們提升Bottom指針,會發生什么事呢?Bottom* bottom = new Bottom(); Left* left = bottom;

這段代碼工作正常。我們可以把一個Bottom的對象當作一個Left對象來使用,因為兩個類的內存部局是一樣的。那么,如果將其提升為Right呢?會發生什么事?

Right* right = bottom;為了執行這條語句,我們需要判斷指針的值以便讓它指向Bottom中對應的段。Bottom
?
?Left::Top::a
?Left::b
right?Right::Top::a
?Right::c
?Bottom::d
經過這一步,我們可以像操作正常Right對象一樣使用right指針訪問bottom。雖然,bottom與right現在指向兩個不同的內存地址。出于完整性的緣故,思考一下執行下面這條語句時會出現什么狀況。Top* top = bottom;是的,什么也沒有。這條語句是有歧義的:編譯器將會報錯。error: `Top' is an ambiguous base of `Bottom'兩種方式可以避免這樣的歧義Top* topL = (Left*) bottom; Top* topR = (Right*) bottom;執行這兩條語句后,topL和left會指向同樣的地址,topR和right也會指向同樣的地址。

虛擬繼承

為了避免重復繼承Top,我們必須虛擬繼承Top:

class Top { public: int a; }; class Left : virtual public Top { public: int b; }; class Right : virtual public Top { public: int c; }; class Bottom : public Left, public Right { public: int d; };這就得到了如下的層次結構(也許是你一開始就想得到的)

雖然從程序員的角度看,這也許更加的明顯和簡便,但從編譯器的角度看,這就變得非常的復雜。重新考慮下Bottom的布局,其中的一個(也許沒有)可能是:

Bottom

Left::Top::a

Left::b

Right::c

Bottom::d

這個布局的優點是,布局的第一部分與Left的布局重疊了,這樣我們就可以很容易的通過一個Left指針訪問 Bottom類。可是我們怎么處理

Right* right = bottom;

我們將哪個地址賦給right呢? 經過這個賦值,如果right是指向一個普通的Right對象,我們應該就能使用?right了。但是這是不可能的!Right本身的內存布局是完全不同的,這樣我們就無法像訪問一個"真正的"Right對象一樣,來訪問升級的Bottom對象。而且,也沒有其它(簡單的)可以正常運作的Bottom布局。

解決辦法是復雜的。我們先給出解決方案,之后再來解釋它。

你應該注意到了這個圖中的兩個地方。第一,字段的順序是完全不同的(事實上,差不多是相反的)。第二,有幾個vptr指針。這些屬性是由編譯器根據需要自動插入的(使用虛擬繼承,或者使用虛擬函數的時候)。編譯器也在構造器中插入了代碼,來初始化這些指針。

vptr (virtual pointers)指向一個 “虛擬表”。類的每個虛擬基類都有一個vptr指針。要想知道這個虛擬表 (vtable)是怎樣運用的,看看下面的C++ 代碼。

Bottom* bottom = new Bottom(); Left* left = bottom; int p = left->a;

第二個賦值使left指向了bottom的所在地址(即,它指向了Bottom對象的“頂部”)。我們想想最后一條賦值語句的編譯情況(稍微簡化了):

movl left, %eax # %eax = left movl (%eax), %eax # %eax = left.vptr.Left movl (%eax), %eax # %eax = virtual base offset addl left, %eax # %eax = left + virtual base offset movl (%eax), %eax # %eax = left.a movl %eax, p # p = left.a

用語言來描述的話,就是我們用left指向虛擬表,并且由它獲得了“虛擬基類偏移”(vbase)。這個偏移之后就加到了left,然后left就用來指向Bottom對象的Top部分。從這張圖你可以看到Left的虛擬基類偏移是20;如果假設Bottom中的所有字段都是4個字節,那么給left加上20字節將會確實指向a字段。

經過這個設置,我們就可以同樣的方法訪問Right部分。按這樣

Bottom* bottom = new Bottom(); Right* right = bottom; int p = right->a;

之后right將指向Bottom對象的合適的部位:

Bottom
?
?vptr.Left
?Left::b
right?vptr.Right
?Right::c
?Bottom::d
?Top::a

對top的賦值現在可以編譯成像前面Left同樣的方式。唯一的不同就是現在的vptr是指向了虛擬表的不同部位:取得的虛擬表偏移是12,這完全正確(確定!)。我們可以將其圖示概括:

當然,這個例子的目的就是要像訪問真正Right對象一樣訪問升級的Bottom對象。因此,我們必須也要給Right(和Left)布局引入vptrs:

現在我們就可以通過一個Right指針,一點也不費事的訪問Bottom對象了。不過,這是付出了相當大的代價:我們要引入虛擬表,類需要擴展一個或更多個虛擬指針,對一個對象的一個簡單屬性的查詢現在需要兩次間接的通過虛擬表(即使編譯器某種程度上可以減小這個代價)。

向下轉換

如我們所見,將一個派生類的指針轉換為一個父類的指針(或者說,向上轉換)可能涉及到給指針增添一個偏移。有人可能會想了,這樣向下轉換(反方向的)就可以簡單的通過減去同樣的偏移來實現。確實,對非虛擬繼承來說是這樣的。可是,虛擬繼承(毫不奇怪的!)帶來了另一種復雜性。

假設我們像下面這個類這樣擴展繼承層次。class AnotherBottom : public Left, public Right { public: int e; int f; };

繼承層次現在看起來是這樣

現在考慮一下下面的代碼。

Bottom* bottom1 = new Bottom(); AnotherBottom* bottom2 = new AnotherBottom(); Top* top1 = bottom1; Top* top2 = bottom2; Left* left = static_cast<Left*>(top1);

下圖顯示了Bottom和AnotherBottom的布局,而且在最后一個賦值后面顯示了指向top的指針。

Bottom
?vptr.Left
?Left::b
?vptr.Right
?Right::c
?Bottom::d
top1?Top::a
AnotherBottom
?vptr.Left
?Left::b
?vptr.Right
?Right::c
?AnotherBottom::e
?AnotherBottom::f
top2?Top::a

現在考慮一下怎么去實現從top1到left的靜態轉換,同時要想到,我們并不知道top1是否指向一個Bottom類型的對象,或者是指向一個AnotherBottom類型的對象。所以這辦不到!這個重要的偏移依賴于top1運行時的類型(Bottom則20,AnotherBottom則24)。編譯器將報錯:

error: cannot convert from base `Top' to derived type `Left' via virtual base `Top'

因為我們需要運行時的信息,所以應該用一個動態轉換來替代實現:

Left* left = dynamic_cast<Left*>(top1);

可是,編譯器仍然不滿意:

error: cannot dynamic_cast `top' (of type `class Top*') to type `class Left*' (source type is not polymorphic)

(注:polymorphic多態的)

問題在于,動態轉換(轉換中使用到typeid)需要top1所指向對象的運行時類型信息。但是,如果你看看這張圖,你就會發現,在top1指向的位置,我們僅僅只有一個integer (a)而已。編譯器沒有包含指向Top的虛擬指針,因為它不認為這是必需的。為了強制編譯器包含進這個vptr指針,我們可以給Top增加一個虛擬的析構器:

class Top { public: virtual ~Top() {} int a; };

這個修改需要指向Top的vptr指針。Bottom的新布局是

(當然類似的其它類也有一個新的指向Top的vptr指針)。現在編譯器為動態轉換插進了一個庫調用:

left = __dynamic_cast(top1, typeinfo_for_Top, typeinfo_for_Left, -1);

這個函數__dynamic_cast定義在stdc++庫中(相應的頭文件是cxxabi.h);參數為Top的類型信息,Left和Bottom(通過vptr.Top),這個轉換可以執行。 (參數 -1 標示出Left和Top之間的關系現在還是未知)。更多詳細資料,請參考tinfo.cc?的具體實現 。

總結語

最后,我們來看看一些沒了結的部分。

指針的指針

這里出現了一點令人迷惑的問題,但是如果你仔細思考下一的話它其實很簡單。我們來看一個例子。假設使用上一節用到的類層次結構(向下類型轉換).在前面的小節我們已經看到了它的結果:

Bottom* b = new Bottom(); Right* r = b;(在將b的值賦給r之前,需要將它調整8個字節,從而讓它指向Bottom對象的Right部分).因此,我們可以合法地將一個Bottom* 賦值給一個Right*的指針。但是Bottom**和Right**又會怎樣呢??
Bottom** bb = &b; Right** rr = bb;

編譯器會接受這樣的形式嗎?我們快速測試一下,編譯器會報錯:

error: invalid conversion from `Bottom**' to `Right**'為什么呢?假設編譯器可以接受從bb到rr的賦值。我們可以只管的看到結果如下:?

因此,bb和rr都指向b,并且b和r指向Bottom對象的正確的章節。現在考慮當我們賦值給*rr時會發生什么(注意*rr的類型時Right*,因此這個賦值是有效的):

*rr = b;

這樣的賦值和上面的賦值給r在根本上是一致的。因此,編譯器會用同樣的方式實現它!特別地,它會在賦值給*rr之前將b的值調整8個字節。辦事*rr指向的是b!我們再一次圖示化這個結果:

只要我們通過*rr來訪問Bottom對象這都是正確的,但是只要我們通過b自身來訪問它,所有的內存引用都會有8個字節的偏移---明顯這是個不理想的情況。

因此,總的來說,及時*a 和*b通過一些子類型相關,**aa和**bb卻是不相關的。

虛擬基類的構造函數

編譯器必須確保對象的所有虛指針都被正確的初始化。特別是,編譯器確保了類的所有虛基類都被調用,并且只被調用一次。如果你不顯示地調用虛擬超類(不管他們在繼承層次結構中的距離有多遠),編譯器都會自動地插入調用他們缺省構造函數。

這樣也會引來一些不可以預期的錯誤。以上面給出的類層次結構作為示例,并添加上構造函數的部分:

class Top { public:Top() { a = -1; } Top(int _a) { a = _a; } int a; }; class Left : public Top { public:Left() { b = -2; }Left(int _a, int _b) : Top(_a) { b = _b; } int b; }; class Right : public Top { public:Right() { c = -3; }Right(int _a, int _c) : Top(_a) { c = _c; } int c; }; class Bottom : public Left, public Right { public:Bottom() { d = -4; } Bottom(int _a, int _b, int _c, int _d) : Left(_a, _b), Right(_a, _c) { d = _d; } int d; };(首先考慮非虛擬的情況。)你會期望下面的代碼段輸出什么:Bottom bottom(1,2,3,4); printf("%d %d %d %d %d\n", bottom.Left::a, bottom.Right::a, bottom.b, bottom.c, bottom.d);你可能會希望得到下面的結果,并且也得到了下面的結果:1 1 2 3 4然而,現在考慮虛擬的情況(我們虛擬繼承自Top類)。如果我們僅僅做那樣一個改變,并再一次運行程序,我們會得到:-1 -1 2 3 4為什么呢?通過跟蹤構造函數的執行,會發現:Top::Top() Left::Left(1,2) Right::Right(1,3) Bottom::Bottom(1,2,3,4)就像上面解釋的一樣,編譯器在Bottom類執行其他構造函數之前中插入調用了缺省構造函數。 然后,當Left去調用它自身的超類的構造函數時(Top),我們會發現Top已經被初始化了因此構造函數不會被調用。

為了避免這種情況,你應該顯示的調用虛基類的構造函數:

Bottom(int _a, int _b, int _c, int _d): Top(_a), Left(_a,_b), Right(_a,_c) { d = _d; }

指針等價

再假設同樣的(虛擬)類繼承等級,你希望這樣就打印“相等”嗎?

Bottom* b = new Bottom(); Right* r = b; if(r == b)printf("Equal!\n");

記住這兩個地址并不實際相等(r偏移了8個字節)。但是這應該對用戶完全透明;因此,實際上編譯器在r與b比較之前,就給r減去了8個字節;這樣,這兩個地址就被認為是相等的了。

轉換為void類型的指針

最后,我們來思考一下當將一個對象轉換為void類型的指針時會發生什么事情。編譯器必須保證一個指針轉換為void類型的指針時指向對象的頂部。使用虛函數表這很容易實現。你可能已經想到了指向top域的偏移量是什么。它是虛函數指針到對象頂部的偏移量。因此,轉化為void類型的指針操作可以使用查詢虛函數表的方式來實現。然而一定要確保使用動態類型轉換,如下:

dynamic_cast<void*>(b);

參考文獻

[1]?CodeSourcery, 特別是C++ ABI Summary,?Itanium C++ ABI(不考慮名字,這些文檔是在平臺無關的上下文中引用的;特別低,structure of the vtables給出了虛函數表的詳細信息)。

libstdc++實現的動態類型轉化,和同RTTI和命名調整定義在?tinfo.cc中。

[2]libstdc++?網站,特別是?C++ Standard Library API這一章節。

[3]Jan Gray 寫的C++: Under the Hood?

[4]Bruce Eckel的Thinking in C++(第二卷) 第9章"多重繼承"。 作者允許下載這本書download.


總結

以上是生活随笔為你收集整理的C++ 多继承和虚继承的内存布局的全部內容,希望文章能夠幫你解決所遇到的問題。

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

五月婷婷在线播放 | 一区二区视频在线观看免费 | 激情电影影院 | 久久综合九色综合久久久精品综合 | 亚洲综合成人av | 亚洲区另类春色综合小说 | 久草免费在线观看 | www久 | 婷婷激情五月综合 | 欧美日韩在线第一页 | 亚洲激情综合网 | 欧美日韩国产一区二区三区在线观看 | 久久无码精品一区二区三区 | 久久久久久久久久影院 | 干干干操操操 | 久操伊人 | 亚洲精品高清在线 | 欧美最新大片在线看 | 免费久久网 | 国产精品毛片一区视频 | 久久久久一区二区三区 | 色网站在线 | 久久视频免费在线观看 | 日韩视频一区二区在线观看 | 四虎成人精品 | 91大神电影| 国内精品久久久久久久 | 久久艹中文字幕 | 一区二区三区久久 | 99欧美精品 | 亚洲精品中文字幕视频 | 99精品免费在线观看 | 狠狠狠狠狠狠天天爱 | 2017狠狠干 | 婷婷资源站 | 精品国产乱码久久久久久1区2匹 | 久久污视频 | 久久久福利影院 | 国产精品99久久久久久大便 | 天堂av网在线| 日韩精品一区二区在线观看 | 丁香激情五月婷婷 | 久久天堂精品视频 | 一区三区视频在线观看 | 色五月成人 | 免费a网址 | 国产女人18毛片水真多18精品 | 91人人干 | 日本中文在线观看 | a在线观看免费视频 | 精品国产免费人成在线观看 | 亚洲欧洲美洲av | 91视频链接 | 亚洲国产一区av | 手机在线视频福利 | 色婷婷综合久久久 | 99c视频高清免费观看 | 91一区二区在线 | 国产精品毛片一区视频 | 欧美最新大片在线看 | 亚洲日本在线一区 | 国产综合久久 | 久久精品国产美女 | 色综合天天狠天天透天天伊人 | 亚洲另类在线视频 | 日本三级香港三级人妇99 | 成人中文字幕在线 | 婷婷播播网 | 91精品国产三级a在线观看 | 91av观看| 欧美激情在线网站 | 亚洲三级网 | 97精品欧美91久久久久久 | 国产老太婆免费交性大片 | 91在线视频免费观看 | 干干日日 | 成人在线你懂得 | 偷拍久久久| 日韩免费看的电影 | 91精品国产91 | 五月天激情开心 | 2023av| 99精品国产一区二区三区不卡 | 黄av免费在线观看 | 少妇视频一区 | 国产黄色片免费 | 国产亚洲成av人片在线观看桃 | 国产精品视频免费在线观看 | 亚洲资源网 | 久久不见久久见免费影院 | 国产精品激情 | 干狠狠 | 一区二区三区四区五区在线视频 | 国产色影院 | 91香蕉视频黄色 | 日韩免费在线 | 免费a视频| 国产成人久久精品 | 在线观看的黄色 | 超碰97中文 | 欧美成人中文字幕 | 国产馆在线播放 | 国产xxxx做受性欧美88 | a视频免费在线观看 | 中文字幕第 | 久久久精品日本 | 国产亚洲欧美在线视频 | 色av色av色av | 婷婷亚洲综合 | 精品国产91亚洲一区二区三区www | 涩涩伊人| 四虎永久精品在线 | 国产一区二区三区在线免费观看 | av丝袜在线 | 国产破处在线视频 | 久草影视在线观看 | 91精品国产一区二区在线观看 | 一区二区三区电影 | 国产精品久久久久久影院 | 国产精品色视频 | 黄色精品国产 | 国产成人香蕉 | 日本久久久久久久久久久 | 久久久免费观看 | 亚洲精品色婷婷 | 亚洲日本在线一区 | 成年人视频在线观看免费 | 欧美性成人 | 亚洲女裸体| 国产高清在线不卡 | 久久国产精品成人免费浪潮 | 天天插天天狠天天透 | 国产精品久久久久久久av电影 | 国产精品乱码高清在线看 | 91精品国产高清自在线观看 | 蜜臀久久99精品久久久无需会员 | 青青草国产精品视频 | 免费合欢视频成人app | 欧美大片在线看免费观看 | 在线观看爱爱视频 | 日韩精品一区二区三区在线播放 | 一区二区视频在线看 | 久久国产精品一区二区三区四区 | 激情文学丁香 | 麻豆视频免费在线 | 麻豆视频www | 国产999久久久 | 手机av片| 不卡日韩av | 在线观看av黄色 | 精品国产一区二区三区久久影院 | 在线性视频日韩欧美 | 国产午夜精品在线 | 国产成年免费视频 | 久久人人97超碰国产公开结果 | 99久久成人 | 精品资源在线 | 久久国内精品视频 | 日本久久中文 | 亚洲天堂网在线播放 | 日韩高清在线看 | 天天操天天爽天天干 | 97在线精品国自产拍中文 | 成年人看片 | 免费看的黄色录像 | 久久激情综合网 | 国产亚洲精品久久19p | 西西4444www大胆无视频 | 精品久久久久久久久久久久久久久久 | 久久久久亚洲精品男人的天堂 | 一区二区三区精品久久久 | 日韩中文字幕免费视频 | 在线亚洲观看 | 国产成人精品电影久久久 | 国产一区二区精品在线 | 国产私拍在线 | 久久午夜免费观看 | 中文字幕 国产 一区 | 菠萝菠萝在线精品视频 | 亚洲情感电影大片 | 国产人免费人成免费视频 | 国产一级一级国产 | 色姑娘综合网 | 99国产精品一区二区 | 中国一级片在线观看 | 日韩精品中文字幕有码 | 国产黄色成人 | 99精品在线视频观看 | 久久久久久蜜桃一区二区 | 久久国色夜色精品国产 | 99久久精品国产免费看不卡 | 亚洲精品在线视频网站 | 97国产视频 | 久久亚洲成人网 | a在线观看视频 | av中文字幕在线观看网站 | 成人网中文字幕 | 91九色视频在线观看 | 激情深爱.com | 激情五月婷婷 | 成人av免费| 夜夜躁狠狠躁日日躁 | 久久久久久久久久网 | 黄网站污| 久久99精品国产91久久来源 | 久久精品国产一区二区 | av动图| 免费视频 三区 | 啪啪资源 | 中文字幕欧美日韩va免费视频 | 久久精品国产亚洲精品2020 | 国内三级在线观看 | 日本公妇色中文字幕 | 日韩中文字幕在线不卡 | 二区视频在线观看 | 久久久国产电影 | 精品在线播放视频 | 亚洲综合色丁香婷婷六月图片 | 在线看片91 | 日日操网站 | 黄色影院在线观看 | 91热在线 | 97视频免费在线观看 | 国产小视频在线 | 免费在线国产 | 久久婷综合 | 日韩在线国产 | 在线 国产 日韩 | 在线看v片成人 | 国产一区二区高清视频 | 黄污在线看 | 91av社区| 在线成人中文字幕 | 天天亚洲综合 | 精品久久国产 | 天天爱天天射 | 亚洲特级片 | 国产精品精品国产 | 又黄又爽又湿又无遮挡的在线视频 | 国产亚洲一区二区在线观看 | 久久久九九 | 久久精品久久精品久久 | 成人三级视频 | 亚洲欧洲成人精品av97 | 91激情视频在线观看 | 免费性网站 | 亚洲国产精品电影 | 最近更新好看的中文字幕 | 高清av免费一区中文字幕 | 国产999精品久久久 免费a网站 | 免费日韩视频 | 国产又粗又猛又色 | 免费手机黄色网址 | 综合久久网| 在线电影中文字幕 | 韩国在线一区二区 | 日韩手机视频 | 国产伦精品一区二区三区四区视频 | 精品一区二区免费视频 | 国产91在线播放 | 国产一二三精品 | 美女精品 | 免费一级片观看 | 亚洲成av人片在线观看香蕉 | 九九热在线视频免费观看 | 免费能看的av | 97综合在线 | 少妇高潮冒白浆 | 国产视频观看 | 久久激情影院 | 国产精品九九视频 | 成年人看片网站 | 国精产品一二三线999 | 久久午夜电影网 | 91精品人成在线观看 | 日韩免费av片 | h网站免费在线观看 | 在线观影网站 | 久久精品国产v日韩v亚洲 | 成人免费看电影 | 国产视频一区二区在线观看 | 国产一级片网站 | 婷婷激情五月 | 一区二区三区视频网站 | 日韩有码在线观看视频 | 国产一级免费av | 久久99精品久久久久婷婷 | 黄a网站| 日本动漫做毛片一区二区 | 天天爽夜夜爽精品视频婷婷 | 在线黄色免费 | 国产精品 中文在线 | 国产黄 | 久久久.com | 欧美日韩视频网站 | 91成人精品一区在线播放 | 日韩av片免费在线观看 | 中文字幕av专区 | 中文字幕中文字幕在线一区 | 激情综合国产 | 日韩精品免费一区 | 欧美日韩亚洲第一页 | 亚洲成 人精品 | 国产精品第二十页 | 欧美一区二区三区免费观看 | 日韩在线欧美在线 | 久草视频中文在线 | 久久亚洲婷婷 | 在线免费观看羞羞视频 | 亚洲免费精品一区二区 | 国产人成看黄久久久久久久久 | 国产视频在线观看一区 | 国产超碰在线观看 | 91丨九色丨蝌蚪丨老版 | 在线看小早川怜子av | 丁香六月av | 999毛片 | 亚洲国产精彩中文乱码av | 天天射综合网站 | 在线视频一区二区 | 免费视频一二三区 | 综合网在线视频 | 久久婷婷一区二区三区 | 片网站 | 亚洲另类视频在线 | 国产精品1区2区3区在线观看 | 日本久久久久久科技有限公司 | 欧美精品乱码久久久久 | 成人黄色在线看 | 国产精品一区二区在线观看免费 | 天天干夜夜操视频 | 日韩乱色精品一区二区 | 亚洲国产播放 | 久久综合中文字幕 | 日韩免费在线观看视频 | 国产97在线观看 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 久久精品五月 | 亚洲高清在线视频 | 人人爽久久久噜噜噜电影 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 91免费观看网站 | 免费网站色 | 97精品国自产拍在线观看 | 久草网站 | 欧洲精品亚洲精品 | 国产一级精品视频 | 亚洲男男gaygay无套同网址 | 狠狠干夜夜操天天爽 | 91成品人影院 | 曰本免费av| 四虎成人网 | 999热线在线观看 | 久草在线视频网 | av在线一二三区 | 色视频网站免费观看 | 中文字幕在线观看免费 | 91刺激视频 | 怡红院av | 国产特级毛片aaaaaaa高清 | 中文字幕在线看视频国产中文版 | 国内揄拍国内精品 | 在线看污网站 | 亚洲国产无 | 91丨porny丨九色 | 一本一道波多野毛片中文在线 | 中文字幕中文字幕在线中文字幕三区 | www.av在线.com | 国产精品久久久久一区二区 | 久草在线这里只有精品 | 国产麻豆视频在线观看 | 国产自制av | 久久精品人人做人人综合老师 | 激情开心 | 激情综合五月天 | 蜜桃视频成人在线观看 | 九九九热精品免费视频观看网站 | 黄色毛片在线观看 | 九九视频免费在线观看 | 国产成人久久精品77777综合 | 瑞典xxxx性hd极品 | jizzjizzjizz亚洲 | 国产精品mv | 九九九九九国产 | 久草在线视频精品 | zzijzzij亚洲日本少妇熟睡 | 在线久久| 狠狠色2019综合网 | 国内精品久久天天躁人人爽 | 一区二区三区四区在线 | 亚州av成人 | 国产男女无遮挡猛进猛出在线观看 | 国产资源中文字幕 | 久久福利国产 | 国产婷婷色 | 黄色一区二区在线观看 | 亚洲国产精品久久久久 | www.天天操 | 亚洲一级电影 | 日韩久久精品一区二区 | 国产一级淫片免费看 | 国产中文字幕视频 | 欧美一级日韩免费不卡 | 视频国产一区二区三区 | 麻豆94tv免费版 | 91亚洲视频在线观看 | 久久人人爽av | 日本三级在线观看中文字 | 中文字幕高清 | 中文字幕文字幕一区二区 | 亚洲免费精品视频 | 97精品国产97久久久久久免费 | 六月丁香婷婷网 | 国产一区二区手机在线观看 | 在线视频99 | 最新黄色av网址 | 欧美成人aa | 精品视频免费在线 | a久久久久 | 91片在线观看 | wwwww.国产 | 婷婷在线网 | 精品久久一二三区 | 99久热精品 | 国产精品毛片一区 | 国产91粉嫩白浆在线观看 | 中文字幕高清av | 欧美日韩精品综合 | 欧美久久久久久久 | 狠狠干综合| 亚洲va欧洲va国产va不卡 | 美女黄频网站 | www99久久 | 亚洲精品国产视频 | 日韩手机视频 | www.亚洲精品在线 | 日韩精品一区二区三区免费观看视频 | 国产日韩欧美中文 | 久久久午夜精品理论片中文字幕 | 国产亚洲欧美精品久久久久久 | 99热在| 激情偷乱人伦小说视频在线观看 | 欧美一级片在线 | 91资源在线播放 | 五月婷香蕉久色在线看 | 色99中文字幕 | 一区二区不卡视频在线观看 | 日韩在线一级 | 天堂在线一区二区 | 91福利在线观看 | 岛国av在线不卡 | 国产成人精品一区二区三区在线观看 | 国产超碰97 | 久草免费色站 | 精品一二三区视频 | 色网av| 欧美成人xxxx| 亚洲欧美精品在线 | 国产成人333kkk | 欧洲av不卡| 激情av综合 | 成人免费视频播放 | 手机看片99 | 日韩在线观看一区二区 | av一区二区三区在线播放 | av一级片 | 久久久国产日韩 | av片子在线观看 | av一区二区三区在线 | 成人在线一区二区 | 国产精品免费成人 | 日韩av在线免费看 | 国语自产偷拍精品视频偷 | 1024在线看片 | 欧美日韩精品在线 | 亚洲成av人影片在线观看 | 中文字幕在线观看视频网站 | 又黄又爽的免费高潮视频 | 中文字幕av最新更新 | 黄色成人在线观看 | 国产一级片在线播放 | 欧美极品久久 | 91av在线免费播放 | 激情视频免费观看 | 免费观看的av | 国产在线自 | 亚洲在线视频免费 | 欧美日韩精品在线播放 | 久久久久久久久久久久99 | 日韩三级视频在线看 | 91综合色| 超碰在线最新网址 | 精品久久久久久亚洲综合网 | 国产精品亚洲片夜色在线 | 9色在线视频 | 黄色毛片电影 | 丁香视频 | 国产91综合一区在线观看 | 91丨porny丨九色 | 岛国精品一区二区 | 国产日韩在线一区 | 国产 视频 高清 免费 | 国产一区二区手机在线观看 | 91亚洲在线观看 | 天天色天天上天天操 | 成人毛片久久 | 欧美一级片在线 | 五月婷婷激情综合网 | 国产亚洲午夜高清国产拍精品 | 狠狠干在线 | 黄色小网站在线观看 | 亚洲片在线观看 | 国产精品网站一区二区三区 | 国产大陆亚洲精品国产 | 亚洲国产影院av久久久久 | 欧美精品久久人人躁人人爽 | 成人一区二区三区在线观看 | 夜夜视频资源 | 国内精品久久久久久久97牛牛 | 美女网站色免费 | 成人免费 在线播放 | 日韩欧美在线高清 | 日韩欧美在线中文字幕 | 国产在线观看不卡 | 亚洲精品久久久久久久蜜桃 | 在线观看av黄色 | 91| 成人在线你懂得 | 国产麻豆精品一区二区 | www色片| 亚洲一二三区精品 | 一区电影| 国产日韩精品欧美 | av电影免费在线播放 | 色婷婷丁香 | 一区二区三区免费在线播放 | 5月丁香婷婷综合 | 在线观看日韩一区 | 国产中文字幕网 | 久久人人做 | 91在线观 | 午夜精选视频 | 99久久免费看| 特级西西444www大精品视频免费看 | 国产理论片在线观看 | 九九九热 | 成人动漫一区二区 | 91激情视频在线播放 | 丁香久久婷婷 | 日韩欧美视频一区 | 欧美日韩国产精品一区 | 最近中文字幕视频完整版 | 欧美精品一区二区在线播放 | 最新国产视频 | 中文字幕国产一区 | 免费在线黄网 | 国产99免费 | 天天射天天干天天爽 | av在线小说 | 四虎影视成人精品国库在线观看 | 激情文学丁香 | 国产区在线看 | 色婷婷亚洲精品 | 免费视频三区 | 日av免费 | 亚洲国产日韩一区 | 中文字幕在线看片 | 国产精品免费不 | 亚洲成人国产精品 | av中文字幕在线看 | 日韩免费一级电影 | 日韩中文字幕视频在线 | 久久国产精品成人免费浪潮 | av电影在线观看 | 人成在线免费视频 | 精品久久久久久亚洲 | av观看在线观看 | 日韩精品免费在线观看视频 | 在线不卡a | 看片一区二区三区 | 高清日韩一区二区 | 免费影视大全推荐 | 国产专区视频在线 | 午夜精品久久久久久中宇69 | 日韩精品一区二区三区免费观看视频 | 国产视频资源在线观看 | 99久久er热在这里只有精品15 | av电影免费在线看 | 欧美伦理电影一区二区 | 久草在线费播放视频 | 97视频资源 | 天天草网站 | 中文字幕日韩精品有码视频 | 天天摸天天舔 | 色综合中文字幕 | 麻豆国产视频下载 | 五月天久久久 | 国产成人精品在线观看 | 亚洲精品视 | 国产精品久久电影观看 | 九色精品免费永久在线 | 欧美日韩在线观看视频 | 激情丁香久久 | 日韩大片在线播放 | 成人h电影| 色偷偷中文字幕 | 久久午夜剧场 | 亚洲日本va午夜在线影院 | 亚洲人成人99网站 | 久草在线视频网 | 久久成人免费 | 一区二区在线不卡 | 久久高清免费视频 | www.91国产| 久久夜色精品国产欧美乱极品 | 97超级碰碰 | 国产高清中文字幕 | 亚洲第一av在线 | 999成人国产 | 蜜臀av.com| 国产免费久久精品 | 日韩视频一区二区三区在线播放免费观看 | 亚洲激情在线观看 | 亚洲综合在线播放 | 手机成人av在线 | 91精品在线观看入口 | 夜夜躁狠狠躁日日躁 | 国产91全国探花系列在线播放 | 四虎国产 | 中文字幕日韩高清 | 亚洲色图 校园春色 | 久久久在线视频 | 成人一级片免费看 | 国产丝袜制服在线 | 亚a在线| www在线观看国产 | 欧洲视频一区 | 久精品视频 | 91黄视频在线观看 | 国产日韩视频在线观看 | 欧美日韩国产一区二区在线观看 | 97在线观看视频国产 | 91精品在线免费观看视频 | 日本韩国精品一区二区在线观看 | 国产成人精品一区二区三区免费 | 91精品啪啪 | 97品白浆高清久久久久久 | 4hu视频 | 国产1区2区3区精品美女 | av在线播放国产 | 成人在线视频免费观看 | 91av视频免费观看 | 久久精品艹 | 久久精品网站视频 | 99国产精品视频免费观看一公开 | 中文字幕一区二区三区在线视频 | 在线韩国电影免费观影完整版 | 色婷婷视频网 | 超碰在97 | 国产综合小视频 | 日韩特黄一级欧美毛片特黄 | 99精品久久99久久久久 | 手机色站| 91精品网站在线观看 | 男女精品久久 | 国产免费成人av | 中文字幕在线观看第二页 | 91免费国产在线观看 | 欧美日韩亚洲国产一区 | 黄色av网站在线观看 | 国产精品美女久久久 | 国产97在线视频 | 成年人免费观看国产 | 国产精品一区二区吃奶在线观看 | av大全在线免费观看 | 91香蕉视频色版 | 国产精品久久久久久久av电影 | 亚洲视频在线看 | 天天操天天是 | 久久伊99综合婷婷久久伊 | 操操综合 | 免费在线观看91 | 8x成人免费视频 | 97免费视频在线 | 日p视频在线观看 | 一区二区不卡在线观看 | 看黄色91 | 欧美在线a视频 | 免费在线观看a v | 国产精品a级 | 91少妇精拍在线播放 | 亚洲视频久久久 | 黄色a视频免费 | 天天射天天干天天爽 | 色五月色开心色婷婷色丁香 | 91在线观| 日韩在线色 | 亚洲精品xx| 六月婷婷久香在线视频 | 日韩久久久| 国产精品日韩高清 | 人人爽人人搞 | 亚洲成人家庭影院 | 狠狠88综合久久久久综合网 | 中文字幕高清有码 | 高清不卡毛片 | 国产精品自拍av | 日韩精品中文字幕在线播放 | 成人av电影在线观看 | 国产精品手机在线观看 | 日韩成人免费在线电影 | 96香蕉视频 | 欧美午夜精品久久久久 | 中文字幕 国产 一区 | 国产韩国日本高清视频 | 国产精品一区二区免费 | 国模吧一区 | 免费久久99精品国产婷婷六月 | 99久久国产免费,99久久国产免费大片 | 亚洲黄色大片 | 欧美黑吊大战白妞欧美 | 日本中文不卡 | 亚洲精品美女在线观看 | 五月天久久综合 | 色婷婷视频在线 | 成人在线你懂得 | 国产精品久久久久久久久久不蜜月 | 亚洲欧美日韩在线一区二区 | 欧美在线一 | 日本韩国中文字幕 | 97国产精品 | 91九色网站 | 色婷婷亚洲婷婷 | 亚洲不卡av一区二区三区 | 日韩免费专区 | 国产精品99久久久久久小说 | 国产精品正在播放 | 日韩电影在线视频 | 日韩成人精品一区二区 | 香蕉日日 | 三级av黄色| 久久ww| 久久视频 | 在线观看网站av | 丁香花在线视频观看免费 | a久久久久久 | 国产一区免费视频 | 日日日日日 | 日韩在线免费播放 | 九九热在线精品 | 国产韩国日本高清视频 | 久久a v视频 | 三级a视频 | 亚洲精品网址在线观看 | 欧美在线一二区 | 国产一区视频导航 | 超碰97av在线| 亚洲精品国产精品国自产观看 | 国产淫片免费看 | 色多多视频在线 | 日韩av图片 | 国产一区二区不卡在线 | 成人久久久电影 | 成人黄色免费在线观看 | 在线免费视频你懂的 | 中文字幕在线观看免费高清完整版 | 中文字幕欧美三区 | av三级av | 996久久国产精品线观看 | 欧美日韩在线免费观看视频 | 免费午夜在线视频 | 国产精品久久久久高潮 | 久久久久久欧美二区电影网 | 午夜av电影 | 久久人人爽人人 | 黄色一级大片在线免费看国产一 | 日本黄色免费电影网站 | 丰满少妇在线观看网站 | 91精品国产99久久久久久红楼 | 亚州精品天堂中文字幕 | 久久高视频 | a黄色一级片 | 欧美在线视频二区 | 久久成人综合视频 | 久草男人天堂 | 欧美激情视频一二三区 | 精品国模一区二区三区 | 99成人精品| 亚洲在线视频网站 | 黄色在线网站噜噜噜 | 九九视频精品免费 | 免费不卡中文字幕视频 | 91免费视频网站在线观看 | 国产生活一级片 | 91成人在线观看高潮 | 在线精品视频免费播放 | 免费进去里的视频 | 久久精品1区 | 91看片网址 | 国产精品美女久久 | 看国产黄色大片 | 天天射天天艹 | 欧美一二三专区 | 三级动态视频在线观看 | 久久久久在线视频 | 爱色av.com| 韩国av一区二区三区在线观看 | 成人午夜电影久久影院 | 奇米影视777四色米奇影院 | 日韩欧美69 | 美女网站在线观看 | 免费人成在线观看 | 亚洲v欧美v国产v在线观看 | 亚洲专区在线视频 | 天天色图 | 欧美网站黄色 | 国产激情小视频在线观看 | 成人黄色大片 | 国产精品久久久久久久久久久久午夜 | 色综合天天综合 | 香蕉视频导航 | 婷婷色网址 | 91精品视频免费看 | 狠狠地日 | 日韩久久一区 | 麻豆视频在线观看免费 | 91在线看黄 | 国产免费专区 | 狠狠操操操 | 欧美一区二区免费在线观看 | 婷婷久久综合九色综合 | 一区二区三区精品久久久 | 中文在线字幕免 | 久久av免费电影 | 国产精品免费在线 | 欧美va天堂va视频va在线 | 天天干天天爽 | 久久亚洲成人网 | 久久久亚洲精品 | 91精品国产高清自在线观看 | 亚洲蜜桃av | 亚洲一区二区天堂 | 国产在线观看黄 | 丁香五香天综合情 | 亚洲 综合 国产 精品 | 日韩电影在线观看中文字幕 | 国产精品美女久久久免费 | 最近中文字幕完整高清 | 久久午夜电影院 | 国产精品第一 | 美女啪啪图片 | 精品主播网红福利资源观看 | www.夜夜爱 | 天躁狠狠躁 | 夜添久久精品亚洲国产精品 | 国产视频观看 | 国产午夜精品一区二区三区在线观看 | 日韩午夜视频在线观看 | 99热 精品在线 | 中文在线资源 | 免费av影视 | 五月天免费网站 | 日本久久电影网 | 亚洲欧美少妇 | 日本夜夜草视频网站 | 亚洲三级毛片 | 久草电影免费在线观看 | 国产一区欧美二区 | av观看在线观看 | 免费福利在线 | 免费看三级黄色片 | 可以免费观看的av片 | 九九99| 色婷婷国产精品一区在线观看 | 精品婷婷| 久久久亚洲国产精品麻豆综合天堂 | 欧美精品生活片 | 六月丁香激情网 | 91热这里只有精品 | 亚洲成人黄色 | www,黄视频 | 在线午夜电影神马影院 | 狠狠干网 | 日韩动漫免费观看高清完整版在线观看 | 97国产精品亚洲精品 | 免费看的黄色的网站 | 91成人国产 | 黄色av观看| 免费成人在线电影 | 中国一 片免费观看 | 安徽妇搡bbbb搡bbbb | 免费观看成人av | 午夜视频99| 亚洲精品国产综合99久久夜夜嗨 | 亚洲欧美日韩一区二区三区在线观看 | 国产成人一区二 | 国产精品久久99精品毛片三a | 在线观看免费中文字幕 | 亚洲性xxxx | 国产精品v欧美精品 | 国产一区免费看 | 免费观看一级视频 | 免费av电影网站 | 天天操天天干天天操天天干 | 中文字幕第一页在线视频 | 色妞色视频一区二区三区四区 | 99在线精品观看 | 色老板在线视频 | 在线亚洲欧美视频 | 九九九九九九精品任你躁 | 久久99精品热在线观看 | 在线视频91 | 五月天中文字幕 | www.久热| 四虎影视精品永久在线观看 | 免费久久99精品国产婷婷六月 | 久久久久久久久福利 | 欧美一级在线观看视频 | 在线免费黄色av | 免费看三级网站 | 久久视频精品 | 久久电影国产免费久久电影 | 97视频免费在线观看 | 一本一道久久a久久综合蜜桃 | 人人干网 | 亚洲天天在线 | 江苏妇搡bbbb搡bbbb | 国产色在线视频 | 国产美腿白丝袜足在线av | 欧美日韩高清国产 | 黄色三级免费网址 | 国产亚洲视频在线观看 | 成年人视频在线免费观看 | 亚洲精品国产精品国自产观看 | 国产区精品视频 | 日韩在线免费视频观看 | 日韩精品视频第一页 | 日韩视频一区二区在线观看 | av一区二区在线观看中文字幕 | 久久综合精品国产一区二区三区 | 日韩大片免费在线观看 | 五月天久久激情 | 精品久操 | 视频在线日韩 | 伊人首页 | 国产精品网址在线观看 | 狠狠操在线 | 狠狠操导航 | 国产精品女主播一区二区三区 | 国产精品久久久久久久久久新婚 | 久久精品久久综合 | 国产一级免费观看视频 | 中文字幕超清在线免费 | 日日夜夜免费精品视频 | 五月天丁香 | 久久五月婷婷综合 | 99资源网| 黄色大片中国 | 在线免费观看黄色小说 | 99视频99| 亚洲精品88欧美一区二区 | 中文字幕视频网站 | 丁香5月婷婷 | 久色 网 | 国产精品久久久久久久久免费看 | 干 操 插 | 黄色亚洲大片免费在线观看 | 人人精品 | 在线91观看 | 久久国产精品视频观看 | 色在线最新| 免费看的国产视频网站 | 操操操日日日干干干 | 中文字幕视频网站 | 91探花国产综合在线精品 | 一区二区伦理 | 久久一区二区免费视频 | 五月情婷婷 | 蜜臀av在线一区二区三区 | 超碰99人人 | 五月天婷婷免费视频 | 免费黄在线观看 | 日日夜操 | 午夜久久精品 | www.夜夜骑.com | 97成人资源 | 久久99最新地址 | 国产一区二区在线免费 | 久草观看视频 | 日韩视频图片 | 国产91免费观看 | 亚洲激情视频在线观看 | 这里只有精品视频在线 | 91传媒视频在线观看 | 国产精品第二十页 | 欧美日韩高清一区二区 国产亚洲免费看 | 色91在线| 日韩欧美一区二区在线播放 |