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

C++接口工程實(shí)踐:有哪些實(shí)現(xiàn)方法?

開發(fā) 開發(fā)工具
程序開發(fā)的時(shí)候經(jīng)常會(huì)使用到接口。眾所周知,C++語言層面并沒有接口的概念,但并不意味著C++不能實(shí)現(xiàn)接口的功能。

程序開發(fā)的時(shí)候經(jīng)常會(huì)使用到接口。眾所周知,C++語言層面并沒有接口的概念,但并不意味著C++不能實(shí)現(xiàn)接口的功能。相反,正是由于C++語言沒有提供標(biāo)準(zhǔn)的接口,導(dǎo)致實(shí)際實(shí)現(xiàn)接口的方法多種多樣。那么C++有哪些實(shí)現(xiàn)接口的方法呢,不同的方法又適用于哪些場(chǎng)景呢?本文分享在C++接口工程實(shí)踐上的一些探索心得。

程序開發(fā)的時(shí)候經(jīng)常會(huì)使用到接口。眾所周知,C++語言層面并沒有接口的概念,但并不意味著C++不能實(shí)現(xiàn)接口的功能。相反,正是由于C++語言沒有提供標(biāo)準(zhǔn)的接口,導(dǎo)致實(shí)際實(shí)現(xiàn)接口的方法多種多樣。那么C++有哪些實(shí)現(xiàn)接口的方法呢,不同的方法又適用于哪些場(chǎng)景呢?本文分享在C++接口工程實(shí)踐上的一些探索心得。

一 接口的分類

接口按照功能劃分可以分為調(diào)用接口與回調(diào)接口:

調(diào)用接口

一段代碼、一個(gè)模塊、一個(gè)程序庫、一個(gè)服務(wù)等(后面都稱為系統(tǒng)),對(duì)外提供什么功能,以接口的形式暴露出來,用戶只需要關(guān)心接口怎么調(diào)用,不用關(guān)心具體的實(shí)現(xiàn),即可使用這些功能。這類被用戶調(diào)用的接口,稱為調(diào)用接口。

調(diào)用接口的主要作用是解耦,對(duì)用戶隱藏實(shí)現(xiàn),用戶只需要關(guān)心接口的形式,不用關(guān)心具體的實(shí)現(xiàn),只要保持接口的兼容性,實(shí)現(xiàn)上的修改或者升級(jí)對(duì)用戶無感知。解耦之后也方便多人合作開發(fā),設(shè)計(jì)好接口之后,各模塊只通過接口進(jìn)行交互,各自完成各自的模塊即可。

回調(diào)接口

系統(tǒng)定義接口,由用戶實(shí)現(xiàn),注冊(cè)到系統(tǒng)中,系統(tǒng)有異步事件需要通知用戶時(shí),回調(diào)用戶注冊(cè)的接口實(shí)現(xiàn)。系統(tǒng)定義接口的形式,但無需關(guān)心接口的實(shí)現(xiàn),而是接受用戶的注冊(cè),并在適當(dāng)?shù)臅r(shí)機(jī)調(diào)用。這類由系統(tǒng)定義,用戶實(shí)現(xiàn),被系統(tǒng)調(diào)用的接口,稱為回調(diào)接口。

回調(diào)接口的主要作用是異步通知,系統(tǒng)定義好通知的接口,并在適當(dāng)?shù)臅r(shí)機(jī)發(fā)出通知,用戶接收通知,并執(zhí)行相應(yīng)的動(dòng)作,用戶動(dòng)作執(zhí)行完后控制權(quán)交還給系統(tǒng),用戶動(dòng)作可以給系統(tǒng)返回一些數(shù)據(jù),以決定系統(tǒng)后續(xù)的行為。

二 調(diào)用接口

我們以一個(gè)Network接口為例,說明C++中的調(diào)用接口的定義及實(shí)現(xiàn),示例如下:

class Network 
{
public:
bool send(const char* host,
uint16_t port,
const std::string& message);
}

