精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

C++對象模型之RTTI的實現(xiàn)原理

開發(fā) 前端
RTTI是Runtime Type Identification的縮寫,意思是運行時類型識別。C++引入這個機制是為了讓程序在運行時能根據(jù)基類的指針或引用來獲得該指針或引用所指的對象的實際類型。但是現(xiàn)在RTTI的類型識別已經(jīng)不限于此了,它還能通過typeid操作符識別出所有的基本類型(int,指針等)的變量對應(yīng)的類型。

RTTI是Runtime Type Identification的縮寫,意思是運行時類型識別。C++引入這個機制是為了讓程序在運行時能根據(jù)基類的指針或引用來獲得該指針或引用所指的對象的實際類型。但是現(xiàn)在RTTI的類型識別已經(jīng)不限于此了,它還能通過typeid操作符識別出所有的基本類型(int,指針等)的變量對應(yīng)的類型。

C++通過以下的兩個操作提供RTTI:

  • typeid運算符,該運算符返回其表達式或類型名的實際類型。
  • dynamic_cast運算符,該運算符將基類的指針或引用安全地轉(zhuǎn)換為派生類類型的指針或引用。

下面分別詳細地說明這兩個操作的實現(xiàn)方式。

注所有的測試代碼的測試環(huán)境均為:32位Ubuntu 14.04 g++ 4.8.2,若在不同的環(huán)境中進行測試,結(jié)果可能有不同。

1、typeid運算符

typeid運算符,后接一個類型名或一個表達式,該運算符返回一個類型為std::tpeinf的對象的const引用。type_info是std中的一個類,它用于記錄與類型相關(guān)的信息。類type_info的定義大概如下:

 

  1. class type_info 
  2.     public
  3.         virtual ~type_info(); 
  4.         bool operator==(const type_info&)const; 
  5.         bool operator!=(const type_info&)const; 
  6.         bool before(const type_info&)const; 
  7.         const charname()const; 
  8.     private: 
  9.         type_info(const type_info&); 
  10.         type_info& operator=(const type_info&); 
  11.         
  12.         // data members 
  13. }; 

至于data members部分,不同的編譯器會有所不同,但是都必須提供最小量的信息是class的真實名稱和在type_info對象之間的某些排序算法(通過before()成員函數(shù)提供),以及某些形式的描述器,用來表示顯式的類的類型和該類的任何子類型。

從上面的定義也可以看到,type_info提供了兩個對象的相等比較操作,但是用戶并不能自己定義一個type_info的對象,而只能通過typeid運算符返回一個對象的const引用來使用type_info的對象。因為其只聲明了一個構(gòu)造函數(shù)(復(fù)制構(gòu)造函數(shù))且為private,所以編譯器不會合成任何的構(gòu)造函數(shù),而且賦值操作運行符也為private。這兩個操作就完全禁止了用戶對type_info對象的定義和復(fù)制操作,用戶只能通過指向type_info的對象的指針或引用來使用該類。

下面說說,typeid對靜態(tài)類型的表達式和動態(tài)類型的表達式的處理和實現(xiàn)。

1)typeid識別靜態(tài)類型

當(dāng)typeid中的操作數(shù)是如下情況之一時,typeid運算符指出操作數(shù)的靜態(tài)類型,即編譯時的類型。

  • 類型名
  • 一個基本類型的變量
  • 一個具體的對象
  • 一個指向不含有virtual函數(shù)的類對象的指針的解引用
  • 一個指向不含有virtual函數(shù)的類對象的引用

