• <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
    国产有黄有色有爽视频| 嘟嘟电影网在线观看| 成人18禁高潮啪啪吃奶动态图 | 一级毛片我不卡| 日本av手机在线免费观看| 又粗又硬又长又爽又黄的视频| 免费不卡的大黄色大毛片视频在线观看| 亚洲av男天堂| 日韩伦理黄色片| 色视频www国产| 亚洲精品日本国产第一区| 五月天丁香电影| 人妻系列 视频| 男人狂女人下面高潮的视频| 亚洲精品国产av蜜桃| 国产大屁股一区二区在线视频| 日韩电影二区| 免费大片黄手机在线观看| 欧美三级亚洲精品| 亚洲精品乱码久久久久久按摩| 欧美日韩视频精品一区| 七月丁香在线播放| 日韩av免费高清视频| 91在线精品国自产拍蜜月| 亚洲四区av| 三级国产精品片| 国产色婷婷99| 国内少妇人妻偷人精品xxx网站| 五月玫瑰六月丁香| 国产老妇伦熟女老妇高清| 国产日韩欧美亚洲二区| 亚洲国产高清在线一区二区三| 精品一区二区免费观看| 欧美日韩国产mv在线观看视频 | 久久久久精品久久久久真实原创| 男男h啪啪无遮挡| 久久久久久久大尺度免费视频| 尾随美女入室| freevideosex欧美| 色视频在线一区二区三区| 三级国产精品片| 欧美老熟妇乱子伦牲交| 国产 一区精品| 视频中文字幕在线观看| 亚洲国产成人一精品久久久| 三级经典国产精品| 亚洲伊人久久精品综合| 久久国内精品自在自线图片| 精品一品国产午夜福利视频| 国产黄色免费在线视频| 一区二区三区精品91| 国产 一区精品| 黄色怎么调成土黄色| 久久精品久久久久久久性| 欧美高清成人免费视频www| 22中文网久久字幕| 国产精品女同一区二区软件| 久久久久久久国产电影| 国产精品一区二区在线观看99| 少妇被粗大猛烈的视频| 欧美成人一区二区免费高清观看| 男人添女人高潮全过程视频| freevideosex欧美| 免费观看无遮挡的男女| 国产v大片淫在线免费观看| 在线播放无遮挡| 2022亚洲国产成人精品| 国产精品精品国产色婷婷| 少妇熟女欧美另类| 亚洲最大成人中文| 最近最新中文字幕免费大全7| 最后的刺客免费高清国语| 国产大屁股一区二区在线视频| 你懂的网址亚洲精品在线观看| 七月丁香在线播放| 亚洲人与动物交配视频| 欧美+日韩+精品| 欧美精品一区二区免费开放| 亚洲精品久久午夜乱码| 国产乱人偷精品视频| 久久女婷五月综合色啪小说| 亚洲精品色激情综合| 99久久精品国产国产毛片| 国产精品麻豆人妻色哟哟久久| 国产成人精品久久久久久| 亚洲av福利一区| 在线 av 中文字幕| 高清视频免费观看一区二区| 精品国产三级普通话版| 午夜老司机福利剧场| 久久精品国产亚洲av天美| .国产精品久久| 日韩制服骚丝袜av| 久久久色成人| 久久亚洲国产成人精品v| av播播在线观看一区| 久久99热这里只频精品6学生| 香蕉精品网在线| 亚洲最大成人中文| 亚洲自偷自拍三级| 麻豆乱淫一区二区| 亚洲经典国产精华液单| 啦啦啦在线观看免费高清www| 在线免费十八禁| 成人午夜精彩视频在线观看| av免费观看日本| 啦啦啦视频在线资源免费观看| 高清毛片免费看| 99精国产麻豆久久婷婷| 国产亚洲最大av| 人妻系列 视频| 十八禁网站网址无遮挡 | 最近中文字幕高清免费大全6| 久久久久久久大尺度免费视频| .国产精品久久| 日韩中文字幕视频在线看片 | 国产真实伦视频高清在线观看| 国精品久久久久久国模美| 97在线人人人人妻| 久久精品人妻少妇| 啦啦啦视频在线资源免费观看| 日日啪夜夜爽| 亚洲精品乱码久久久久久按摩| 观看美女的网站| 在线亚洲精品国产二区图片欧美 | 亚洲久久久国产精品| 一区在线观看完整版| 啦啦啦视频在线资源免费观看| 中文字幕人妻熟人妻熟丝袜美| av.在线天堂| 欧美另类一区| 欧美极品一区二区三区四区| 纵有疾风起免费观看全集完整版| 成人漫画全彩无遮挡| 国产精品久久久久久久久免| 国产黄片美女视频| 夫妻午夜视频| 久久精品国产亚洲av天美| 美女中出高潮动态图| 这个男人来自地球电影免费观看 | 国产成人精品婷婷| 国产亚洲一区二区精品| 欧美三级亚洲精品| 视频中文字幕在线观看| 日韩视频在线欧美| freevideosex欧美| 亚洲综合精品二区| 亚洲欧美成人精品一区二区| 免费播放大片免费观看视频在线观看| 日韩免费高清中文字幕av| 联通29元200g的流量卡| 汤姆久久久久久久影院中文字幕| 好男人视频免费观看在线| 亚洲国产毛片av蜜桃av| 欧美日韩在线观看h| 男男h啪啪无遮挡| 国产日韩欧美在线精品| 街头女战士在线观看网站| 免费观看无遮挡的男女| 人妻 亚洲 视频| 国产午夜精品久久久久久一区二区三区| 高清不卡的av网站| 国产色爽女视频免费观看| 国内少妇人妻偷人精品xxx网站| 观看美女的网站| 日日啪夜夜爽| 街头女战士在线观看网站| 久久午夜福利片| 中文字幕久久专区| 看非洲黑人一级黄片| 成人美女网站在线观看视频| 亚洲欧美一区二区三区黑人 | 日韩一区二区三区影片| 亚洲经典国产精华液单| 精品久久久久久久久av| 在线 av 中文字幕| 干丝袜人妻中文字幕| 国产亚洲91精品色在线| 丰满乱子伦码专区| 久久6这里有精品| 国产 精品1| 直男gayav资源| 小蜜桃在线观看免费完整版高清| 亚洲欧美一区二区三区黑人 | 日韩国内少妇激情av| freevideosex欧美| a级毛片免费高清观看在线播放| 五月天丁香电影| 成人美女网站在线观看视频| 精品熟女少妇av免费看| 色婷婷av一区二区三区视频| 18禁在线无遮挡免费观看视频| 国产精品一二三区在线看| 亚洲中文av在线| 国产男人的电影天堂91| 午夜精品国产一区二区电影| 亚洲精品aⅴ在线观看| 久久人人爽av亚洲精品天堂 | 激情 狠狠 欧美| 亚洲人成网站在线播| 成人毛片a级毛片在线播放| 色视频在线一区二区三区| 精品亚洲成a人片在线观看 | 最近最新中文字幕大全电影3| 国产极品天堂在线| 插阴视频在线观看视频| 一个人看视频在线观看www免费| 七月丁香在线播放| 中文字幕亚洲精品专区| 国产免费一级a男人的天堂| 91在线精品国自产拍蜜月| 精品久久久噜噜| 91aial.com中文字幕在线观看| 插阴视频在线观看视频| 五月开心婷婷网| 九色成人免费人妻av| 特大巨黑吊av在线直播| 亚洲精品自拍成人| 日韩亚洲欧美综合| 欧美区成人在线视频| 久久ye,这里只有精品| 亚洲图色成人| 精品人妻视频免费看| 18禁裸乳无遮挡免费网站照片| 日韩成人伦理影院| 免费不卡的大黄色大毛片视频在线观看| 啦啦啦啦在线视频资源| 国产永久视频网站| 夫妻午夜视频| av卡一久久| 国产伦精品一区二区三区视频9| 视频中文字幕在线观看| 超碰97精品在线观看| 人妻一区二区av| 精品人妻偷拍中文字幕| 久久ye,这里只有精品| 国产视频内射| 国产伦理片在线播放av一区| 欧美精品一区二区免费开放| 午夜免费鲁丝| 久久久久久久大尺度免费视频| 黄色日韩在线| 久久久久久久久大av| 国语对白做爰xxxⅹ性视频网站| 久久久a久久爽久久v久久| 成人毛片60女人毛片免费| 欧美另类一区| 99热这里只有是精品50| 日本wwww免费看| 国产中年淑女户外野战色| 最近中文字幕2019免费版| 久久久精品94久久精品| 精品久久久噜噜| 在线观看一区二区三区| 国产v大片淫在线免费观看| 精品人妻偷拍中文字幕| 国产片特级美女逼逼视频| 日韩,欧美,国产一区二区三区| 男女边吃奶边做爰视频| 男女无遮挡免费网站观看| 一区在线观看完整版| 精品人妻熟女av久视频| 国产成人精品久久久久久| 一二三四中文在线观看免费高清| 熟女av电影| 久久人人爽人人爽人人片va| 国产大屁股一区二区在线视频| 一区在线观看完整版| 亚洲人与动物交配视频| 91久久精品电影网| 亚洲av免费高清在线观看| 黄色一级大片看看| 人人妻人人添人人爽欧美一区卜 | 亚洲精品乱码久久久久久按摩| 日韩免费高清中文字幕av| 免费大片黄手机在线观看| 国产乱来视频区| 欧美+日韩+精品| 国产精品免费大片| 久久国产精品男人的天堂亚洲 | 日韩视频在线欧美| 免费不卡的大黄色大毛片视频在线观看| 亚洲国产成人一精品久久久| freevideosex欧美| 国产黄色视频一区二区在线观看| 成年美女黄网站色视频大全免费 | 在线观看美女被高潮喷水网站| 亚洲第一av免费看| 日日撸夜夜添| av在线app专区| 看非洲黑人一级黄片| 麻豆精品久久久久久蜜桃| 在线看a的网站| 国产成人a∨麻豆精品| 日日摸夜夜添夜夜添av毛片| av一本久久久久| 亚洲av成人精品一区久久| 九九久久精品国产亚洲av麻豆| 啦啦啦啦在线视频资源| 亚洲欧美精品专区久久| 麻豆乱淫一区二区| 国产极品天堂在线| 日韩一区二区三区影片| av在线观看视频网站免费| 黄色视频在线播放观看不卡| 人妻夜夜爽99麻豆av| 亚洲精品国产av成人精品| 国产黄片美女视频| 少妇猛男粗大的猛烈进出视频| 伦精品一区二区三区| 国产亚洲午夜精品一区二区久久| 联通29元200g的流量卡| 国产一区亚洲一区在线观看| 精品久久久噜噜| 高清日韩中文字幕在线| 中文在线观看免费www的网站| 少妇被粗大猛烈的视频| 精品99又大又爽又粗少妇毛片| 午夜福利在线在线| 99热6这里只有精品| av网站免费在线观看视频| 日本一二三区视频观看| 国产有黄有色有爽视频| 一本久久精品| 九九在线视频观看精品| 美女cb高潮喷水在线观看| 亚洲色图av天堂| 日本av手机在线免费观看| 色5月婷婷丁香| 激情 狠狠 欧美| 欧美变态另类bdsm刘玥| 免费av中文字幕在线| 日本欧美视频一区| 亚洲自偷自拍三级| 联通29元200g的流量卡| 亚洲国产欧美人成| 久热这里只有精品99| 爱豆传媒免费全集在线观看| 夜夜爽夜夜爽视频| 国产亚洲91精品色在线| 秋霞伦理黄片| 多毛熟女@视频| 久久婷婷青草| 一级a做视频免费观看| 国产成人精品一,二区| 一本色道久久久久久精品综合| 极品少妇高潮喷水抽搐| 亚洲av.av天堂| 丝瓜视频免费看黄片| 免费播放大片免费观看视频在线观看| 亚洲图色成人| 日韩大片免费观看网站| 国产免费又黄又爽又色| 国产亚洲欧美精品永久| 成人一区二区视频在线观看| 免费久久久久久久精品成人欧美视频 | 免费人成在线观看视频色| 免费不卡的大黄色大毛片视频在线观看| 又爽又黄a免费视频| 亚洲国产精品专区欧美| 亚洲国产毛片av蜜桃av| 亚洲av福利一区| 丝袜喷水一区| 大码成人一级视频| 男人添女人高潮全过程视频| 久久久精品94久久精品| 欧美高清成人免费视频www| 日韩强制内射视频| a级一级毛片免费在线观看| 国产亚洲欧美精品永久| 国产在线男女| 一级毛片久久久久久久久女| 免费大片黄手机在线观看| 高清不卡的av网站| 99精国产麻豆久久婷婷| 色婷婷久久久亚洲欧美| 男女边摸边吃奶| 国产成人aa在线观看| 两个人的视频大全免费| 在线免费观看不下载黄p国产| 中文字幕av成人在线电影| 黄色视频在线播放观看不卡| 久久久午夜欧美精品| 99热6这里只有精品| 久久99精品国语久久久| 特大巨黑吊av在线直播| 久久久成人免费电影| 国产日韩欧美亚洲二区| 国产成人精品婷婷| 国产成人午夜福利电影在线观看| 欧美性感艳星| 亚洲中文av在线| 亚洲婷婷狠狠爱综合网| 亚洲欧美精品自产自拍| 丝袜脚勾引网站| 我的老师免费观看完整版| 亚洲综合精品二区| 交换朋友夫妻互换小说| 午夜激情福利司机影院| 国产精品成人在线| 亚洲欧美一区二区三区国产| 日韩欧美 国产精品| 18禁裸乳无遮挡免费网站照片| 色5月婷婷丁香| 少妇丰满av| 在线免费十八禁| 人妻一区二区av| 一边亲一边摸免费视频| 熟妇人妻不卡中文字幕| 国产黄色免费在线视频| 婷婷色综合www| 大香蕉久久网| 伦理电影免费视频| 观看免费一级毛片| 最黄视频免费看| 最近的中文字幕免费完整| 人体艺术视频欧美日本| 免费大片18禁| 青春草视频在线免费观看| 亚洲综合色惰| 中文字幕亚洲精品专区| 久久99精品国语久久久| 国产成人aa在线观看| freevideosex欧美| 女的被弄到高潮叫床怎么办| 精品久久久久久电影网| 精品一区二区三卡| 青春草亚洲视频在线观看| 亚洲最大成人中文| 插阴视频在线观看视频| 久久久久久九九精品二区国产| 免费在线观看成人毛片| 3wmmmm亚洲av在线观看| av在线app专区| 久久人人爽人人爽人人片va| 国产伦理片在线播放av一区| 国产成人a∨麻豆精品| 夜夜看夜夜爽夜夜摸| 丝袜脚勾引网站| 一区二区三区精品91| 中文字幕亚洲精品专区| 爱豆传媒免费全集在线观看| 国产又色又爽无遮挡免| 久久 成人 亚洲| 国产男女超爽视频在线观看| 在现免费观看毛片| 一区二区三区精品91| 午夜精品国产一区二区电影| 国产一区亚洲一区在线观看| 亚洲精华国产精华液的使用体验| 一二三四中文在线观看免费高清| 日本-黄色视频高清免费观看| 久久久久精品性色| 国产精品福利在线免费观看| 国产91av在线免费观看| 自拍欧美九色日韩亚洲蝌蚪91 | 国产极品天堂在线| 成年av动漫网址| 一级毛片 在线播放| 日韩一区二区视频免费看| 久久人人爽av亚洲精品天堂 | 人妻少妇偷人精品九色| 国产午夜精品久久久久久一区二区三区| 黄色配什么色好看| 国产精品久久久久久av不卡| 永久免费av网站大全| 亚洲精品成人av观看孕妇| 最黄视频免费看| 免费黄频网站在线观看国产| 免费av中文字幕在线| 免费看光身美女| 好男人视频免费观看在线| 午夜福利网站1000一区二区三区| 欧美3d第一页| 久久久成人免费电影| 久久精品熟女亚洲av麻豆精品| 久久ye,这里只有精品| 岛国毛片在线播放| 日韩亚洲欧美综合| 日本av免费视频播放| 亚洲美女搞黄在线观看| 国产亚洲91精品色在线| 亚洲久久久国产精品| 欧美成人一区二区免费高清观看| 男女啪啪激烈高潮av片| 狠狠精品人妻久久久久久综合| 一本—道久久a久久精品蜜桃钙片| 国产欧美日韩精品一区二区| 免费观看性生交大片5| 日本免费在线观看一区| 亚洲欧美日韩另类电影网站 | 天堂俺去俺来也www色官网| 99热国产这里只有精品6| 免费黄频网站在线观看国产| 亚洲av电影在线观看一区二区三区| 成人亚洲精品一区在线观看 | 熟女电影av网| 久久精品国产亚洲网站| 精品一区二区免费观看| 久久毛片免费看一区二区三区| 免费观看无遮挡的男女| 国产免费一级a男人的天堂| 国产无遮挡羞羞视频在线观看| 久久99热这里只有精品18| av专区在线播放| 国精品久久久久久国模美| 亚洲欧美一区二区三区黑人 | 免费大片黄手机在线观看| 大香蕉97超碰在线| 国产精品无大码| 最近最新中文字幕大全电影3| 噜噜噜噜噜久久久久久91| 看免费成人av毛片| 亚洲精品日本国产第一区| 成人黄色视频免费在线看| 老师上课跳d突然被开到最大视频| 又粗又硬又长又爽又黄的视频| 内射极品少妇av片p| 日本一二三区视频观看| 亚洲美女黄色视频免费看| 精品人妻一区二区三区麻豆| 久久久久人妻精品一区果冻| 免费av不卡在线播放| 97精品久久久久久久久久精品| 久久精品国产自在天天线| 精品视频人人做人人爽| 亚洲aⅴ乱码一区二区在线播放| 我的老师免费观看完整版| 国产v大片淫在线免费观看| 国产一区亚洲一区在线观看| 内射极品少妇av片p| 亚洲av免费高清在线观看| 少妇人妻一区二区三区视频| 日本欧美视频一区| av在线播放精品| 两个人的视频大全免费| 中文字幕免费在线视频6| 精品久久国产蜜桃| 亚洲经典国产精华液单| 国产中年淑女户外野战色| 亚洲伊人久久精品综合| 欧美日本视频| 国语对白做爰xxxⅹ性视频网站| 久久99精品国语久久久| 亚洲国产毛片av蜜桃av| 国产黄片视频在线免费观看| 两个人的视频大全免费| 欧美高清性xxxxhd video| 黑人猛操日本美女一级片| 女性生殖器流出的白浆| 免费黄色在线免费观看| 高清日韩中文字幕在线| 久久久久久久久久成人| 中文乱码字字幕精品一区二区三区| 国产 一区精品| 大又大粗又爽又黄少妇毛片口| 欧美zozozo另类| 日韩av不卡免费在线播放| 久久久久久久久久久丰满| 久久影院123| 精品国产露脸久久av麻豆| 欧美3d第一页| 大片电影免费在线观看免费| 五月开心婷婷网| 少妇人妻精品综合一区二区| 日韩制服骚丝袜av| 亚洲无线观看免费| 色婷婷久久久亚洲欧美| 最新中文字幕久久久久| 人妻 亚洲 视频| av国产久精品久网站免费入址| 日日啪夜夜撸| 在线观看一区二区三区激情| 国产黄片视频在线免费观看| 国内少妇人妻偷人精品xxx网站| 久久精品国产a三级三级三级| 青春草亚洲视频在线观看| 日本-黄色视频高清免费观看| 特大巨黑吊av在线直播| 丰满乱子伦码专区| 在线天堂最新版资源| 国产一级毛片在线| 自拍欧美九色日韩亚洲蝌蚪91 | 久久99热这里只有精品18| 色5月婷婷丁香| 国产片特级美女逼逼视频| 久久国产乱子免费精品| 国产淫语在线视频| 卡戴珊不雅视频在线播放| 汤姆久久久久久久影院中文字幕| 亚洲人成网站高清观看| 亚洲aⅴ乱码一区二区在线播放| 男女免费视频国产| 久久99热6这里只有精品| 日韩一本色道免费dvd| 高清av免费在线| 亚洲精品一二三| 久久6这里有精品| 欧美日韩综合久久久久久| 男人爽女人下面视频在线观看| 亚洲精品日韩在线中文字幕| 国产欧美日韩一区二区三区在线 | av在线app专区| 成人特级av手机在线观看| 亚洲性久久影院| 国产免费一区二区三区四区乱码| 全区人妻精品视频| 国产中年淑女户外野战色| 欧美bdsm另类| 一个人免费看片子| 亚洲精品国产色婷婷电影| 99国产精品免费福利视频| 亚洲高清免费不卡视频| 国产精品一区二区性色av| 国产精品伦人一区二区|