Network接口現(xiàn)在只需要一個(gè)send接口,可以向指定地址發(fā)送消息。下面我們用不同的方法來定義Network接口。

虛函數(shù)

虛函數(shù)是定義C++接口最直接的方式,使用虛函數(shù)定義Network接口類如下:

class Network 
{
public:
virtual bool send(const char* host,
uint16_t port,
const std::string& message) = 0;

static Network* New();

static void Delete(Network* network);
}

將send定義為純虛函數(shù),讓子類去實(shí)現(xiàn),子類不對(duì)外暴露,提供靜態(tài)方法New來創(chuàng)建子類對(duì)象,并以父類Network的指針形式返回。接口的設(shè)計(jì)一般遵循對(duì)象在哪創(chuàng)建就在哪銷毀的原則,因此提供靜態(tài)的Delete方法來銷毀對(duì)象。因?yàn)閷?duì)象的銷毀封裝在接口內(nèi)部,因此Network接口類可以不用虛析構(gòu)函數(shù)。

使用虛函數(shù)定義接口簡(jiǎn)單直接,但是有很多弊端:

  • 虛函數(shù)開銷:虛函數(shù)調(diào)用需要使用虛函數(shù)表指針間接調(diào)用,運(yùn)行時(shí)才能決定調(diào)用哪個(gè)函數(shù),無法在編譯鏈接期間內(nèi)聯(lián)優(yōu)化。實(shí)際上調(diào)用接口在編譯期間就能確定調(diào)用哪個(gè)函數(shù),無需虛函數(shù)的動(dòng)態(tài)特性。
  • 二進(jìn)制兼容:由于虛函數(shù)是按照索引查詢虛函數(shù)表來調(diào)用,增加虛函數(shù)會(huì)造成索引變化,新接口不能在二進(jìn)制層面兼容老接口,而且由于用戶可能繼承了Network接口類,在末尾增加虛函數(shù)也有風(fēng)險(xiǎn),因此虛函數(shù)接口一經(jīng)發(fā)布,難以修改。

指向?qū)崿F(xiàn)的指針

指向?qū)崿F(xiàn)的指針是C++比較推薦的定義接口的方式,使用指向?qū)崿F(xiàn)的指針定義Network接口類如下:

class NetworkImpl; 
class Network
{
public:
bool send(const char* host,
uint16_t port,
const std::string& message);

Network();

~Network();

private:
NetworkImpl* impl;
}

Network的實(shí)現(xiàn)通過impl指針轉(zhuǎn)發(fā)給NetworkImpl,NetworkImpl使用前置聲明,實(shí)現(xiàn)對(duì)用戶隱藏。使用指向?qū)崿F(xiàn)的指針的方式定義接口,接口類對(duì)象的創(chuàng)建和銷毀可以由用戶負(fù)責(zé),因此用戶可以選擇將Network類的對(duì)象創(chuàng)建在棧上,生命周期自動(dòng)管理。

使用指向?qū)崿F(xiàn)的指針定義接口具有良好的通用性,用戶能夠直接創(chuàng)建和銷毀接口對(duì)象,并且增加新的接口函數(shù)不影響二進(jìn)制兼容性,便于系統(tǒng)的演進(jìn)。

指向?qū)崿F(xiàn)的指針增加了一層調(diào)用,盡管對(duì)性能的影響幾乎可以忽略不計(jì),但不太符合C++的零開銷原則,那么問題來了,C++能否實(shí)現(xiàn)零開銷的接口呢?當(dāng)然可以,即下面要介紹的隱藏的子類。

隱藏的子類

隱藏的子類可以實(shí)現(xiàn)零開銷的接口,思想非常簡(jiǎn)單。調(diào)用接口要實(shí)現(xiàn)的目標(biāo)是解耦,主要就是隱藏實(shí)現(xiàn),也即隱藏接口類的成員變量,如果能將接口類的成員變量都移到另一個(gè)隱藏的實(shí)現(xiàn)類中,接口類就不需要任何成員變量,也就實(shí)現(xiàn)了隱藏實(shí)現(xiàn)的目的。隱藏的子類就是這個(gè)隱藏的實(shí)現(xiàn)類,使用隱藏的子類定義Network接口類如下:

class Network 
{
public:
bool send(const char* host,
uint16_t port,
const std::string& message);

static Network* New();

static void Delete(Network* network);

protected:
Network();

~Network();
}

Network接口類只有成員函數(shù)(非虛函數(shù)),沒有成員變量,并且構(gòu)造函數(shù)和析構(gòu)函數(shù)都申明為protected。提供靜態(tài)方法New創(chuàng)建對(duì)象,靜態(tài)方法Delete銷毀對(duì)象。New方法的實(shí)現(xiàn)中創(chuàng)建隱藏的子類NetworkImpl的對(duì)象,并以父類Network指針的形式返回。NetworkImpl類中存放Network類的成員變量,并將Network類聲明為friend:

class NetworkImpl : public Network 
{
friend class Network;

private:
//Network類的成員變量
}

Network的實(shí)現(xiàn)中,創(chuàng)建隱藏的子類NetworkImpl的對(duì)象,并以父類Network指針的形式返回,通過將this強(qiáng)制轉(zhuǎn)換為NetworkImpl的指針,訪問成員變量:

bool Network::send(const char* host,  
uint16_t port,
const std::string& message)
{
NetworkImpl* impl = (NetworkImpl*)this;
//通過impl訪問成員變量,實(shí)現(xiàn)Network
}

static Network* New()
{
return new NetworkImpl();
}

static void Delete(Network* network)
{
delete (NetworkImpl*)network;
}

使用隱藏的子類定義接口同樣具有良好的通用性和二進(jìn)制兼容性,同時(shí)沒有增加任何開銷,符合C++的零開銷原則。

三 回調(diào)接口

同樣以Network接口為例,說明C++中的回調(diào)接口的定義及實(shí)現(xiàn),示例如下:

class Network 
{
public:
class Listener
{
public:
void onReceive(const std::string& message);
}

bool send(const char* host,
uint16_t port,
const std::string& message);

void registerListener(Listener* listener);
}

現(xiàn)在Network需要增加接收消息的功能,增加Listener接口類,由用戶實(shí)現(xiàn),并注冊(cè)其對(duì)象到Network中后,當(dāng)有消息到達(dá)時(shí),回調(diào)Listener的onReceive方法。

虛函數(shù)

使用虛函數(shù)定義Network接口類如下:

class Network 
{
public:
class Listener
{
public:
virtual void onReceive(const std::string& message) = 0;
}

bool send(const char* host,
uint16_t port,
const std::string& message);

void registerListener(Listener* listener);
}

將onReceive定義為純虛函數(shù),由用戶繼承實(shí)現(xiàn),由于多態(tài)的存在,回調(diào)的是實(shí)現(xiàn)類的方法。

使用虛函數(shù)定義回調(diào)接口簡(jiǎn)單直接,但同樣存在和調(diào)用接口中使用虛函數(shù)同樣的弊端:虛函數(shù)調(diào)用開銷,二進(jìn)制兼容性差。

函數(shù)指針

函數(shù)指針是C語言的方式,使用函數(shù)指針定義Network接口類如下:

class Network 
{
public:
typedef void (*OnReceive)(const std::string& message, void* arg);

bool send(const char* host,
uint16_t port,
const std::string& message);

void registerListener(OnReceive listener, void* arg);
}

使用函數(shù)指針定義C++回調(diào)接口簡(jiǎn)單高效,但只適用于回調(diào)接口中只有一個(gè)回調(diào)函數(shù)的情形,如果Listener接口類中要增加onConnect,onDisconnect等回調(diào)方法,單個(gè)函數(shù)指針無法實(shí)現(xiàn)。另外函數(shù)指針不太符合面向?qū)ο蟮乃枷耄梢該Q成下面要介紹的std::function。

std::function