靜態(tài)類型在程序的運行過程中并不會改變,所以并不需要在程序運行時計算類型,在編譯時就能根據(jù)操作數(shù)的靜態(tài)類型,推導(dǎo)出其類型信息。例如如下的代碼片斷,typeid中的操作數(shù)均為靜態(tài)類型:

 

  1. class X  {  ...... // 具有virtual函數(shù) };  
  2. class XX : public X  { ...... // 具有virtual函數(shù)};  
  3. class Y  { ...... // 沒有virtual函數(shù)};  
  4.   
  5. int main() 
  6.     int n = 0; 
  7.     XX xx; 
  8.     Y y; 
  9.     Y *py = &y; 
  10.   
  11.     // int和XX都是類型名 
  12.     cout << typeid(int).name() << endl; 
  13.     cout << typeid(XX).name() << endl; 
  14.     // n為基本變量 
  15.     cout << typeid(n).name() << endl; 
  16.     // xx所屬的類雖然存在virtual,但是xx為一個具體的對象 
  17.     cout << typeid(xx).name() << endl; 
  18.     // py為一個指針,屬于基本類型 
  19.     cout << typeid(py).name() << endl; 
  20.     // py指向的Y的對象,但是類Y不存在virtual函數(shù) 
  21.     cout << typeid(*py).name() << endl; 
  22.     return 0; 

2)typeid識別多態(tài)類型

當(dāng)typeid中的操作數(shù)是如下情況之一時,typeid運算符需要在程序運行時計算類型,因為其其操作數(shù)的類型在編譯時期是不能被確定的。

  • 一個指向不含有virtual函數(shù)的類對象的指針的解引用
  • 一個指向不含有virtual函數(shù)的類對象的引用

多態(tài)的類型是可以在運行過程中被改變的,例如,一個基類的指針,在程序運行的過程中,它可以指向一個基類對象,也可以指向該基類的派生類的對象,而typeid運算符需要在運行過程中識別出該基類指針所指向的對象的實際類型,這就需要typeid運算符在運行過程中計算其指向的對象的實際類型。例如對于以下的類定義:

 

  1. class X 
  2.     public
  3.         X() 
  4.         { 
  5.             mX = 101; 
  6.         } 
  7.         virtual void vfunc() 
  8.         { 
  9.             cout << "X::vfunc()" << endl; 
  10.         } 
  11.     private: 
  12.         int mX; 
  13. }; 
  14. class XX : public X 
  15.     public
  16.         XX(): 
  17.             X() 
  18.         { 
  19.             mXX = 1001; 
  20.         } 
  21.         virtual void vfunc() 
  22.         { 
  23.             cout << "XX::vfunc()" << endl; 
  24.         } 
  25.     private: 
  26.         int mXX; 
  27. }; 

使用如下的代碼進行測試:

 

  1. void printTypeInfo(const X *px) 
  2.     cout << "typeid(px) -> " << typeid(px).name() << endl; 
  3.     cout << "typeid(*px) -> " << typeid(*px).name() << endl; 
  4. int main() 
  5.     X x; 
  6.     XX xx; 
  7.     printTypeInfo(&x); 
  8.     printTypeInfo(&xx); 
  9.     return 0; 

其輸出如下:

 

C++對象模型之RTTI的實現(xiàn)原理

從輸出的結(jié)果可以看出,無論printTypeInfo函數(shù)中指針px指向的對象是基類X的對象,還是指向派生類XX的對象,typeid運行返回的px的類型信息都是相同的,因為px為一個靜態(tài)類型,其類型名均為PX1X。但是typeid運算符卻能正確地計算出了px指向的對象的實際類型。(注:由于C++為了保證每一個類在程序中都有一個獨一無二的類名,所以會對類名通過一定的規(guī)則進行改寫,所以在這里顯示的類名跟我們定義的有一些不一樣,如類XX的類名,被改寫成了2XX。)

那么問題來了,typeid是如何計算這個類型信息的呢?下面將重點說明這個問題。

多態(tài)類型是通過在類中聲明一個或多個virtual函數(shù)來區(qū)分的。因為在C++中,一個具備多態(tài)性質(zhì)的類,正是內(nèi)含直接聲明或繼承而來的virtual函數(shù)。多態(tài)類的對象的類型信息保存在虛函數(shù)表的索引的-1的項中,該項是一個type_info對象的地址,該type_info對象保存著該對象對應(yīng)的類型信息,每個類都對應(yīng)著一個type_info對象。下面就對這一說法進行驗證。

