色夜影院Iav高清一区I久草在线观看资源I00av视频I国产在线观看avI九九九在线I国产香蕉97碰碰久久人人I成人在线观看免费视频

行業(yè)動(dòng)態(tài)

當(dāng)前位置:首頁(yè)>>新聞中心>>行業(yè)動(dòng)態(tài) 發(fā)布時(shí)間:2017-08-17 04:59:19

工廠(chǎng)設(shè)計(jì)模式在多串口通信中的應(yīng)用

時(shí)間:2017-08-17 04:59:19 來(lái)源:本站 點(diǎn)擊數(shù):808

設(shè)計(jì)模式/軟件設(shè)計(jì)模式Oesign pattern)是軟件設(shè)計(jì)過(guò)程中的經(jīng)驗(yàn)總結(jié)。可 以讓程序代碼易重用、易理解、更穩(wěn)定。目前總結(jié)出來(lái)的模式有23種之多,文中主要涉及工廠(chǎng)模式在多串口通信軟件開(kāi)發(fā)中的應(yīng)用。作者針對(duì)衡器稱(chēng)重系統(tǒng)中常用的儀表、一機(jī)一

秤、一機(jī)多秤等應(yīng)用場(chǎng)景,提出相應(yīng)的解決方案。

1.引言

在軟件開(kāi)發(fā)過(guò)程中,常常會(huì)碰到相似問(wèn)題, 做重復(fù)的工作。如何提高效率,保證代碼的可靠 性,可重用性昵?前人總結(jié)出了很多軟件開(kāi)發(fā)模 式,來(lái)解決相應(yīng)的問(wèn)題。文中將針對(duì)“軟件設(shè)計(jì) 模式”工廠(chǎng)模式”在多串口通信軟件開(kāi)發(fā)中 的應(yīng)用展開(kāi)描述。

2.設(shè)計(jì)模式簡(jiǎn)介

設(shè)計(jì)模式(Oesign patten)是一套被反復(fù)使用 的、多數(shù)人知曉的、經(jīng)過(guò)分類(lèi)編目的、代碼設(shè)計(jì) 經(jīng)驗(yàn)的總結(jié)。使用設(shè)計(jì)模式是為了重用代碼、讓 代碼更容易被他人理解、保證代碼可靠性。最早 提出設(shè)計(jì)模式思想是在1994年,由Erich Gamma 等人,在其所著的《面象對(duì)象的可復(fù)用元素》一 書(shū)中提出的??偨Y(jié)出三大類(lèi)別創(chuàng)建型模式、結(jié) 構(gòu)型模式、行為型模式,六大原則(開(kāi)閉原則、 里氏原則、依賴(lài)倒置原則、接口隔離原則、迪米 特法則、合成復(fù)用原則,23種設(shè)計(jì)模式俱體內(nèi) 容請(qǐng)參看相關(guān)書(shū)籍。本文將重點(diǎn)介紹:工廠(chǎng)設(shè)計(jì) 模式。它屬于創(chuàng)建型模式即在創(chuàng)建對(duì)象的過(guò) 程中,隱藏創(chuàng)建邏輯,這使得程序在創(chuàng)建給定實(shí) 例對(duì)象時(shí),可以提供靈活的判斷。

3.衡器軟件中的問(wèn)題

作者長(zhǎng)期從事衡器稱(chēng)重軟件的設(shè)計(jì)。在長(zhǎng)期 的工作經(jīng)歷中,參與了很多項(xiàng)目,其中多數(shù)都會(huì) 用到串口通信。會(huì)遇到以下幾種典型的應(yīng)用問(wèn)題:

1)在使用衡器儀表時(shí),串口是常見(jiàn)的對(duì)外通 信方式。稱(chēng)重儀表廠(chǎng)家多,型號(hào)不一,通信格式 各不相同。能不能使用統(tǒng)一的開(kāi)發(fā)模式,進(jìn)行管 理,減少重復(fù)性的工作昵?

