• <tr id="yyy80"></tr>
  • <sup id="yyy80"></sup>
  • <tfoot id="yyy80"><noscript id="yyy80"></noscript></tfoot>
  • 99热精品在线国产_美女午夜性视频免费_国产精品国产高清国产av_av欧美777_自拍偷自拍亚洲精品老妇_亚洲熟女精品中文字幕_www日本黄色视频网_国产精品野战在线观看 ?

    基于函數(shù)式編程語(yǔ)言的事件驅(qū)動(dòng)模型的設(shè)計(jì)與實(shí)現(xiàn)

    2016-11-09 01:11:23劉德財(cái)高建華
    關(guān)鍵詞:移動(dòng)游戲編程語(yǔ)言監(jiān)聽(tīng)

    劉德財(cái) 高建華

    (上海師范大學(xué)計(jì)算機(jī)科學(xué)與技術(shù)系 上海 200234)

    ?

    基于函數(shù)式編程語(yǔ)言的事件驅(qū)動(dòng)模型的設(shè)計(jì)與實(shí)現(xiàn)

    劉德財(cái)高建華

    (上海師范大學(xué)計(jì)算機(jī)科學(xué)與技術(shù)系上海 200234)

    函數(shù)式編程語(yǔ)言在移動(dòng)游戲研發(fā)中使用十分普遍,例如客戶端的Lua、JavaScript,服務(wù)端的Ruby、Erlang、JavaScript。但目前對(duì)移動(dòng)游戲開(kāi)發(fā)框架的設(shè)計(jì)大多是基于傳統(tǒng)面向?qū)ο蟮姆椒?,并沒(méi)有很好地利用函數(shù)式編程語(yǔ)言的特性。針對(duì)項(xiàng)目代碼模塊的通信問(wèn)題,通過(guò)借鑒面向?qū)ο?OOP)中的觀察者模式以及現(xiàn)有的函數(shù)式編程語(yǔ)言的開(kāi)源框架Node.js,設(shè)計(jì)并實(shí)現(xiàn)一種適用于函數(shù)式編程語(yǔ)言的事件驅(qū)動(dòng)模型FPEDM(Functional Programming Event Driven Model)。該模型具有簡(jiǎn)單易用,擴(kuò)展性強(qiáng),與移動(dòng)游戲軟件耦合度低、復(fù)用性好的特點(diǎn),應(yīng)用到項(xiàng)目開(kāi)發(fā)中可大大提高開(kāi)發(fā)效率,簡(jiǎn)化項(xiàng)目框架的復(fù)雜度。

    函數(shù)式編程事件驅(qū)動(dòng)模型

    0 引 言

    隨著移動(dòng)智能設(shè)備的配置不斷提高以及移動(dòng)互聯(lián)網(wǎng)技術(shù)的快速發(fā)展,移動(dòng)游戲的開(kāi)發(fā)設(shè)計(jì)變得越來(lái)越重要。移動(dòng)游戲的開(kāi)發(fā)和傳統(tǒng)的端游開(kāi)發(fā)有著很大的區(qū)別,端游一般開(kāi)發(fā)周期長(zhǎng),項(xiàng)目龐大復(fù)雜,引擎技術(shù)由于不開(kāi)源而更新周期較長(zhǎng),開(kāi)發(fā)語(yǔ)言一般為面向?qū)ο笳Z(yǔ)言,如C++、Java等,而移動(dòng)游戲則開(kāi)發(fā)周期短,游戲版本迭代快,引擎技術(shù)開(kāi)源使得引擎技術(shù)更新較快,開(kāi)發(fā)語(yǔ)言趨向于函數(shù)式編程的動(dòng)態(tài)語(yǔ)言,如Lua,JavaScript,Ruby等。目前在移動(dòng)游戲開(kāi)發(fā)框架設(shè)計(jì)領(lǐng)域的研究比較少,實(shí)際開(kāi)發(fā)中很多也還是照搬了傳統(tǒng)面向?qū)ο?OOP)的設(shè)計(jì)思想,沒(méi)有很好地利用函數(shù)式編程語(yǔ)言的特性,使游戲項(xiàng)目變得龐大復(fù)雜,并不能很好地適應(yīng)開(kāi)發(fā)周期短、項(xiàng)目變更快的移動(dòng)開(kāi)發(fā),同時(shí)編程語(yǔ)言本身的差異也使得在實(shí)現(xiàn)OOP設(shè)計(jì)思想上有困難。

    本文就移動(dòng)游戲開(kāi)發(fā)框架設(shè)計(jì)中的代碼模塊間通信問(wèn)題進(jìn)行設(shè)計(jì)和研究,通過(guò)借鑒面向?qū)ο?OOP)的觀察者模式和開(kāi)源框架Node.js[1],設(shè)計(jì)并實(shí)現(xiàn)了基于函數(shù)式編程語(yǔ)言的一種事件驅(qū)動(dòng)的模型框架FPEDM,該模型具有易使用,易擴(kuò)展,可復(fù)用的特點(diǎn),同時(shí)模型也充分利用了FP語(yǔ)言的特點(diǎn),更加適合FP語(yǔ)言編寫(xiě)的移動(dòng)游戲項(xiàng)目,更為重要的是把設(shè)計(jì)思想提取成為了一個(gè)文件,不依賴任何具體的移動(dòng)游戲項(xiàng)目。FPEDM應(yīng)用在實(shí)際開(kāi)發(fā)中可大大提升項(xiàng)目開(kāi)發(fā)效率和軟件質(zhì)量。

    1 相關(guān)知識(shí)

    1.1函數(shù)式編程

    函數(shù)式編程和指令式編程(面向過(guò)程編程和面向?qū)ο缶幊?相比較,函數(shù)式編程提升了函數(shù)的地位,函數(shù)是第一類對(duì)象和數(shù)據(jù)的集合,使得編程者對(duì)程序的狀態(tài)和執(zhí)行次序不必太關(guān)心[2]。

    1.2函數(shù)式編程語(yǔ)言

    函數(shù)式編程語(yǔ)言的構(gòu)成范式的理論基礎(chǔ)是由Alonzo Church等提出并證明與圖靈機(jī)等價(jià)的lambda演算系統(tǒng),在該范式下,程序由函數(shù)和對(duì)函數(shù)的應(yīng)用上下文構(gòu)成[3]。相對(duì)于Objective-C,蘋(píng)果最新發(fā)布的開(kāi)發(fā)語(yǔ)言Swift一個(gè)很重要的改進(jìn)就是就加入了函數(shù)式編程的支持。

    1.3事件驅(qū)動(dòng)模型

    事件驅(qū)動(dòng)模型在軟件設(shè)計(jì)中主要涵蓋三個(gè)方面:事件源、事件和事件處理者[4]。事件(如GUI中的敲入一個(gè)鍵、單擊鼠標(biāo))發(fā)生后,事件源就會(huì)激發(fā)與此事件相應(yīng)的消息,事件調(diào)度器將事件傳給事件處理者的處理函數(shù)進(jìn)行處理。

    2 FPEDM的設(shè)計(jì)和實(shí)現(xiàn)

    2.1FPEDM的設(shè)計(jì)

    傳統(tǒng)的軟件工程中,事件驅(qū)動(dòng)模型的設(shè)計(jì)一般如圖1所示。首先由事件注冊(cè)者在事件調(diào)度器中注冊(cè)/移除注冊(cè)特定的事件,事件處理者同時(shí)向調(diào)度器監(jiān)聽(tīng)/取消監(jiān)聽(tīng)特定的事件,事件源發(fā)生事件后告知事件調(diào)度器發(fā)生了某個(gè)事件,事件調(diào)度器收到后通過(guò)派發(fā)告知正在監(jiān)聽(tīng)這個(gè)事件的每一個(gè)處理者,讓所有處理者對(duì)事件作出響應(yīng)[5]。

    傳統(tǒng)的事件驅(qū)動(dòng)模型設(shè)計(jì)充分體現(xiàn)了面向?qū)ο蟮脑O(shè)計(jì)思想,優(yōu)點(diǎn)是可擴(kuò)展性好,缺點(diǎn)是設(shè)計(jì)較為復(fù)雜。一個(gè)事件的完成需要多個(gè)參與者,如圖1所示一般需要四個(gè)參與者,這也導(dǎo)致開(kāi)發(fā)人員在理解和使用上成本較高,這在開(kāi)發(fā)周期長(zhǎng)的大型項(xiàng)目中是能夠承受的。但在開(kāi)發(fā)周期較短、迭代迅速的移動(dòng)游戲項(xiàng)目中,顯得有些設(shè)計(jì)過(guò)度,不利于移動(dòng)游戲項(xiàng)目的快速開(kāi)發(fā)和BUG排查。

    圖1 面向?qū)ο蟮氖录?qū)動(dòng)模型

    本文通過(guò)借鑒面向?qū)ο笾械挠^察者設(shè)計(jì)模式[6]和開(kāi)源框架Node.js[7],設(shè)計(jì)了如圖2所示的基于函數(shù)式編程語(yǔ)言的事件驅(qū)動(dòng)模型(FPEDM)。FPEDM中一個(gè)事件的參與者只剩下事件源和事件處理者,其中事件源通過(guò)引用FPEDM文件,具有了注冊(cè)/取消注冊(cè)事件和事件派發(fā)的功能,事件處理者通過(guò)向事件源(同時(shí)也是事件調(diào)度器)監(jiān)聽(tīng)/取消監(jiān)聽(tīng)特定的事件。FPEDM中的事件源在事件發(fā)生時(shí)派發(fā)事件,所有正在監(jiān)聽(tīng)這一事件的事件處理者都會(huì)收到,從而作出響應(yīng)。FPEDM使得整個(gè)事件驅(qū)動(dòng)的模型變得簡(jiǎn)單易用,模型不依賴于具體的移動(dòng)游戲項(xiàng)目,做到了思想和代碼的100%復(fù)用,并且實(shí)現(xiàn)了和圖1一樣的功能。

    圖2 FPEDM

    2.2FPEDM的實(shí)現(xiàn)

    從圖2中可以看到, FPEDM的關(guān)鍵就是FPEDM文件的實(shí)現(xiàn)。從2.1節(jié)可以知道,事件驅(qū)動(dòng)模型包含6個(gè)過(guò)程:注冊(cè)/取消注冊(cè),監(jiān)聽(tīng)/取消監(jiān)聽(tīng),發(fā)生和派發(fā),其中發(fā)生是事件源的職責(zé),事件源應(yīng)該明確知道事件何時(shí)發(fā)生。因此FPEDM文件只需實(shí)現(xiàn)注冊(cè)/取消注冊(cè),監(jiān)聽(tīng)/取消監(jiān)聽(tīng)、派發(fā)5個(gè)過(guò)程以及引用FPEDM文件的方法即可。

    本文中描述FPEDM文件的實(shí)現(xiàn)采用的是moonscript風(fēng)格的偽代碼,moonscript是lua的模板編程語(yǔ)言。

    FPEDM文件對(duì)于注冊(cè)/取消注冊(cè)采用了一張哈希表(Hash table)進(jìn)行維護(hù),具體結(jié)構(gòu)如圖3所示,該數(shù)據(jù)結(jié)構(gòu)充分利用了函數(shù)式編程語(yǔ)言的函數(shù)是第一類對(duì)象的特點(diǎn)。哈希表中的關(guān)鍵碼值為事件ID,關(guān)鍵碼值所對(duì)應(yīng)的是所有正在監(jiān)聽(tīng)這一事件的處理函數(shù)的指引(函數(shù)式編程語(yǔ)言中沒(méi)有指針概念,本文稱為指引)的集合。

    圖3 FPEDM的數(shù)據(jù)結(jié)構(gòu)

    FPEDM文件的添加監(jiān)聽(tīng)方法如圖4所示,其中輸入為事件源,事件ID以及監(jiān)聽(tīng)者(處理函數(shù)),函數(shù)中第一個(gè)參數(shù)self為函數(shù)的調(diào)用者。從圖2可以知道FPEDM文件是被事件源引用的,所以這個(gè)self就是事件源,第3行的findOrCreateListenerTable函數(shù)是創(chuàng)建或者找到已存在的圖3所示的數(shù)據(jù)結(jié)構(gòu),即得到event_id的所有處理函數(shù)的指引集合,第4行為向這個(gè)集合中添加監(jiān)聽(tīng)者listener,最后返回self(事件源)是為了方法的鏈?zhǔn)秸{(diào)用。

    圖4FPEDM文件的addListener方法

    FPEDM文件的移除監(jiān)聽(tīng)方法如圖5所示,其中輸入為事件源,事件ID以及監(jiān)聽(tīng)者(處理函數(shù)),第4、5行得到event_id的處理函數(shù)集合,并從中移除listener,第6、7行為移除一次性的監(jiān)聽(tīng)者。一次性監(jiān)聽(tīng)者的添加和圖4方法基本一致,只是在event_id后添加once字符組成新event_id以區(qū)別正常監(jiān)聽(tīng)者,它會(huì)在收到事件作出響應(yīng)后自動(dòng)移除監(jiān)聽(tīng)。

    圖5FPEDM文件的removeListener方法

    FPEDM文件派發(fā)事件的方法如圖6所示,輸入為事件源,事件ID,以及事件派發(fā)時(shí)所帶的參數(shù)(可以多個(gè)參數(shù)),第2-5行得到event_id的處理函數(shù)集合,并依次調(diào)用。每次調(diào)用時(shí)都會(huì)把派發(fā)所帶的參數(shù)傳給處理函數(shù),這樣使得事件源和監(jiān)聽(tīng)者之間可以進(jìn)行數(shù)據(jù)交流,第6-10行為處理一次性監(jiān)聽(tīng)者的響應(yīng),并在10行自動(dòng)移除監(jiān)聽(tīng)。

    圖6FPEDM文件的emit方法

    引用FPEDM文件的EventEmitter方法如圖7所示,從圖2可知輸入為事件源,第2行對(duì)引用對(duì)象(事件源)設(shè)置標(biāo)志位,標(biāo)記其擁有了FPEDM文件的方法,3-9行依次把FPEDM文件中的方法賦予引用對(duì)象(事件源),并借鑒了Node.js的API風(fēng)格為每個(gè)方法取了別名,便于理解和實(shí)際應(yīng)用。

    圖7FPEDM文件的EventEmitter方法

    3 FPEDM的評(píng)價(jià)

    3.1簡(jiǎn)單易用

    項(xiàng)目使用FPEDM十分簡(jiǎn)易,它和Web的js文件使用方法類似,只需要在事件源文件中引用FPEDM文件,調(diào)用EventEmitter注冊(cè)自身后即可。圖8展示了FPEDM的使用。

    圖8FPEDM的使用示例

    3.2充分利用了函數(shù)式編程語(yǔ)言的特點(diǎn)

    FPEDM充分利用了FP語(yǔ)言編程的文件模塊化和函數(shù)為第一類對(duì)象的特點(diǎn),無(wú)需再把FP語(yǔ)言偽裝成OOP語(yǔ)言來(lái)使用,靈活度提高了不少,代碼之間的邏輯關(guān)系變得更加清晰,沒(méi)有復(fù)雜的繼承和龐大的UML類圖。

    3.3分布式的事件管理機(jī)制

    傳統(tǒng)事件調(diào)度器一般都存在輪詢代碼,不斷輪詢每一個(gè)事件的狀態(tài),從而做出是否派發(fā)事件的決定。FPEDM中的事件源通過(guò)引用FPEDM文件后,可以實(shí)現(xiàn)自己管理自己的事件,無(wú)需單獨(dú)的事件調(diào)度器存在。由于這種分布式的事件管理機(jī)制,在一定程度上可以消除移動(dòng)游戲項(xiàng)目中的代碼中心瓶頸問(wèn)題。

    3.4實(shí)現(xiàn)了模型和代碼的100%復(fù)用

    由于FPEDM的代碼獨(dú)立成了一個(gè)模塊文件,使得只要是和FPEDM文件使用同一門(mén)語(yǔ)言編寫(xiě)的移動(dòng)游戲項(xiàng)目,無(wú)需任何的修改即可直接使用,而且使用過(guò)程十分簡(jiǎn)單方便。同時(shí)理論上任何FP語(yǔ)言都可以實(shí)現(xiàn)FPEDM文件,所以對(duì)使用FP語(yǔ)言編寫(xiě)的項(xiàng)目來(lái)說(shuō),使用FPEDM都是一個(gè)不錯(cuò)的選擇。

    3.5保留了OOP式事件驅(qū)動(dòng)模型的優(yōu)勢(shì)

    表1列出了FPEDM和傳統(tǒng)面向?qū)ο?OOP)的事件驅(qū)動(dòng)模型對(duì)比結(jié)果,因?yàn)閮蓚€(gè)模型都是對(duì)軟件的一種設(shè)計(jì),所以對(duì)比的指標(biāo)采用了軟件工程中常用的評(píng)價(jià)指標(biāo),包括了復(fù)用性,易用性,可維護(hù)性和擴(kuò)展性[8]。從表1的結(jié)果可以看出FPEDM保留了OOP式事件驅(qū)動(dòng)模型的可維護(hù)性和擴(kuò)展性特點(diǎn),提升了事件驅(qū)動(dòng)模型的代碼復(fù)用性,降低了事件驅(qū)動(dòng)模型的使用和理解門(mén)檻,在移動(dòng)游戲開(kāi)發(fā)中的實(shí)際效果也證實(shí)了這些優(yōu)勢(shì)。

    表1 OOP式事件驅(qū)動(dòng)模型和FPEDM對(duì)比

    4 結(jié) 語(yǔ)

    本文通過(guò)借鑒傳統(tǒng)軟件設(shè)計(jì)思想中的觀察者模式和開(kāi)源框架Node.js,設(shè)計(jì)并實(shí)現(xiàn)了基于函數(shù)式編程語(yǔ)言的FPEDM,并把其和傳統(tǒng)OOP式事件驅(qū)動(dòng)模型相比較,得出FPEDM具有簡(jiǎn)單易用、充分利用了FP語(yǔ)言特性、分布式事件管理機(jī)制、代碼復(fù)用率100%和保留了OOP式事件驅(qū)動(dòng)模型優(yōu)勢(shì)的特點(diǎn),使其十分適合用于移動(dòng)游戲項(xiàng)目(FP語(yǔ)言開(kāi)發(fā))的開(kāi)發(fā)和設(shè)計(jì)。日后的研究主要是實(shí)現(xiàn)FPEDM中多事件協(xié)作的處理和事件的異步驅(qū)動(dòng)等。

    [1] Node.js的模塊機(jī)制.https://Node.js.org/api/modules.html.

    [2] 微軟關(guān)于函數(shù)式編程的定義和解釋.https://msdn.microsoft.com/en-us/library/bb669144.aspx.

    [3] 李向陽(yáng),連小綺.函數(shù)式程序范式在語(yǔ)義web中的應(yīng)用[J].中國(guó)科技信息,2006,12(24):79,87.

    [4] 韓彪,吳眾欣,欒鐘治,等.一種適于主-從模式網(wǎng)絡(luò)計(jì)算的事件驅(qū)動(dòng)架構(gòu)[J].西安交通大學(xué)學(xué)報(bào),2010,44(2):39-43.

    [5] Westermann U,Jain R. Toward a Common Event Model for Multimedia Applications[J]. MultiMedia, IEEE, 2007,14(1):19-29.

    [6] Zhu G K. Applying Software Design Patterns in Electromagnetic Field Simulators[J]. Antennas and Propagation Magazine, IEEE, 2012,54(2):174-179.

    [7] 王金龍,宋斌,丁銳. Node.js:一種新的Web應(yīng)用構(gòu)建技術(shù)[J].現(xiàn)代電子技術(shù),2015,38(6):70-73.

    [8] Ian Sommerville. 軟件工程[M]. 程成,陳霞,等譯.北京:機(jī)械工業(yè)出版社,2013: 178-192.

    DESIGN AND IMPLEMENTATION OF EVENT-DRIVEN MODEL BASED ON FUNCTIONAL PROGRAMMING LANGUAGE

    Liu DecaiGao Jianhua

    (Department of Computer Science and Technology, Shanghai Normal University, Shanghai 200234,China)

    Functional programming language (FPL) has been widely used in the development of mobile games, such as Lua and JavaScript on client, Ruby, Erlang and JavaScript on server. However, most of the designs in regard to mobile game development framework are based on traditional object-oriented method, they do not make good use of the characteristics of FPL. In this paper, focuses on the communication in modules of project code, we designed and implemented an event-driven model applicable to FPL, named FPEDM, by referring the observer pattern of object-oriented programming (OOP) and existing open source framework of FPL Node.js. The model is simple and easy to use, has strong scalability, low coupling dependency with specific mobile game projects, and good reusability. By applying it to project development, the development efficiency can be greatly improved, the complexity of the project framework can be simplified as well.

    Functional programmingEvent-driven model

    2015-06-06。國(guó)家自然科學(xué)基金項(xiàng)目(61073163);上海市企業(yè)自主創(chuàng)新專項(xiàng)資金項(xiàng)目(滬CXY-2013-88)。劉德財(cái),碩士生,主研領(lǐng)域:軟件可靠性設(shè)計(jì)理論與方法。高建華,教授。

    TP3

    A

    10.3969/j.issn.1000-386x.2016.09.002

    猜你喜歡
    移動(dòng)游戲編程語(yǔ)言監(jiān)聽(tīng)
    壓力-體積轉(zhuǎn)換在CFC編程語(yǔ)言中的實(shí)現(xiàn)解析
    二季度全球移動(dòng)游戲平均周下載量同比增長(zhǎng)20%
    千元監(jiān)聽(tīng)風(fēng)格Hi-Fi箱新選擇 Summer audio A-401
    Q1中國(guó)移動(dòng)游戲市場(chǎng)收入超500億元
    綜藝報(bào)(2020年8期)2020-05-11 11:56:40
    Java編程語(yǔ)言的特點(diǎn)與應(yīng)用
    淺談不同編程語(yǔ)言對(duì)計(jì)算機(jī)軟件開(kāi)發(fā)的影響
    電子制作(2018年1期)2018-04-04 01:48:36
    網(wǎng)絡(luò)監(jiān)聽(tīng)的防范措施
    電子制作(2017年20期)2017-04-26 06:58:02
    面向?qū)ο骔eb開(kāi)發(fā)編程語(yǔ)言的的評(píng)估方法
    應(yīng)召反潛時(shí)無(wú)人機(jī)監(jiān)聽(tīng)航路的規(guī)劃
    局域網(wǎng)監(jiān)聽(tīng)軟件的設(shè)計(jì)
    河南科技(2014年5期)2014-02-27 14:08:21
    久久久久久久久久久免费av| 国产午夜精品久久久久久一区二区三区| 欧美97在线视频| 秋霞在线观看毛片| 免费观看的影片在线观看| 最近中文字幕高清免费大全6| 一级毛片久久久久久久久女| 久久人人爽人人爽人人片va| 一级毛片 在线播放| 99热国产这里只有精品6| 亚洲精品乱码久久久久久按摩| 欧美区成人在线视频| 国产欧美亚洲国产| 伊人久久精品亚洲午夜| 欧美激情国产日韩精品一区| 人人妻人人爽人人添夜夜欢视频 | 亚洲av成人精品一二三区| 日本午夜av视频| 日本午夜av视频| 亚洲成人中文字幕在线播放| 亚洲美女黄色视频免费看| 久久久亚洲精品成人影院| 两个人的视频大全免费| 夜夜看夜夜爽夜夜摸| 免费大片黄手机在线观看| 国产精品不卡视频一区二区| 国产av一区二区精品久久 | 欧美三级亚洲精品| 三级经典国产精品| 日韩成人伦理影院| 日本欧美视频一区| 国产成人a区在线观看| av在线老鸭窝| 国产成人精品一,二区| 99久久综合免费| 日韩,欧美,国产一区二区三区| 欧美日韩一区二区视频在线观看视频在线| 精华霜和精华液先用哪个| 91精品伊人久久大香线蕉| 精品久久久久久电影网| 欧美精品一区二区免费开放| 亚洲精品日韩av片在线观看| 国产精品偷伦视频观看了| 国产精品偷伦视频观看了| 纵有疾风起免费观看全集完整版| 国产一区二区三区综合在线观看 | 内地一区二区视频在线| 嫩草影院入口| 亚洲国产欧美在线一区| av播播在线观看一区| 天天躁夜夜躁狠狠久久av| 久久久久久九九精品二区国产| 午夜福利网站1000一区二区三区| 国产成人精品久久久久久| 亚洲欧美一区二区三区黑人 | 大香蕉97超碰在线| 欧美成人一区二区免费高清观看| 免费观看性生交大片5| 综合色丁香网| 舔av片在线| 舔av片在线| 超碰av人人做人人爽久久| 一级二级三级毛片免费看| 综合色丁香网| 校园人妻丝袜中文字幕| 国精品久久久久久国模美| 欧美日韩视频高清一区二区三区二| 国产精品女同一区二区软件| 一区二区三区四区激情视频| 18禁在线无遮挡免费观看视频| 亚洲av电影在线观看一区二区三区| 青春草亚洲视频在线观看| 噜噜噜噜噜久久久久久91| 亚洲国产精品一区三区| 校园人妻丝袜中文字幕| 最近中文字幕高清免费大全6| 成人18禁高潮啪啪吃奶动态图 | 少妇熟女欧美另类| 精品人妻熟女av久视频| 欧美xxxx性猛交bbbb| 国产亚洲一区二区精品| 成人二区视频| 男人狂女人下面高潮的视频| 国产乱来视频区| 日本黄色片子视频| 99热全是精品| 免费看日本二区| 国产欧美日韩一区二区三区在线 | 久久久成人免费电影| 国产成人免费观看mmmm| 一本—道久久a久久精品蜜桃钙片| 国产一区亚洲一区在线观看| 亚洲国产欧美在线一区| 一级a做视频免费观看| 成人18禁高潮啪啪吃奶动态图 | 欧美高清性xxxxhd video| 久热久热在线精品观看| 成人美女网站在线观看视频| 欧美人与善性xxx| 大话2 男鬼变身卡| 日本免费在线观看一区| 亚洲激情五月婷婷啪啪| av播播在线观看一区| 搡女人真爽免费视频火全软件| 精品国产三级普通话版| 久久国产乱子免费精品| 中文欧美无线码| 美女国产视频在线观看| 一本—道久久a久久精品蜜桃钙片| 高清av免费在线| 国国产精品蜜臀av免费| 青春草亚洲视频在线观看| 天天躁日日操中文字幕| 高清不卡的av网站| 一区二区三区四区激情视频| 大片免费播放器 马上看| 国产淫片久久久久久久久| 建设人人有责人人尽责人人享有的 | 舔av片在线| 亚洲成人手机| 99久久精品国产国产毛片| 久久精品夜色国产| 美女视频免费永久观看网站| 国产欧美日韩一区二区三区在线 | 免费播放大片免费观看视频在线观看| 亚洲av男天堂| 日韩av免费高清视频| 亚洲精品国产色婷婷电影| 国产黄片视频在线免费观看| 天美传媒精品一区二区| 丰满少妇做爰视频| 亚洲国产精品成人久久小说| 干丝袜人妻中文字幕| 久久久a久久爽久久v久久| 青春草视频在线免费观看| 成人午夜精彩视频在线观看| 亚洲国产日韩一区二区| 国产精品一区二区在线观看99| 国产在线男女| 人人妻人人爽人人添夜夜欢视频 | 欧美zozozo另类| 欧美性感艳星| 99九九线精品视频在线观看视频| 国产成人免费无遮挡视频| av不卡在线播放| 少妇 在线观看| 亚洲国产精品国产精品| 亚洲av中文字字幕乱码综合| av.在线天堂| 一区二区三区精品91| 久久久久久久久大av| 精品一区在线观看国产| 国精品久久久久久国模美| 2021少妇久久久久久久久久久| 最近的中文字幕免费完整| 国产精品久久久久久久久免| 观看免费一级毛片| 成人午夜精彩视频在线观看| 免费大片黄手机在线观看| 男女免费视频国产| 日本av免费视频播放| 在线观看三级黄色| 欧美zozozo另类| 高清欧美精品videossex| 亚洲精品国产av蜜桃| tube8黄色片| 国产成人一区二区在线| 色网站视频免费| 亚洲欧美精品专区久久| 日韩大片免费观看网站| 观看美女的网站| 老司机影院成人| 狠狠精品人妻久久久久久综合| 免费人成在线观看视频色| 亚洲在久久综合| 亚洲国产高清在线一区二区三| 日本av免费视频播放| 亚洲av福利一区| 亚洲精品久久午夜乱码| 大香蕉97超碰在线| 晚上一个人看的免费电影| 国产伦精品一区二区三区四那| 女人久久www免费人成看片| 亚洲av欧美aⅴ国产| 久久精品久久久久久噜噜老黄| 自拍欧美九色日韩亚洲蝌蚪91 | 大片电影免费在线观看免费| av在线播放精品| 亚洲精品日本国产第一区| 纯流量卡能插随身wifi吗| h视频一区二区三区| 美女脱内裤让男人舔精品视频| 日本色播在线视频| 日韩av免费高清视频| av卡一久久| 少妇人妻精品综合一区二区| 精品亚洲乱码少妇综合久久| 一个人看视频在线观看www免费| 成年美女黄网站色视频大全免费 | 欧美成人午夜免费资源| 小蜜桃在线观看免费完整版高清| 国产精品久久久久久久电影| 日本午夜av视频| 一边亲一边摸免费视频| 亚洲婷婷狠狠爱综合网| 国产69精品久久久久777片| 免费人成在线观看视频色| 亚洲经典国产精华液单| 欧美xxⅹ黑人| 精品国产乱码久久久久久小说| 视频中文字幕在线观看| 中文乱码字字幕精品一区二区三区| 蜜桃久久精品国产亚洲av| 免费看光身美女| 边亲边吃奶的免费视频| 一本色道久久久久久精品综合| 日日摸夜夜添夜夜爱| 国产精品一区www在线观看| 久久精品国产a三级三级三级| 久久毛片免费看一区二区三区| 大香蕉久久网| 久久99精品国语久久久| 日本猛色少妇xxxxx猛交久久| 一区二区三区乱码不卡18| 久久久久久人妻| 国产高清三级在线| 三级经典国产精品| 亚洲第一区二区三区不卡| 视频区图区小说| 亚洲av电影在线观看一区二区三区| av女优亚洲男人天堂| av线在线观看网站| 不卡视频在线观看欧美| 男人舔奶头视频| 一本—道久久a久久精品蜜桃钙片| 亚洲va在线va天堂va国产| 干丝袜人妻中文字幕| 人妻一区二区av| 中文字幕av成人在线电影| 亚洲av福利一区| 日本一二三区视频观看| 国产深夜福利视频在线观看| 三级经典国产精品| 欧美日韩在线观看h| 少妇精品久久久久久久| 91精品一卡2卡3卡4卡| 亚洲一区二区三区欧美精品| av又黄又爽大尺度在线免费看| 在线 av 中文字幕| 亚洲不卡免费看| 日本黄大片高清| 亚洲精品自拍成人| 色婷婷av一区二区三区视频| 人妻少妇偷人精品九色| 国产高清三级在线| 天堂中文最新版在线下载| 亚洲一级一片aⅴ在线观看| 一本久久精品| 内地一区二区视频在线| 亚洲国产精品999| 国产亚洲5aaaaa淫片| a级毛片免费高清观看在线播放| 成年人午夜在线观看视频| 精品亚洲成国产av| 女性生殖器流出的白浆| 深夜a级毛片| 男女国产视频网站| 美女高潮的动态| 亚洲最大成人中文| 国产精品福利在线免费观看| 亚洲内射少妇av| 六月丁香七月| 国产大屁股一区二区在线视频| 国产av精品麻豆| 十分钟在线观看高清视频www | 黄片wwwwww| 色视频在线一区二区三区| 啦啦啦啦在线视频资源| 人人妻人人爽人人添夜夜欢视频 | 国产亚洲av片在线观看秒播厂| 国产成人精品福利久久| 美女主播在线视频| 精品少妇久久久久久888优播| 亚洲人成网站在线播| 不卡视频在线观看欧美| 久久精品国产自在天天线| 卡戴珊不雅视频在线播放| 99久久人妻综合| 成人亚洲欧美一区二区av| 我的女老师完整版在线观看| 啦啦啦中文免费视频观看日本| 在线亚洲精品国产二区图片欧美 | 久久6这里有精品| 久久久久国产精品人妻一区二区| h视频一区二区三区| 欧美日韩一区二区视频在线观看视频在线| 最近最新中文字幕免费大全7| 一二三四中文在线观看免费高清| 国产欧美日韩一区二区三区在线 | av女优亚洲男人天堂| 欧美老熟妇乱子伦牲交| 国产真实伦视频高清在线观看| 人人妻人人添人人爽欧美一区卜 | 内射极品少妇av片p| 日本午夜av视频| 91久久精品国产一区二区成人| 精品亚洲乱码少妇综合久久| 欧美区成人在线视频| 国产亚洲欧美精品永久| 国产精品一区www在线观看| 熟女av电影| 欧美精品一区二区免费开放| 日本爱情动作片www.在线观看| 如何舔出高潮| 看免费成人av毛片| 亚洲一级一片aⅴ在线观看| 亚洲精品日本国产第一区| 美女中出高潮动态图| 中文天堂在线官网| 久久影院123| 一级av片app| 伦理电影大哥的女人| 十分钟在线观看高清视频www | 在线观看三级黄色| 国产黄色视频一区二区在线观看| 国产精品人妻久久久久久| 哪个播放器可以免费观看大片| 久久国产亚洲av麻豆专区| 国产久久久一区二区三区| 你懂的网址亚洲精品在线观看| 18禁裸乳无遮挡动漫免费视频| 最近2019中文字幕mv第一页| 亚洲性久久影院| 精品国产三级普通话版| 亚洲精品日本国产第一区| 国产伦理片在线播放av一区| 精品国产三级普通话版| 日韩欧美精品免费久久| 青春草视频在线免费观看| 久久国产乱子免费精品| 亚洲aⅴ乱码一区二区在线播放| 日日啪夜夜爽| 亚洲精品aⅴ在线观看| 免费大片18禁| 熟妇人妻不卡中文字幕| 在线天堂最新版资源| 免费av中文字幕在线| 久久久久久久大尺度免费视频| 久久国产精品大桥未久av | 亚洲av.av天堂| 久久精品夜色国产| 伦精品一区二区三区| 久久99热这里只有精品18| 女性被躁到高潮视频| 久久亚洲国产成人精品v| 亚洲国产av新网站| 熟女人妻精品中文字幕| 欧美人与善性xxx| 草草在线视频免费看| 在现免费观看毛片| 小蜜桃在线观看免费完整版高清| 少妇人妻一区二区三区视频| 天天躁日日操中文字幕| 中文字幕久久专区| 国产黄频视频在线观看| av在线播放精品| 国产成人精品一,二区| 国产精品福利在线免费观看| 国产免费视频播放在线视频| 国产片特级美女逼逼视频| 精品一品国产午夜福利视频| 国产午夜精品久久久久久一区二区三区| 精品久久久精品久久久| 免费少妇av软件| 91午夜精品亚洲一区二区三区| 最新中文字幕久久久久| 美女福利国产在线 | 久久久a久久爽久久v久久| 亚洲精品乱码久久久久久按摩| 国国产精品蜜臀av免费| 久久久久久人妻| 国产免费福利视频在线观看| 久久综合国产亚洲精品| 国产一级毛片在线| 在线天堂最新版资源| 中国国产av一级| 免费黄频网站在线观看国产| 国产乱人视频| 一区二区三区免费毛片| 一级爰片在线观看| 亚洲精品,欧美精品| 18禁裸乳无遮挡免费网站照片| 亚洲av中文字字幕乱码综合| 黄片wwwwww| 好男人视频免费观看在线| 国产在线男女| 日韩制服骚丝袜av| 51国产日韩欧美| 国产成人一区二区在线| 日韩制服骚丝袜av| 51国产日韩欧美| 亚洲成色77777| 国产亚洲午夜精品一区二区久久| 中文字幕制服av| 三级国产精品欧美在线观看| 成人影院久久| tube8黄色片| 精华霜和精华液先用哪个| 老司机影院成人| 免费大片黄手机在线观看| 在线观看三级黄色| 天堂俺去俺来也www色官网| 日本-黄色视频高清免费观看| 欧美日韩视频高清一区二区三区二| 免费黄频网站在线观看国产| 91午夜精品亚洲一区二区三区| 91精品伊人久久大香线蕉| 国产午夜精品一二区理论片| 国产精品秋霞免费鲁丝片| 国产成人aa在线观看| 网址你懂的国产日韩在线| av一本久久久久| 免费黄频网站在线观看国产| 国产一区二区三区av在线| 插阴视频在线观看视频| 欧美高清成人免费视频www| 亚洲av成人精品一二三区| 97精品久久久久久久久久精品| 国产有黄有色有爽视频| 久久久久人妻精品一区果冻| 久久久久人妻精品一区果冻| 一个人免费看片子| 婷婷色综合大香蕉| 春色校园在线视频观看| 日本黄色日本黄色录像| 亚洲内射少妇av| 亚洲精品一区蜜桃| 国产永久视频网站| 欧美xxxx黑人xx丫x性爽| 亚洲在久久综合| 舔av片在线| 日韩一区二区视频免费看| 久久久亚洲精品成人影院| 18禁裸乳无遮挡免费网站照片| 伦精品一区二区三区| 日本猛色少妇xxxxx猛交久久| 国产在线一区二区三区精| 久久国产乱子免费精品| a 毛片基地| 亚洲成色77777| 少妇裸体淫交视频免费看高清| 国产免费又黄又爽又色| 国产精品av视频在线免费观看| 久久人人爽人人片av| 两个人的视频大全免费| 久久午夜福利片| 人人妻人人爽人人添夜夜欢视频 | 国产免费一级a男人的天堂| 久久 成人 亚洲| 日日摸夜夜添夜夜添av毛片| 色吧在线观看| 高清毛片免费看| 精品人妻视频免费看| 97精品久久久久久久久久精品| 高清午夜精品一区二区三区| 亚洲,一卡二卡三卡| 欧美日本视频| 午夜激情久久久久久久| 99久久人妻综合| 亚洲美女黄色视频免费看| 热99国产精品久久久久久7| 久久久久久久久久久免费av| 免费大片18禁| 久久婷婷青草| 中国三级夫妇交换| 亚洲人成网站在线播| 一区二区三区精品91| 男人爽女人下面视频在线观看| 欧美日韩综合久久久久久| 欧美少妇被猛烈插入视频| 久久久久久久亚洲中文字幕| 久久99热这里只有精品18| 亚洲精品国产av蜜桃| 亚洲av日韩在线播放| 高清不卡的av网站| 夜夜爽夜夜爽视频| av在线蜜桃| 国产视频首页在线观看| 久久国产亚洲av麻豆专区| 内地一区二区视频在线| 亚洲国产日韩一区二区| 欧美日韩精品成人综合77777| 午夜免费鲁丝| 久久99热6这里只有精品| 久久毛片免费看一区二区三区| 高清黄色对白视频在线免费看 | 午夜老司机福利剧场| 精品酒店卫生间| 高清不卡的av网站| 不卡视频在线观看欧美| 久久影院123| av视频免费观看在线观看| 有码 亚洲区| 成人综合一区亚洲| 最近最新中文字幕免费大全7| 亚洲精品一区蜜桃| 精品久久久久久电影网| 内地一区二区视频在线| 久久精品久久久久久噜噜老黄| 久久婷婷青草| 日韩在线高清观看一区二区三区| 黑人高潮一二区| 涩涩av久久男人的天堂| 亚洲伊人久久精品综合| 午夜精品国产一区二区电影| 国产午夜精品久久久久久一区二区三区| 午夜激情福利司机影院| 久久精品人妻少妇| 国产美女午夜福利| 22中文网久久字幕| 中文乱码字字幕精品一区二区三区| 久久人妻熟女aⅴ| 免费观看的影片在线观看| 一级毛片黄色毛片免费观看视频| 男男h啪啪无遮挡| 91狼人影院| 丰满乱子伦码专区| 欧美变态另类bdsm刘玥| 97在线视频观看| 欧美变态另类bdsm刘玥| 夫妻午夜视频| 日韩欧美一区视频在线观看 | 亚洲欧美精品专区久久| 麻豆精品久久久久久蜜桃| av在线观看视频网站免费| 乱系列少妇在线播放| 午夜福利高清视频| 成年人午夜在线观看视频| 三级国产精品欧美在线观看| 国产老妇伦熟女老妇高清| 我的老师免费观看完整版| 日本一二三区视频观看| 国产精品一区二区在线不卡| 久热这里只有精品99| 日韩av免费高清视频| 久久国产精品男人的天堂亚洲 | 国产亚洲最大av| 人妻 亚洲 视频| 我要看日韩黄色一级片| 大又大粗又爽又黄少妇毛片口| 国产男人的电影天堂91| 免费少妇av软件| 亚洲内射少妇av| 日韩欧美一区视频在线观看 | 久久影院123| 直男gayav资源| 久久久成人免费电影| 亚洲av在线观看美女高潮| 国产成人免费观看mmmm| av在线老鸭窝| 99热网站在线观看| 国产在线一区二区三区精| 搡女人真爽免费视频火全软件| 99久久人妻综合| 国产精品国产三级国产av玫瑰| 日日啪夜夜爽| 亚洲一级一片aⅴ在线观看| 亚洲第一av免费看| 夫妻午夜视频| 中国美白少妇内射xxxbb| 国产综合精华液| 欧美激情极品国产一区二区三区 | 日韩一区二区三区影片| 日韩av在线免费看完整版不卡| a 毛片基地| 亚洲激情五月婷婷啪啪| 99热全是精品| 久久国产乱子免费精品| 女的被弄到高潮叫床怎么办| h视频一区二区三区| 最黄视频免费看| 97在线人人人人妻| 日本午夜av视频| 国产久久久一区二区三区| 草草在线视频免费看| 免费黄频网站在线观看国产| 2018国产大陆天天弄谢| 赤兔流量卡办理| 中国国产av一级| 日本黄色日本黄色录像| 91精品伊人久久大香线蕉| 人体艺术视频欧美日本| 大香蕉97超碰在线| 久久热精品热| 国产精品国产三级国产专区5o| 22中文网久久字幕| 久久精品国产亚洲网站| 日韩av不卡免费在线播放| 在线免费观看不下载黄p国产| 国产黄频视频在线观看| 91精品国产九色| 亚洲国产av新网站| 国产日韩欧美在线精品| 欧美少妇被猛烈插入视频| 久久av网站| 一区二区三区四区激情视频| .国产精品久久| 高清欧美精品videossex| 制服丝袜香蕉在线| 少妇人妻精品综合一区二区| 国产一区二区三区av在线| 内地一区二区视频在线| 国产成人91sexporn| 联通29元200g的流量卡| 伦理电影免费视频|