使用如以的代碼,對上述的類X和類XX的對象的內(nèi)存布局進行測試:

 

  1. typedef void (*FuncPtr)(); 
  2. int main() 
  3.     XX xx; 
  4.     FuncPtr func; 
  5.     char *p = (char*)&xx; 
  6.     // 獲得虛函數(shù)表的地址 
  7.     int **vtbl = (int**)*(int**)p; 
  8.     // 輸出虛函數(shù)表的地址,即vptr的值 
  9.     cout << vtbl << endl; 
  10.     // 獲得type_info對象的指針,并調(diào)用其name成員函數(shù) 
  11.     cout << "\t[-1]: " << (vtbl[-1]) << " -> " 
  12.         << ((type_info*)(vtbl[-1]))->name() << endl; 
  13.     // 調(diào)用第一個virtual函數(shù) 
  14.     cout << "\t[0]: " << vtbl[0] << " -> "
  15.     func = (FuncPtr)vtbl[0]; 
  16.     func(); 
  17.     // 輸出基類的成員變量的值 
  18.     p += sizeof(int**); 
  19.     cout << *(int*)p << endl; 
  20.     // 輸出派生類的成員變量的值 
  21.     p += sizeof(int); 
  22.     cout << *(int*)p << endl; 
  23.     return 0; 

測試代碼,對類XX的對象的內(nèi)存布局進行測試,其輸出結(jié)果如下:

 

C++對象模型之RTTI的實現(xiàn)原理

從運行結(jié)果可以看到,利用虛函數(shù)表的-1的項的地址轉(zhuǎn)換成一個type_info的指針類型,并調(diào)用name成員函數(shù)的輸出為2XX,其輸出與前面的測試代碼中利用typeid的輸出一致。從而可以知道,關(guān)于多態(tài)類型的計算是通過基類指針或引用指向的對象(子對象)的虛函數(shù)表獲得的。

從運行的結(jié)果可以知道,類XX的對象的內(nèi)存布局如下:

 

C++對象模型之RTTI的實現(xiàn)原理

對于以下的代碼片斷:

  1. typeid(*px).name() 

可能被轉(zhuǎn)換成如下的C++偽代碼,用于計算實際對象的類型:

  1. (*(type_info*)px->vptr[-1]).name(); 

在多重繼承和虛擬繼承的情況下,一個類有n(n>1)個虛函數(shù)表,該類的對象也有n個vptr,分別指向這些虛函數(shù)表,但是一個類的所有的虛函數(shù)表的索引為-1的項的值(type_info對象的地址)都是相等的,即它們都指向同一個type_info對象,這樣就實現(xiàn)了無論使用了哪一個基類的指針或引用指向其派生類的對象,都能通過相應(yīng)的虛函數(shù)表獲取到相同的type_info對象,從而得到相同的類型信息。

3)typeid的識別錯誤的情況

從第2)節(jié)可以看到,typeid對于多態(tài)類型是通過虛函數(shù)表來計算的,若一個基類的指針指向了一個派生類,而該派生類并不存在virtual函數(shù)會出現(xiàn)什么情況呢?

例如,把第2)節(jié)中的X和XX類中的virtual函數(shù)全部去掉,改成以下的代碼:

 

  1. class X 
  2.     public
  3.         X() 
  4.         { 
  5.             mX = 101; 
  6.         } 
  7.     private: 
  8.         int mX; 
  9. }; 
  10.   
  11. class XX : public X 
  12.     public
  13.         XX(): 
  14.             X() 
  15.         { 
  16.             mXX = 1001; 
  17.         } 
  18.     private: 
  19.         int mXX; 
  20. }; 