2)地磅稱(chēng)重管理中,有一機(jī)一秤也有 機(jī)多秤的模式。在多秤同時(shí)使用時(shí),儀表型 號(hào)可能相同,也可能不同,有沒(méi)有簡(jiǎn)潔、高效的 擴(kuò)展軟件代碼的方法昵?

4.工廠(chǎng)設(shè)計(jì)模式

針對(duì)上述問(wèn)題,作者通過(guò)實(shí)踐和總結(jié),覺(jué)得軟件開(kāi)發(fā)模式的中的工廠(chǎng)模式”比較適合解決 這類(lèi)問(wèn)題。

什么是工廠(chǎng)模式?顧名思義,就是客戶(hù)提 訂單,交給工廠(chǎng)生產(chǎn),最后得到“產(chǎn) 品”。工廠(chǎng)模式模擬了這個(gè)過(guò)程。“工廠(chǎng)模 式”分為三種子類(lèi)別:簡(jiǎn)單工廠(chǎng)、工廠(chǎng)方法、抽 象工廠(chǎng)。這三種方法,本質(zhì)相同,但各有其應(yīng)用 場(chǎng)景,簡(jiǎn)單來(lái)說(shuō),如下:

1)簡(jiǎn)單工廠(chǎng):一個(gè)工廠(chǎng)生產(chǎn)多種不同產(chǎn)品。

2)工廠(chǎng)方法:多個(gè)工廠(chǎng),每個(gè)工廠(chǎng)生產(chǎn)一種 產(chǎn)品。是對(duì)簡(jiǎn)單工廠(chǎng)的改進(jìn),因?yàn)?/span>“簡(jiǎn)單工 廠(chǎng)”不符合開(kāi)閉原則”。

3)抽象工廠(chǎng):多個(gè)工廠(chǎng),每個(gè)工廠(chǎng)生產(chǎn)一種 或多種產(chǎn)品??梢愿鶕?jù)訂單需求,生產(chǎn)“產(chǎn) 品”訂單中可能存在多種不同的產(chǎn)品”需 求,可以交給不同的“工廠(chǎng)來(lái)生產(chǎn)”。

這三種模式都能解決衡器軟件中的儀表串口 通信問(wèn)題。文中重點(diǎn)講解簡(jiǎn)單工廠(chǎng)“抽象 工廠(chǎng)”這兩種模式,這兩種模式比較容易理解, 其它的模式也可依此類(lèi)推。

5.面向?qū)ο蟮膶?shí)現(xiàn)過(guò)程

設(shè)計(jì)模式的運(yùn)用與編程語(yǔ)言無(wú)關(guān)。作者以常 用的C++語(yǔ)言為例,說(shuō)明面向?qū)ο蟮姆庋b過(guò)程。

首先,作者封裝了一組串口通信類(lèi),將串口 通信過(guò)程中,常用的的方法,封裝在一個(gè)類(lèi)族里, 為后期模式設(shè)計(jì)提供基礎(chǔ)如圖1所示。

云網(wǎng)客1.jpg

串口類(lèi)庫(kù)可根據(jù)需要不斷擴(kuò)展,封裝好后, 與下文的設(shè)計(jì)模式類(lèi)隔離,減少代碼耦合。這個(gè) 類(lèi)族中的底層子類(lèi),相當(dāng)于工廠(chǎng)”里生產(chǎn)的產(chǎn)品

1)簡(jiǎn)單工廠(chǎng)的實(shí)現(xiàn)過(guò)程

簡(jiǎn)單工廠(chǎng)模式如圖2所示,將產(chǎn)品”實(shí)例的創(chuàng)建放到工廠(chǎng)方法中完成,從而為產(chǎn)品的選擇提供靈活性。這里的產(chǎn)品就是儀表型號(hào),工廠(chǎng)就是 TMeterFactory 類(lèi),其方法 CreateMeter 可以創(chuàng)建各種儀表的實(shí)例。

云網(wǎng)客2.jpg

主要部分的偽代碼如下:

#include

classTM eterfactory//儀表工廠(chǎng)類(lèi)