std::function提供對(duì)可調(diào)用對(duì)象的抽象,可封裝簽名相符的任意的可調(diào)用對(duì)象。使用std::function定義Network接口類如下:

class Network 
{
public:
typedef std::function<void(const std::string& message)> OnReceive;

bool send(const char* host,
uint16_t port,
const std::string& message);

void registerListener(const OnReceive& listener);
}

std::function可以很好的取代函數(shù)指針,配合std::bind,具有很好的通用性,因而被廣受推崇。但std::function同樣只適用于回調(diào)接口中只有一個(gè)回調(diào)方法的情形。另外,std::function比較重量級(jí),使用上面的便利卻會(huì)帶來了性能上的損失,有人做過性能對(duì)比測(cè)試,std::function大概比普通函數(shù)慢6倍以上,比虛函數(shù)還慢。

類成員函數(shù)指針

類成員函數(shù)指針的使用比較靈活,使用類成員函數(shù)指針定義Network接口類如下:

class Network 
{
public:
class Listener
{
public:
void onReceive(const std::string& message);
}

typedef void (Listener::* OnReceive)(const std::string& message);

bool send(const char* host,
uint16_t port,
const std::string& message);

void registerListener(Listener* listener, OnReceive method);

template<typename Class>
void registerListener(Class* listener,
void (Class::* method)(const std::string& message)
{
registerListener((Listener*)listener, (OnReceive)method);
}
}

因?yàn)轭惓蓡T函數(shù)指針必須和類對(duì)象一起使用,所以Network的注冊(cè)接口需要同時(shí)提供對(duì)象指針和成員函數(shù)指針,registerListener模板函數(shù)可注冊(cè)任意類的對(duì)象和相應(yīng)符合簽名的方法,無需繼承Listener,與接口類解耦。

使用類成員函數(shù)指針定義C++回調(diào)接口靈活高效,可實(shí)現(xiàn)與接口類解耦,并且不破壞面向?qū)ο筇匦裕珊芎玫娜〈鷤鹘y(tǒng)的函數(shù)指針的方式。

類成員函數(shù)指針同樣只適用于回調(diào)接口中只有一個(gè)回調(diào)方法的情形,如果有多個(gè)回調(diào)方法,需要針對(duì)每一個(gè)回調(diào)方法提供一個(gè)類成員函數(shù)指針。那么有沒有方法既能實(shí)現(xiàn)與接口類解耦,又能適用于多個(gè)回調(diào)方法的場(chǎng)景呢?參考下面介紹的非侵入式接口。

四 非侵入式接口

Rust中的Trait功能非常強(qiáng)大,可以在類外面,不修改類代碼,實(shí)現(xiàn)一個(gè)Trait,那么C++能否實(shí)現(xiàn)Rust的Trait的功能呢?還是以Network接口為例,假設(shè)現(xiàn)在Network發(fā)送需要考慮序列化,重新設(shè)計(jì)Network接口,示例如下:

定義Serializable接口:

class Serializable 
{
public:
virtual void serialize(std::string& buffer) const = 0;
};

Network接口示例:

class Network 
{
public:
bool send(const char* host,
uint16_t port,
const Serializable& s);
}

Serializable接口相當(dāng)于Rust中的Trait,現(xiàn)在一切實(shí)現(xiàn)了Serializable接口的類的對(duì)象均可以通過Network接口發(fā)送。那么問題來了,能否在不修改類的定義的同時(shí),實(shí)現(xiàn)Serializable接口呢?假如我們要通過Network發(fā)送int類型的數(shù)據(jù),能否做到呢?答案是肯定的:

class IntSerializable : public Serializable 
{
public:
IntSerializable(const int* i) :
intThis(i)
{

}

IntSerializable(const int& i) :
intThis(&i)
{

}

virtual void serialize(std::string& buffer) const override
{
buffer += std::to_string(*intThis);
}

private:
const int* const intThis;
};

有了實(shí)現(xiàn)了Serializable接口的IntSerializable,就可以實(shí)現(xiàn)通過Network發(fā)送int類型的數(shù)據(jù)了:

Network* network = Network::New(); 
int i = 1;
network->send(ip, port, IntSerializable(i));

Rust編譯器通過impl關(guān)鍵字記錄了每個(gè)類實(shí)現(xiàn)了哪些Trait,因此在賦值時(shí)編譯器可以自動(dòng)實(shí)現(xiàn)將對(duì)象轉(zhuǎn)換為相應(yīng)的Trait類型,但C++編譯器并沒有記錄這些轉(zhuǎn)換信息,需要手動(dòng)轉(zhuǎn)換類型。

 

非侵入式接口讓類和接口區(qū)分開來,類中的數(shù)據(jù)只有成員變量,不包含虛函數(shù)表指針,類不會(huì)因?yàn)閷?shí)現(xiàn)了N個(gè)接口而引入N個(gè)虛函數(shù)表指針;而接口中只有虛函數(shù)表指針,不包含數(shù)據(jù)成員,類和接口之間通過實(shí)現(xiàn)類進(jìn)行類型轉(zhuǎn)換,實(shí)現(xiàn)類充當(dāng)了類與接口之間的橋梁。類只有在充當(dāng)接口用的時(shí)候才會(huì)引入虛函數(shù)表指針,不充當(dāng)接口用的時(shí)候沒有虛函數(shù)表指針,更符合C++的零開銷原則。

【本文為51CTO專欄作者“阿里巴巴官方技術(shù)”原創(chuàng)稿件,轉(zhuǎn)載請(qǐng)聯(lián)系原作者】

??戳這里,看該作者更多好文??

 

責(zé)任編輯:武曉燕 來源: 51CTO專欄
相關(guān)推薦

2010-01-26 09:50:30

C++接口

2010-01-14 17:13:53

C++接口

2010-02-03 16:35:45

C++回文

2010-02-03 10:50:33

C++多態(tài)

2025-05-23 08:15:00

C++constexpr字面類型

2010-02-03 17:23:27

C++使用接口

2010-01-18 14:41:52

Visual C++開

2010-01-27 15:54:49

C++實(shí)現(xiàn)程序

2010-02-01 16:54:18

C++打印地址信息

2010-02-04 11:23:25

C++反射機(jī)制

2010-01-22 13:59:34

Visual C++應(yīng)

2010-02-01 14:21:24

C++初始化列表

2010-02-03 09:59:42

C++文件流操作

2010-03-05 16:56:42

Python綁定C++

2022-04-18 12:29:18

C++

2023-05-09 07:38:57

jQueryAjax代碼

2021-10-11 11:53:07

C++接口代碼

2014-01-02 10:46:35

PostgreSQLC++

2023-10-30 10:29:50

C++最小二乘法

2020-08-07 17:41:37

主流固態(tài)硬盤
點(diǎn)贊
收藏

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