測試代碼不變,如下:

 

  1. void printTypeInfo(const X *px) 
  2.     cout << "typeid(px) -> " << typeid(px).name() << endl; 
  3.     cout << "typeid(*px) -> " << typeid(*px).name() << endl; 
  4. int main() 
  5.     X x; 
  6.     XX xx; 
  7.   
  8.     printTypeInfo(&x); 
  9.     printTypeInfo(&xx); // 注釋1 
  10.   
  11.     return 0; 

其輸出如下:

 

C++對象模型之RTTI的實現(xiàn)原理

從輸出的結(jié)果可以看到,對于注釋1的函數(shù)調(diào)用,雖然函數(shù)中基類(X)的指針px指向一個派生類對象(XX類的對象xx),但是typeid卻并不沒有像第2)節(jié)那樣能正確地通過指針px計算出其所指對象的實際類型。

其原因在于類XX和類X都沒有一個virtual函數(shù),所以類XX和類X并不表現(xiàn)出多態(tài)類的性質(zhì)。所以對類的指針的解引用符合第1)節(jié)中所說的靜態(tài)類型,所以其類型信息是在編譯時就已經(jīng)確定的,并不需要在程序運行的過程中運行計算,所以其輸出的類型均為1X而沒有輸出1XX。更進一步說,是因為類X和類XX都不存在virtual函數(shù),所以類X和XX都不存在虛函數(shù)表,所以也就沒有空間存儲跟類X和XX類型有關(guān)的type_info對象的地址。

然而在C++中即使一個類不具有多態(tài)的性質(zhì),仍然允許把一個派生類的指針賦值給一個基類的指針,所以這個錯誤比較隱晦。

2、dynamic_cast運算符

把一個基類類型的指針或引用轉(zhuǎn)換至繼承架構(gòu)的末端某一個派生類類型的指針或引用被稱為向下轉(zhuǎn)型(downcast)。dynamic_cast運算符的作用是安全而有效地進行向下轉(zhuǎn)型。

把一個派生類的指針或引用轉(zhuǎn)換成其基類的指針或引用總是安全的,因為通過分析對象的內(nèi)存布局可以知道,派生類的對象中必然存在基類的子對象,所以通過基類的指針或引用對派生類對象進行的所有基類的操作都是合法和安全的。而向下轉(zhuǎn)型有潛在的危險性,因為基類的指針可以指向基類對象或其任何派生類的對象,而該對象并不一定是向下轉(zhuǎn)型的類型的對象。所以向下轉(zhuǎn)型遏制了類型系統(tǒng)的作用,轉(zhuǎn)換后對指針或引用的使用可能會引發(fā)錯誤的解釋或腐蝕程序內(nèi)存等錯誤。

例如對于以下的類定義:

 

  1. class X 
  2.     public
  3.         X() 
  4.         { 
  5.             mX = 101; 
  6.         } 
  7.         virtual ~X() 
  8.         { 
  9.         } 
  10.     private: 
  11.         int mX; 
  12. }; 
  13.   
  14. class XX : public X 
  15.     public
  16.         XX(): 
  17.             X() 
  18.         { 
  19.             mXX = 1001; 
  20.         } 
  21.         virtual ~XX() 
  22.         { 
  23.         } 
  24.     private: 
  25.         int mXX; 
  26. }; 
  27.   
  28. class YX : public X 
  29.     public
  30.         YX() 
  31.         { 
  32.             mYX = 1002; 
  33.         } 
  34.         virtual ~YX() 
  35.         { 
  36.         } 
  37.     private: 
  38.         int mYX; 
  39. }; 