{

Private:

m apm _m eter;// 管理 所有的儀表對(duì)象 public

TM eterfactory0;

ICommO bject*C reateM eter (char*strM eter- Name);//創(chuàng)建儀表實(shí)例方法

~TM eterFactoryO;//銷(xiāo)毀儀表類(lèi)實(shí)例

}

ICommObject*TM eterFactory::CreateM eter (char*strM eterN am e)

{ //檢查儀表實(shí)例是否存在 ifm _m eter.end )!=m _m eter.find (strM eterN am e)) return m_m eter.find strM eterN am e)->second; //創(chuàng)建新的儀表實(shí)例 ICommO bject*pM eter=N ULL; if(!strcm p "X K 3190A 9",strM eterN am e)) pM eter=new TXK3190A9 0; else return NULL;

...//繼續(xù)添加代碼,創(chuàng)建其他儀表型號(hào) m_meter.insert std ^pa ir rM eterN am e,pM eter)); return pMeter;

}

客戶(hù)端調(diào)用代碼如下 charweight[10]={0};

TMeterFactory*pFactory=new TMeterFactory;

 

ICommObject*pMeter=pFactory->CreateMe-

 

ter(“XK3190A9”);

 

strcpy(weight,pMeter->read());// 讀取重量,中間省略 open,write,close 等方法代碼

 

上述過(guò)程中,可以看到:在使用簡(jiǎn)單工廠(chǎng)模式 (或其它模式) 時(shí),并不一定能減少代碼量,但是易于后期擴(kuò)展和理解。從客戶(hù)端的調(diào)用代碼可以看出:模式提供了統(tǒng)一的接口,調(diào)用者只要給出儀表型號(hào),就能得到相應(yīng)的類(lèi)實(shí)例。實(shí)例創(chuàng)建過(guò)程封裝到其他代碼塊中,只要那部分代碼沒(méi)有問(wèn)題,調(diào)用者就能得到正確的結(jié)果,相當(dāng)于黑盒操作。這種方式,適合多人分工合作,共同開(kāi)發(fā)軟件。

 

(2) 抽象工廠(chǎng)的實(shí)現(xiàn)過(guò)程

 

簡(jiǎn)單工廠(chǎng)模式適合一機(jī)一秤的稱(chēng)重軟件開(kāi)發(fā)。抽象工廠(chǎng)模式適合解決一機(jī)多秤的稱(chēng)重模式。他將儀表實(shí)例創(chuàng)建過(guò)程推遲到子類(lèi)中完成,從而為訂單中的多種產(chǎn)品組合提供機(jī)會(huì)。以下是一機(jī)一秤一機(jī)兩秤類(lèi)圖如圖 3 所示。

云網(wǎng)客3.jpg

由上圖可以看出,每一個(gè)工廠(chǎng)代表一種稱(chēng)重模式,可以從一機(jī)一秤,擴(kuò)展到一機(jī) n 。而每一種稱(chēng)重模式中,可以用同一種型號(hào)的儀表,也可以用不同種型號(hào)的儀表組成系統(tǒng)。具

 

體實(shí)施時(shí),可根據(jù)需求選擇。C++ 偽代碼如下: class ICommObject;

 

class IFactory // 抽象工廠(chǎng)

 

{

 

public:

virtual ICommObject * CreateMeter1()=0; // 創(chuàng)建儀表 1,此處為純虛方法

 

virtual ICommObject * CreateMeter2 ()=0; // 創(chuàng)建儀表 2

 

// 可以繼續(xù)添加 protected:

 

IFactroy();

 

};

 

Class TOne_pc_and_one_scale:public IFactory// 具體工廠(chǎng):實(shí)現(xiàn)一機(jī)一秤功能

 

{

 

public:

 

ICommObject * CreateMeter1 () {return new TXK3190A9;}

 

};

 

Class TOne_pc_and_two_scale:public IFactroy// 具體工廠(chǎng):實(shí)現(xiàn)一機(jī)兩秤功能

 

{

 

public:

 

ICommObject * CreateMeter1(){return new

 

T8142pro;}

 

ICommObject * CreateMeter2(){return new

 

XK3180;}

 

};

 

客戶(hù)端調(diào)用代碼如下: // 一機(jī)一秤調(diào)用方法