国内精品麻豆美女在线播放视频| 爱爱爱免费视频在线观看| 欧美激情综合色综合啪啪| 欧美xxxxxxxx| 少妇高潮毛片色欲ava片| 男人的天堂在线视频| 奇米影视在线99精品| 久久综合伊人77777蜜臀| 中文在线观看免费视频| 日韩大片欧美大片| 亚洲精品国产无套在线观 | 亚洲一区二区av| 亚洲国产精品嫩草影院| 亚洲精品在线视频观看| 欧美熟妇另类久久久久久不卡| 日本vs亚洲vs韩国一区三区二区| 九九九久久久久久| 欧美精品日韩在线| 欧美三级午夜理伦三级小说| 欧美丰满美乳xxx高潮www| 免费看一级大黄情大片| h网站久久久| 国产欧美在线观看一区| 国产在线精品二区| 国产免费黄色片| 日韩1区2区3区| 97视频免费在线观看| 国产成人自拍网站| 精品国产一区二区三区久久久樱花 | 自拍偷拍亚洲在线| 99久久人妻无码精品系列| 中文字幕区一区二区三| 欧美肥胖老妇做爰| 91福利国产成人精品播放| 忘忧草在线日韩www影院| 夜夜精品浪潮av一区二区三区| 亚洲一卡二卡区| 国产区在线视频| 久久久久久免费网| 精品一区在线播放| 视频一区二区免费| 国产91精品入口| 99久久免费国| 亚洲黄色在线播放| 粉嫩av一区二区三区粉嫩| 91视频国产高清| 国产精品无码免费播放| 久久国产精品无码网站| 国产精品视频播放| 亚洲午夜无码久久久久| 日韩精品一卡二卡三卡四卡无卡| 欧美与黑人午夜性猛交久久久| 日韩三级免费看| 激情综合电影网| 久久久女女女女999久久| 欧美日韩在线观看免费| 午夜日韩在线| 欧美黄色www| 久久久久久久久久久久国产| 欧美日本二区| 韩国美女主播一区| 可以在线观看av的网站| 亚洲一区国产一区| 日本成人免费在线| 无码人妻av一区二区三区波多野| 老鸭窝毛片一区二区三区| 国产成人精品视频| 在线免费观看av片| 国产精品1024| 国产有色视频色综合| 欧美孕妇性xxxⅹ精品hd| 国产亚洲综合性久久久影院| 亚洲成人在线视频网站| 黄色精品免费看| 亚洲综合男人的天堂| www..com日韩| 日韩免费电影| 欧美一区二区三区在线视频| 少妇熟女视频一区二区三区| 色婷婷精品视频| 中文字幕久精品免费视频| 国产精品精品软件男同| 亚洲无线一线二线三线区别av| 97国产精品视频人人做人人爱| 中国一级免费毛片| 青青国产91久久久久久| 91影视免费在线观看| 三级在线观看网站| 欧美精彩视频一区二区三区| 黑人巨大国产9丨视频| a毛片不卡免费看片| 欧美曰成人黄网| 中文字幕永久免费| 精品国产精品久久一区免费式| 久久中文字幕在线| 日韩在线视频免费播放| 九一久久久久久| 国产一区二区在线观看免费播放| 国产高清自拍视频在线观看| 悠悠色在线精品| 无遮挡又爽又刺激的视频 | 国产在线欧美| 国产精品video| www.国产黄色| 欧美高清在线视频| 你真棒插曲来救救我在线观看| 欧亚一区二区| 亚洲韩国欧洲国产日产av| 欧美自拍偷拍网| 国产一区二区三区久久| 国产在线日韩在线| 蜜桃成人在线视频| 一二三四社区欧美黄| 91最新在线观看| 国产精品白浆| 成年无码av片在线| 国产女优在线播放| 久久你懂得1024| 久久精品无码中文字幕| 日本一区二区中文字幕| 亚洲欧美激情一区| 五月天婷婷网站| 国产在线观看免费一区| 色乱码一区二区三在线看| 免费成人在线电影| 欧美成人激情免费网| 中文字幕91视频| 久久中文在线| 你懂的网址一区二区三区| 黑人另类精品××××性爽| 制服丝袜日韩国产| 娇小11一12╳yⅹ╳毛片| 午夜在线精品偷拍| 精品视频一区二区| mm视频在线视频| 日韩欧美视频一区| 午夜精品福利在线视频| 精品写真视频在线观看| 天堂资源在线亚洲资源| 天天综合网天天| 日韩久久精品电影| 国产www在线| jlzzjlzz国产精品久久| 99在线免费视频观看| 视频一区中文字幕精品| 欧美成人免费在线视频| 国产精品午夜福利| 亚洲欧洲综合另类在线| 中文字幕 日韩 欧美| 色喇叭免费久久综合| 国产精品视频精品| 色综合久久影院| 欧美三级视频在线观看| 妖精视频在线观看免费| 开心九九激情九九欧美日韩精美视频电影 | 欧美牲交a欧美牲交aⅴ免费真| 久久九九热re6这里有精品| 国内外成人免费激情在线视频网站 | 亚洲欧美日韩在线一区| 久久免费激情视频| 久久九九影视网| 精品999在线| 欧美黄色录像片| 97se亚洲综合| 蜜臀久久精品| 一区二区三区四区精品| 在线播放精品视频| 亚洲精品欧美在线| 国产精品扒开腿做爽爽爽a片唱戏| 日韩亚洲精品在线| 欧美三级华人主播| 欧美一级做a| 欧美激情视频在线观看| 韩国av免费在线观看| 偷拍日韩校园综合在线| 在线观看日本中文字幕| 国产真实乱对白精彩久久| 国产一区二区三区乱码| 伊人成综合网yiren22| 国产精品美乳一区二区免费 | 精品久久久久久久久久久下田| 国产在线高清精品| 麻豆福利在线观看| 亚洲一区av在线播放| 国产麻豆免费视频| 精品成人国产在线观看男人呻吟| 欧美特级黄色录像| 国产精品一区二区免费不卡| 男人用嘴添女人下身免费视频| 狠狠做六月爱婷婷综合aⅴ| 亚洲www在线| 中文在线а√在线8| www.国产精品一二区| 成人午夜免费在线观看| 欧美亚洲高清一区| 国产精品第72页| 国产精品久久久久一区二区三区| 久久久久中文字幕亚洲精品| 久久精品综合| 嫩草影院中文字幕| 成人影院天天5g天天爽无毒影院| 成人综合色站| 青青在线精品| 热久久99这里有精品| 牛牛精品在线视频| 久久久精品国产| 激情小说 在线视频| 精品国产乱码久久久久久1区2区| 亚洲av无码乱码国产精品fc2| 亚洲影院久久精品| 激情无码人妻又粗又大| 91久色porny| 亚洲乱妇老熟女爽到高潮的片| 日韩va欧美va亚洲va久久| 国产欧美日韩网站| 自拍偷拍欧美| 亚洲在线色站| 精品国产一区二区三区香蕉沈先生| 成人一区二区三区四区| 色狠狠一区二区三区| 国产成人免费av电影| h片在线观看视频免费免费| 久久69精品久久久久久久电影好 | 国产女人18毛片水18精品| 色综合亚洲图丝熟| 久久人人爽人人爽人人片av高请| bt在线麻豆视频| 色噜噜狠狠色综合网图区| 国产高清在线| 亚洲男人的天堂在线| 天天爽夜夜爽夜夜爽| 日韩视频一区在线观看| 97人妻精品一区二区三区| 在线观看欧美黄色| 一级成人黄色片| 婷婷综合久久一区二区三区| 久久综合综合久久| 亚洲综合一二三区| 九九热视频精品| 一区二区三区四区在线播放| www深夜成人a√在线| 一色屋精品亚洲香蕉网站| 美国美女黄色片| 亚洲国产高清aⅴ视频| 国产人妻大战黑人20p| 国产欧美va欧美不卡在线| 少妇人妻好深好紧精品无码| 欧美激情中文不卡| 日本精品久久久久中文| 国产精品天干天干在线综合| 娇妻被老王脔到高潮失禁视频| 久久久精品天堂| 精品人妻中文无码av在线| 国产欧美日韩一区二区三区在线观看| 亚洲 小说 欧美 激情 另类| 久久精品一区二区三区不卡| 一道本在线观看| 中文字幕不卡的av| 免费看特级毛片| 一区二区视频在线看| 国产成人啪精品午夜在线观看| 亚洲妇女屁股眼交7| 久久黄色精品视频| 狠狠躁夜夜躁人人躁婷婷91| 男人的天堂av网站| 欧美乱妇23p| 黄色www视频| 亚洲男人第一网站| 天堂中文а√在线| 色在人av网站天堂精品| 国产盗摄——sm在线视频| 日本久久久久久久久久久| 欧洲成人一区| 成人激情在线观看| 国产毛片久久久| 欧美性xxxx69| 911精品美国片911久久久 | 亚洲AV成人无码网站天堂久久| 成人免费在线视频观看| 男人av资源站| 亚洲影视在线播放| 午夜精品免费观看| 7777精品伊人久久久大香线蕉的| 亚洲精品无码专区| 国产午夜精品视频| 丝袜综合欧美| 国产福利视频一区二区| 亚洲国产一区二区三区网站| 精品国产免费人成电影在线观... 精品国产免费久久久久久尖叫 | 在线中文字幕一区| 精品人妻av一区二区三区| 亚洲精品二三区| av每日在线更新| 欧美极品欧美精品欧美视频 | 91在线观看网站| 欧美人与拘性视交免费看| 日韩国产精品毛片| 可以免费看不卡的av网站| wwwxxx色| 中文字幕不卡的av| 欧美三级一区二区三区| 7777精品伊人久久久大香线蕉最新版| 无码国产精品高潮久久99| 久久久999精品视频| 一区二区三区短视频| 91精品国产综合久久久久久丝袜| 成人性生交大片免费看96| 亚洲五月六月| 亚洲乱码视频| 99视频在线观看视频| 国产视频亚洲色图| 日韩免费不卡视频| 欧美一级欧美三级在线观看| 国模吧精品人体gogo| 国内免费精品永久在线视频| 韩国三级大全久久网站| 色之综合天天综合色天天棕色| 99亚洲一区二区| 黄色片子免费看| 国产精品丝袜在线| 午夜影院免费在线观看| 亚洲国产精品一区二区三区| 亚洲婷婷噜噜| 91亚洲精品久久久| 97视频热人人精品免费| 美女喷白浆视频| 91麻豆国产自产在线观看| 国产亚洲精品成人| 欧美一区二区三区视频免费| 午夜视频在线观看网站| 国产成人一区二区| 国产乱码精品一区二区亚洲| 无码aⅴ精品一区二区三区浪潮| 国产91丝袜在线播放0| 91精品一区二区三区蜜桃| 欧美日韩一区二区三区四区 | 欧美性受xxxx白人性爽| 激情小说亚洲图片| 日韩xxxx视频| 成人高清伦理免费影院在线观看| 久久精品一区二区三| 日韩欧美中文字幕制服| 91三级在线| 99精品欧美一区二区三区| 欧美精品网站| 国产xxx在线观看 | 久久综合久久网| 成人性视频免费网站| 久久精品无码人妻| 亚洲国产精品美女| 综合日韩av| 日韩福利一区二区三区| 另类小说欧美激情| 国产av 一区二区三区| 精品三级在线观看| 51漫画成人app入口| 精品久久蜜桃| 羞羞视频在线观看欧美| www.黄色在线| 欧美巨大另类极品videosbest | 国产美女一区| 亚洲女优在线观看| 欧美老肥妇做.爰bbww| 在线电影福利片| 国产一区二区中文字幕免费看| 国产精品亚洲综合久久| 非洲一级黄色片| 69堂精品视频| 97人人在线视频| 日本在线观看一区二区三区| 美女视频黄久久| 欧美日韩在线观看免费| 日韩av中文字幕在线免费观看| 99re66热这里只有精品4| 天天综合中文字幕| 成人v精品蜜桃久久一区| 亚洲AV无码成人精品区东京热| 色午夜这里只有精品| 日韩精品成人在线观看| 欧美黑人经典片免费观看| 国产精品美女久久久久久2018 | 风流少妇一区二区| 日本高清不卡码| 日韩中文字幕网站| 哺乳一区二区三区中文视频| 日韩视频第二页| 国产精品成人在线观看| 蜜臀久久精品久久久久| 国产精品第七十二页| 欧美日韩精品| 日韩影视一区二区三区| 日韩欧美aaaaaa| 激情开心成人网| 亚洲天堂第一区| 久久九九影视网| 亚洲AV无码国产精品午夜字幕| 日韩美女免费视频| 欧美在线高清| 欧美18—19性高清hd4k| 欧美xxxxxxxx|