使用如下的測試代碼,其中的類型轉(zhuǎn)換均為向下轉(zhuǎn)型:

  1. int main(){ X x; XX xx; YX yx; X *px = &xx; cout << px << endl; XX *pxx = dynamic_cast<XX*>(px); // 轉(zhuǎn)換1 cout << pxx << endl; YX *pyx = dynamic_cast<YX*>(px); // 轉(zhuǎn)換2 cout << pyx << endl; pyx = (YX*)px; // 轉(zhuǎn)換3 cout << pyx << endl; pyx = static_cast<YX*>(px); // 轉(zhuǎn)換4 cout << pyx << endl; return 0;} 

其運行結(jié)果如下:

 

C++對象模型之RTTI的實現(xiàn)原理

運行結(jié)果分析

px是一個基類(X)的指針,但是它指向了派生類XX的一個對象。在轉(zhuǎn)換1中,轉(zhuǎn)換成功,因為px指向的對象確實為XX的對象。在轉(zhuǎn)換2中,轉(zhuǎn)換失敗,因為px指向的對象并不是一個YX對象,此時dymanic_cast返回NULL。轉(zhuǎn)換3為C風(fēng)格的類型轉(zhuǎn)換而轉(zhuǎn)換4使用的是C++中的靜態(tài)類型轉(zhuǎn)換,它們均能成功轉(zhuǎn)換,但是這個對象實際上并不是一個YX的對象,所以在轉(zhuǎn)換3和轉(zhuǎn)換4中,若繼續(xù)通過指針使用該對象必然會導(dǎo)致錯誤,所以這個轉(zhuǎn)換是不安全的。

從上述的結(jié)果可以看出在向下轉(zhuǎn)型中,只有dynamic_case才能實現(xiàn)安全的向下轉(zhuǎn)型。那么dynamic_case是如何實現(xiàn)的呢?有了上面typeid和虛函數(shù)表的知識后,這個問題并不難解釋了,以轉(zhuǎn)換1為例。

  • 計算指針或引用變量所指的對象的虛函數(shù)表的type_info信息,如下:
  1. *(type_info*)px->vptr[-1] 
  • 靜態(tài)推導(dǎo)向下轉(zhuǎn)型的目標類型的type_info信息,即獲取類XX的type_info信息
  • 比較1)和2)中獲取到的type_info信息,若2)中的類型信息與1)中的類型信息相等或是其基類類型,則返回相應(yīng)的對象或子對象的地址,否則返回NULL。

引用的情況與指針稍有不同,失敗時并不是返回NULL,而是拋出一個bad_cast異常,因為引用不能參考NULL。

責(zé)任編輯:未麗燕 來源: 今日頭條
相關(guān)推薦

2023-11-22 12:25:05

C++RTTI

2010-02-01 14:33:05

C++實現(xiàn)RTTI

2010-01-25 14:18:46

C++對象模型

2010-01-18 17:48:46

C++類對象

2010-05-12 10:53:04

Symbian開發(fā)

2011-07-10 15:36:54

C++

2011-06-21 10:17:41

c++內(nèi)存模型

2009-12-22 01:54:50

C++之父Bjarne Stro

2023-12-22 13:58:00

C++鏈表開發(fā)

2015-03-23 10:04:43

c++編譯器c++實現(xiàn)原理總結(jié)

2011-07-15 00:47:13

C++多態(tài)

2011-07-14 17:45:06

CC++

2012-09-18 13:26:39

CC++

2011-07-10 15:26:54

C++

2011-07-13 18:24:18

C++

2025-07-04 09:19:54

2012-05-30 15:03:43

ibmdw

2015-11-30 11:14:59

C++對象池自動回收

2011-07-15 01:38:56

C++this指針

2010-01-25 11:13:18

C++棧對象
點贊
收藏

51CTO技術(shù)棧公眾號