char weight_A9[10]={0};// 重量字符串

 

IFactory * pScale=new TOne_pc_and_one_scale;

 

ICommObject * pA9=pScale->CreateMeter1();

 

strcpy(weight,pA9->read());// 讀取重量到 weight

 

中,中間省略 open,write,close 等方法代碼

 

 

// 一機(jī)兩秤調(diào)用方法 char weight_8142[10]={0},weight_3180[10]={0};//

重量字符串

 

IFactory * pScale=new TOne_pc_and_two_scale; // 創(chuàng)建工廠(chǎng)實(shí)例

ICommObject * p3180=pScale->CreateMeter1(); ICommObject * p8142=pScale->CreateMeter2(); strcpy (weight_3180,p3180->read ());// 讀取重量

到 weight_A9 中,中間省略 open,write,close 等方法代碼

 

strcpy (weight_8142,p8142->read ()); // 讀取重量到 weight_814

 

使用抽象工廠(chǎng)模式,在添加新的工廠(chǎng)時(shí),并不影響已有的工廠(chǎng)代碼,已有的代碼基本不需改動(dòng),提高了程序的穩(wěn)定性,符合開(kāi)

閉原則,因此成為 23 種軟件設(shè)計(jì)模式之一。

 

6.工廠(chǎng)模式在稱(chēng)重傳感器溫度測(cè)試軟件中的應(yīng)用

 

作者在編寫(xiě) 《傳感器溫度測(cè)試軟件》 的過(guò)程中,使用了數(shù)據(jù)采集板,每個(gè)板上有一個(gè)串口,多塊板同時(shí)向上位機(jī)發(fā)送傳感器的實(shí)時(shí)溫度測(cè)量數(shù)據(jù)。利用抽象工廠(chǎng)設(shè)計(jì)模式,很好的完成了軟件編寫(xiě)。原來(lái)在其他軟件中的通信代碼 (即圖 1),移植過(guò)來(lái)使用,進(jìn)行部分?jǐn)U展,實(shí)現(xiàn)了代碼重用。軟件可以對(duì)每一個(gè)串口的通信數(shù)據(jù)和通信參數(shù),進(jìn)行單獨(dú)的管理。如下圖:

云網(wǎng)客6.jpg

7.相關(guān)問(wèn)題討論

Windows 系統(tǒng)中,某個(gè)串口設(shè)備,在某一時(shí)刻,只能被一個(gè)軟件使用 (虛擬串口設(shè)備除外)。多個(gè)進(jìn)程或線(xiàn)程同時(shí)使用,會(huì)產(chǎn)生沖突。沖突的情況分為三種:

(1) 兩個(gè) (或兩個(gè)以上) 不同的軟件,同時(shí)打開(kāi)同一個(gè)串口

(2) 同一個(gè)軟件,運(yùn)行兩次實(shí)例 (或兩次以上) 在內(nèi)存中,同時(shí)打開(kāi)同一個(gè)串口

(3) 同一個(gè)軟件,運(yùn)行一次,但在軟件內(nèi)部?jī)纱危ɑ騼纱我陨希?打開(kāi)同一個(gè)串口

②兩種情況涉及不同進(jìn)程之間的資源搶占的沖突,可以考慮用進(jìn)程互斥的方法解決,不屬于軟件模式的解決范疇

對(duì)于第③種情況,可用“單例模式解決軟件內(nèi)部多次、同時(shí)讀、寫(xiě)同一個(gè)串口沖突的問(wèn)題。

單例模式的目標(biāo)就是:每個(gè)類(lèi)只能創(chuàng)建一個(gè)實(shí)例。類(lèi)的構(gòu)造函數(shù)拷貝構(gòu)造函數(shù)設(shè)為私有保護(hù)權(quán)限,類(lèi)實(shí)例由其靜態(tài)成員函數(shù)創(chuàng)建。

文中的工廠(chǎng)模式也涉及到串口的調(diào)用,因此可能有人會(huì)問(wèn):工廠(chǎng)模式能否結(jié)合單例模式同時(shí)使用呢?答案是否定的。單例模式封裝的對(duì)象是串口硬件實(shí)體。本文中的工廠(chǎng)模式是以稱(chēng)重儀表為對(duì)象,進(jìn)行封裝。兩者的出發(fā)點(diǎn)和角度不同,雖然都用到了串口通信,但是功能需求不同。物理串口,同一時(shí)刻,只能被一個(gè)實(shí)例使用,因此用單例模式比較合理。而稱(chēng)重儀表類(lèi),則存在多臺(tái)相同型號(hào)的儀表同時(shí)使用的情況,所以需要?jiǎng)?chuàng)建同一個(gè)類(lèi)的多個(gè)實(shí)例。這些屬于面對(duì)的編程思想,需要結(jié)合實(shí)踐去體會(huì)他們的異同。

8.總結(jié)

在軟件設(shè)計(jì)過(guò)程中,不僅衡器稱(chēng)重軟件一機(jī)多秤(即一臺(tái)上位機(jī),多臺(tái)稱(chēng)重儀表同時(shí)工作),可以使用工廠(chǎng)模式來(lái)設(shè)計(jì),其它類(lèi)似的涉及多臺(tái)儀表,多個(gè)串口同時(shí)工作的軟件,都可參考這種模式。軟件模式的使用,使代碼易于閱讀,管理,能提高代碼的重用效率。實(shí)際軟件開(kāi)發(fā)中,具體使用哪種模式,是一種模式,還是多種模式混合使用?對(duì)于開(kāi)發(fā)者來(lái)說(shuō),需要有一定行業(yè)經(jīng)驗(yàn),總結(jié)出用戶(hù)的需求,整理出規(guī)律性的內(nèi)容,再選擇合適開(kāi)發(fā)模式,才能找到一條正確的道路。

 

 