国产精品久久久久久久久久久久久久久 | 色播五月激情综合网| 蜜桃网站成人| 亚洲天堂中文字幕在线| 亚洲电影在线一区二区三区| 日韩欧美一二区| 亚洲国产精品久久久久婷蜜芽| 国产无套粉嫩白浆在线2022年| 麻豆91精品91久久久的内涵| 欧美国产日本高清在线 | 欧美裸体男粗大视频在线观看| 古装做爰无遮挡三级聊斋艳谭| 黑森林国产精品av| 国产精品灌醉下药二区| 国产一级二级三级精品| 在线观看国产成人| 国产欧美综合一区二区三区| 色婷婷**av毛片一区| 国产夫妻性爱视频| 日韩精品一区二区三区中文| 色婷婷亚洲一区二区三区| mm131午夜| 国产一级在线| 成人动漫一区二区| 91深夜福利视频| 少妇一级淫片日本| 国产一区二区三区久久| 美日韩精品视频免费看| 亚洲欧洲久久久| 黄色成人美女网站| 91精品国产综合久久香蕉麻豆| 国产原创popny丨九色| 黄网页在线观看| 国产日韩欧美高清在线| 久久国产精品高清| 性生交大片免费看女人按摩| 久久国产综合精品| 日韩av免费看网站| 国产精品999在线观看| 欧美日韩福利| 久热在线中文字幕色999舞| 免费看黄色av| 亚洲宅男一区| 日韩精品久久久久久福利| 99国产精品免费视频| 欧美一级免费| 欧美精品第1页| 日日噜噜噜噜久久久精品毛片| 亚洲优女在线| 午夜精品一区二区三区免费视频| 99精品一级欧美片免费播放| 麻豆影视国产在线观看| 国产精品国产三级国产普通话99| 日韩精品电影网站| 国产午夜在线观看| 欧美韩日一区二区三区| 亚洲精品9999| aaa在线免费观看| 国产精品欧美经典| 亚洲va久久久噜噜噜久久狠狠| 黄色在线网站| 国产午夜亚洲精品羞羞网站| 色噜噜色狠狠狠狠狠综合色一| 男人av在线| 国产日韩精品一区二区三区在线| 日韩免费电影一区二区| 福利在线观看| 国产精品成人免费| 天天操天天干天天玩| v片在线观看| 亚洲精品免费电影| 国产午夜精品视频一区二区三区| www视频在线看| 一区二区在线免费| 日韩一级性生活片| 麻豆mv在线观看| 色94色欧美sute亚洲13| 国产一二三四在线视频| 国外成人福利视频| 日韩午夜激情电影| av在线播放网址| 免费看av成人| 久久激情视频免费观看| 国产亚洲精品码| 午夜亚洲激情| 国产一区二区色| 午夜精品一区二区三| 91在线小视频| 亚洲一区二区在| 牛牛精品在线视频| 欧美日韩国产一区在线| 免费一区二区三区在线观看| 高清在线一区二区| 日韩精品一二三四区| 欧美三级视频网站| 欧美日韩国产精品一区二区亚洲| 2019中文字幕在线观看| 亚洲天堂中文字幕在线| 成人福利视频网站| 亚洲精品中文字幕在线| 亚洲奶水xxxx哺乳期| 欧美日韩一区二区在线| 日本不卡一区在线| 久久99国产精品久久99大师| 中文字幕精品网| 国产午夜福利精品| 麻豆91在线看| 狠狠色综合色区| 黄色一级片在线观看| 高跟丝袜欧美一区| 天天干天天曰天天操| 深爱激情久久| 欧美高清在线观看| 自拍偷拍第八页| 不卡一卡二卡三乱码免费网站| 亚洲欧洲三级| 乡村艳史在线观看| 日韩欧美在线一区二区三区| 在线小视频你懂的| 91久久综合| 96国产粉嫩美女| 北岛玲日韩精品一区二区三区| 亚洲永久精品大片| 亚洲免费一级视频| 亚洲免费福利一区| 久久久久亚洲精品| 国产日韩精品suv| 国产免费观看久久| 久久久噜噜噜www成人网| 伊人精品久久| 欧美日本黄视频| 在线免费观看日韩视频| 久久久久久久电影| 欧美老熟妇喷水| 高潮按摩久久久久久av免费| 久久大大胆人体| 依依成人在线视频| 国产日韩精品视频一区| 日本女优爱爱视频| 天堂在线精品| 人妖精品videosex性欧美| 天天av天天翘| 天天影视涩香欲综合网| 在线观看亚洲免费视频| 欧美女激情福利| 亚洲自拍偷拍视频| av毛片在线免费| 777午夜精品免费视频| 亚洲综合图片一区| 蜜臀久久99精品久久久画质超高清 | 色播久久人人爽人人爽人人片视av| 中文字幕国产在线观看| 99久久国产免费看| 六月丁香婷婷激情| 曰本一区二区三区视频| 欧美在线视频观看免费网站| 亚洲日本中文字幕在线| 狠狠久久五月精品中文字幕| 欧美 变态 另类 人妖| 日韩一区二区免费看| 黑人中文字幕一区二区三区| 日韩精品美女| 国产香蕉97碰碰久久人人| 在线观看亚洲国产| 亚洲激情图片一区| 四虎精品一区二区| 性色一区二区三区| 日韩欧美在线电影| 亚洲午夜剧场| 欧美区二区三区| 天天干视频在线观看| 色欧美片视频在线观看| 国产wwwwxxxx| 国产精品一二三四| 欧美日韩不卡在线视频| 亚洲专区视频| 国产日韩欧美91| av黄在线观看| 精品丝袜一区二区三区| 久久这里只有精品9| 亚洲三级在线播放| 国产一级黄色录像| 日本美女视频一区二区| 大桥未久一区二区| 精品综合久久88少妇激情| 国产成人亚洲综合青青| 黄色在线播放网站| 亚洲国产欧美久久| 中文字幕第99页| 亚洲综合久久久久| 男人的天堂官网| 国产高清一区日本| 久久久久久久久久久免费视频| 久久精品国产亚洲夜色av网站| 91夜夜揉人人捏人人添红杏| 成人福利视频| 精品国产一区二区三区久久| 人妻视频一区二区三区| 欧美在线视频你懂得| 青青草成人免费| 国产视频一区在线观看| 韩国三级丰满少妇高潮| 久久久噜噜噜久久狠狠50岁| 欧美xxxx吸乳| 国产综合久久久| 国产精品xxx在线观看www| 91九色综合| 81精品国产乱码久久久久久| 黄色的网站在线观看| 亚洲精品之草原avav久久| 国产人妖在线播放| 欧洲亚洲精品在线| 国产精品19乱码一区二区三区| 国产片一区二区| 中文字幕天堂av| 极品少妇一区二区| 亚洲人成无码www久久久| 激情久久综合| 一区二区三区视频在线播放| 免费成人网www| 久久精品ww人人做人人爽| 国产精品一区免费在线| 国产精品久久久久久久久久小说| 俺来也官网欧美久久精品| 久久久精品久久| av电影在线观看一区二区三区| 亚洲美腿欧美激情另类| 丰满人妻一区二区| 日韩色视频在线观看| 国产精品久久久久久69| 欧美日韩国产精品自在自线| 一级片在线观看免费| 精品国产成人av| 四虎永久在线精品| 亚洲激情图片小说视频| 国产一区二区视频在线观看免费| 国产精品理论片| 69xxx免费| 亚洲国产高清在线| 欧美做受xxxxxⅹ性视频| 91色视频在线| 日本少妇毛茸茸| eeuss影院一区二区三区 | 国产色99精品9i| 国产自摸综合网| 国产精品一区二区三区www| 成人久久久久爱| 国产乱码精品一区二区三区亚洲人| 国产美女91呻吟求| 涩涩涩久久久成人精品| 91久久嫩草影院一区二区| 欧美亚洲二区| 91色p视频在线| 日韩免费高清视频网站| 成人av播放| 99热这里只有精品首页| 国产精品美女xx| 欧美日韩一区二区三区在线电影| 国产亚洲精品自在久久| 私拍精品福利视频在线一区| 麻豆蜜桃91| 国产剧情在线观看一区| 亚欧精品在线| 欧美韩国一区| 成人免费播放器| 亚洲欧美大片| 午夜视频你懂的| 国产精品综合久久| 精品少妇人妻av一区二区三区| www.66久久| 欧美 日韩 国产 成人 在线观看 | 青青草91视频| 波多野结衣国产精品| 国产精品系列在线播放| xxxxxx黄色| 日本一二三不卡| 久久国产波多野结衣| 亚洲mv在线观看| 波多野结衣视频在线看| 91精品在线免费观看| 亚洲精品久久久久avwww潮水| 亚洲精品二三区| 91涩漫在线观看| 欧美激情精品久久久久久免费印度 | 992kp快乐看片永久免费网址| 精品一二三四区| 中国极品少妇videossexhd| 欧美激情一区二区三区不卡| 青青草偷拍视频| 日本乱人伦一区| 国产伦精品一区二区三区视频痴汉| 精品日韩在线一区| 国产在线三区| 欧美精品videossex88| 三级成人在线| 成人永久免费| 欧美在线电影| 日韩小视频在线播放| 久久精品国产99久久6| 超碰caoprom| 亚洲欧美中日韩| 一级片免费在线播放| 欧美一级高清片在线观看| 九色视频在线观看免费播放| 欧美理论电影在线播放| 欧洲成人一区| 久久久久网址| 午夜日韩视频| 成人亚洲精品777777大片| 不卡的看片网站| 91日韩中文字幕| 欧亚洲嫩模精品一区三区| 亚洲奶汁xxxx哺乳期| 久久久成人的性感天堂| 婷婷激情一区| 精品国产乱码久久久久久丨区2区| 五月激情综合| 男人女人黄一级| 99精品视频在线免费观看| 国产一二三区精品| 欧美午夜精品免费| 免费黄网站在线观看| 久久久噜噜噜久久久| 91麻豆精品一二三区在线| 日本中文不卡| 另类av一区二区| 中文字幕乱码一区| 一区二区三区免费看视频| 亚洲在线免费观看视频| 国产亚洲精品久久久优势 | 精品免费在线视频| 成人久久精品人妻一区二区三区| 久久亚洲国产精品成人av秋霞| 777午夜精品电影免费看| 麻豆传媒一区二区| 91久久久久| 日韩无码精品一区二区| 亚洲国产裸拍裸体视频在线观看乱了 | 97人人干人人| 你懂的网址国产 欧美| 中文字幕国产高清| 国产精品久久久久影院色老大 | 欧美一级二区| 国产精品1000部啪视频| 精品久久久久久久久久ntr影视| 黑人乱码一区二区三区av| 欧美激情视频播放| 97品白浆高清久久久久久| 国产 欧美 日韩 一区| 国产精品一区二区在线看| 久久免费公开视频| 精品国免费一区二区三区| 91福利在线免费| 玖玖玖精品中文字幕| 老司机精品久久| 亚洲欧美va天堂人熟伦| 欧美天堂一区二区三区| 亚洲精品传媒| 亚洲a区在线视频| 亚洲图片在线| www.日本高清| 欧美性xxxx极品hd满灌| 国产在线视频你懂得| 国产欧美日韩免费| 五月激情综合| 日本性生活一级片| 色婷婷久久综合| 福利片在线看| 亚洲综合中文字幕在线| 精品999成人| mm131美女视频| 欧美日韩卡一卡二| 3d玉蒲团在线观看| 黑人中文字幕一区二区三区| 久久精品三级| 久久精品亚洲a| 日韩美一区二区三区| 日韩欧美精品一区二区三区| 青青草久久网络| 国产一区二区毛片| 在线观看亚洲欧美| 日韩视频中文字幕| 成人知道污网站| 久久久精品麻豆| 亚洲一区二区五区| 加勒比一区二区三区在线| 亚洲精品免费一区二区三区| 99在线|亚洲一区二区| 国产小视频你懂的| 亚洲娇小xxxx欧美娇小| 国产成人免费| 成人黄色av片| 国产精品亲子伦对白| 欧美 日韩 国产 在线| 国产精品亚洲自拍| 亚洲成色精品| 国产又黄又粗又猛又爽的| 亚洲精品一区在线观看| 99久久伊人| 成年人午夜视频在线观看 |