中文字幕在线观看免费高清电影 | www.888av | 日日操天天爽 | 国产精品99爱| 久久精品一二三区 | 四虎在线免费观看 | 欧美日韩亚洲在线观看 | 国产精品高潮久久av | 婷婷亚洲最大 | 亚洲精品视频在线播放 | 免费三级av | 一级特黄aaa大片在线观看 | 国产美女免费观看 | 成人在线播放免费观看 | 日日麻批40分钟视频免费观看 | 日韩欧美高清在线观看 | 一区二区激情视频 | 免费观看特级毛片 | 日韩小视频网站 | 91九色在线播放 | 热九九精品 | 亚洲欧洲成人精品av97 | 人人澡人摸人人添学生av | a在线观看国产 | 中文字幕精品一区二区三区电影 | 91精品国产麻豆 | 国产在线高清 | 在线视频黄 | 二区三区在线视频 | 三级黄色网络 | 99精品视频在线看 | 香蕉视频国产在线 | 国产九九在线 | 日韩欧美黄色网址 | 婷婷色在线资源 | 国产一级h| 91大神免费在线观看 | 日韩免费看片 | 久久大香线蕉app | 911精品美国片911久久久 | 日日操夜 | 亚洲一区日韩精品 | 69欧美视频 | 国产精品黄网站在线观看 | 91看片成人| 国内精品视频在线 | 99人久久精品视频最新地址 | 久久精品国产亚洲aⅴ | 五月婷婷中文字幕 | 成片免费观看视频999 | 日韩高清免费电影 | 色婷婷免费视频 | 日韩日韩日韩日韩 | 91麻豆精品国产自产 | 福利一区二区三区四区 | 国产精品国产亚洲精品看不卡15 | 国产毛片在线 | 波多野结衣日韩 | 贫乳av女优大全 | 黄网站大全 | 中文字幕在线观看视频免费 | 精品亚洲va在线va天堂资源站 | 国产精品免费视频观看 | 欧美另类激情 | 欧美日韩国产二区三区 | 激情文学丁香 | 在线视频你懂 | 国产精品国产三级国产aⅴ入口 | 国产粉嫩在线 | 麻豆超碰| 精品国产123| 精品一区中文字幕 | www天天干| 精品久久久久国产 | 日韩美在线观看 | 成年人免费观看在线视频 | 欧美日韩高清一区 | 99色视频 | 久久精品草 | 国产91粉嫩白浆在线观看 | 成人久久免费视频 | 一区二区三区www | 中文字幕一区在线 | 久久久久久久网 | 日韩在线三级 | 日韩大片在线看 | www日韩欧美 | 91精品国自产拍天天拍 | 婷婷五月在线视频 | 中文字幕色播 | 日韩在线视频一区 | 在线国产能看的 | 黄色免费大全 | 精品国产一二三 | 日本精品久久久久影院 | 五月天婷婷狠狠 | 黄色aaa级片 | 草久视频在线 | 久久久久日本精品一区二区三区 | 国产高清网站 | 91夫妻自拍 | 91在线视频在线观看 | av在线播放中文字幕 | 四虎最新入口 | 国产成人久 | 在线观看久久久久久 | 日韩一区二区免费在线观看 | 亚洲伊人成综合网 | 成人av午夜 | 最近免费中文字幕 | 久久久久电影 | 精品国产一区二区三区在线 | 成人在线视| 日韩精品视频免费在线观看 | 久久久久免费精品国产 | 久久综合久久88 | 最近最新mv字幕免费观看 | 久久久精品午夜 | www.av中文字幕.com | 在线视频 影院 | 91中文字幕在线 | 精品久久91| 久久久久国产精品一区二区 | 91精品久久久久久粉嫩 | 欧美精品三级在线观看 | 欧美福利在线播放 | 日韩毛片一区 | 91在线影院| 亚洲精品久久久久中文字幕m男 | 五月天激情婷婷 | 五月婷婷视频在线 | 超碰在线个人 | 在线播放精品一区二区三区 | 91亚色视频在线观看 | 中文资源在线官网 | 超碰人在线 | 久草综合在线观看 | 日韩精品高清不卡 | 超碰97在线资源 | 国产精品视频专区 | 狠狠久久| 韩日精品视频 | 亚洲一级在线观看 | 午夜影院先 | 国产精品久久久久久久免费大片 | 69国产盗摄一区二区三区五区 | 精品影院一区二区久久久 | 99久久久久久久 | 国产一区二区精品久久 | 天天爱天天操天天射 | 国产精品亚洲综合久久 | 日韩午夜大片 | 在线亚州 | 伊人狠狠 | 国产一区二区三区四区在线 | 五月天com | 97免费公开视频 | 亚洲天堂网在线观看视频 | 亚洲欧美成aⅴ人在线观看 四虎在线观看 | 国产精品高清在线观看 | 亚洲经典视频 | 午夜精品久久 | 国产91精品欧美 | 九九免费精品 | 久青草电影 | 国产综合香蕉五月婷在线 | 久久久久亚洲最大xxxx | japanesefreesexvideo高潮 | 国产精品视频久久 | 国产午夜精品免费一区二区三区视频 | 99精品国产一区二区三区麻豆 | 永久免费在线 | 精品国产免费人成在线观看 | 欧美在线一二区 | 婷婷5月激情5月 | 亚洲免费色| 97成人精品视频在线播放 | 日本一区二区三区免费观看 | 亚洲最大av在线播放 | 国产资源在线播放 | 亚洲最新av网址 | 国产精选在线 | 中国一区二区视频 | 国产高清av免费在线观看 | 免费久久久久久久 | zzijzzij日本成熟少妇 | 伊人色播 | av高清一区 | 999视频网站| 成人午夜电影在线播放 | www激情com| 国产高清视频在线 | 日日干夜夜操视频 | 久久久国产电影 | 中文字幕在线观看网址 | 久久精品国产一区 | 久久国产免费看 | 久久精品一区二区国产 | 国产欧美在线一区 | 中文字幕在线观看免费观看 | 国产精品一区二区三区在线 | 最新国产精品久久精品 | 日韩精品不卡 | 久久电影国产免费久久电影 | 草久在线 | 激情久久久久久久久久久久久久久久 | 操操操人人 | 国产一二区在线观看 | 国产黄色在线 | 天天色综合1 | 97精品国产91久久久久久久 | 天天综合亚洲 | 在线观看一区二区视频 | 久久精品第一页 | 中文字幕精品www乱入免费视频 | 久草久热 | 国产午夜精品免费一区二区三区视频 | 美女网站在线观看 | 午夜精品久久久久久久99 | 96视频在线 | 欧美精品亚洲精品 | 亚洲国内在线 | 一区二三国产 | 日日夜夜网 | 天天操人人干 | 国产剧情一区二区在线观看 | 亚洲一区美女视频在线观看免费 | 免费黄色在线播放 | 天天躁日日躁狠狠躁av麻豆 | 欧美日产在线观看 | 亚洲japanese制服美女 | 在线观看中文字幕一区二区 | 超碰人人av| 国产精国产精品 | 麻豆91在线观看 | 天天操月月操 | 日韩综合色 | 国产精品综合av一区二区国产馆 | 精品国产一区二区三区四区在线观看 | 欧美日韩免费观看一区二区三区 | 高清一区二区三区av | 中文字幕乱在线伦视频中文字幕乱码在线 | avwww在线| 国产一区成人在线 | 麻豆成人网 | 免费69视频 | 有码中文字幕在线观看 | 亚洲国产成人在线观看 | 91成版人在线观看入口 | 色www精品视频在线观看 | 中文永久字幕 | 91成人观看 | 日韩三级视频 | 在线看免费 | 性色av免费在线观看 | 天天操夜夜逼 | 男女男视频 | 九九久久婷婷 | 欧美亚洲国产精品久久高清浪潮 | 福利一区二区 | 激情 一区二区 | 日韩专区一区二区 | 久久精品首页 | 午夜黄色| 色国产视频 | www.天天成人国产电影 | 久久字幕精品一区 | av直接看 | 日本激情中文字幕 | 久久精彩 | 干狠狠| 婷婷激情在线 | 中文一区在线观看 | 超碰在线91 | 99激情网 | 久久婷亚洲五月一区天天躁 | 免费观看成人 | 天天天干夜夜夜操 | 毛片无卡免费无播放器 | 国产五月天婷婷 | 成人在线播放网站 | 欧美福利精品 | 色诱亚洲精品久久久久久 | 欧美极度另类性三渗透 | 日韩在线视频一区 | 91亚洲国产成人 | 日韩在线高清免费视频 | 亚洲精品国偷自产在线91正片 | 在线之家官网 | 久久精品综合视频 | 欧美精品久久久久久久久免 | 精品国产乱码久久久久 | 麻豆91网站 | 色婷婷影视 | 91精品国产综合久久福利不卡 | 成人久久久久久久久久 | 国产 日韩 在线 亚洲 字幕 中文 | 91精品国产自产在线观看 | 毛片无卡免费无播放器 | 久久久首页 | 久久久私人影院 | 欧美在线91 | 亚洲成人黄色在线 | 香蕉久草在线 | 97在线精品国自产拍中文 | 久久久资源 | 久久免费视频网站 | 免费在线观看成人av | 久久免费国产电影 | 91看片一区二区三区 | 日韩高清国产精品 | 国产黄a三级 | 久久精品com | 丁香六月婷 | 欧美极品少妇xbxb性爽爽视频 | 国内精品在线看 | 久久天堂影院 | 久久综合九色九九 | 日本黄色免费在线观看 | 99久久这里有精品 | 91色一区二区三区 | av在线免费不卡 | 黄色免费在线看 | 国产精品一区二区精品视频免费看 | 亚洲激情五月 | 91av中文 | 久久精品视频网址 | 亚洲日本国产精品 | 国产精品99久久免费黑人 | 婷婷六月中文字幕 | 久久精品久久精品 | 中国一级片免费看 | 欧美男同视频网站 | 久久爱www. | 欧美精品免费视频 | 三级黄色片子 | 久久久精品网站 | 日日操夜夜操狠狠操 | 国产理论一区二区三区 | 国产精品成人自产拍在线观看 | 免费日韩高清 | 日本成人免费在线观看 | 天天激情在线 | 精品一区 在线 |