一起草最新网址_日韩一区二区麻豆国产_91视频婷婷_日本一区二区视频在线_日韩激情一区二区三区_国产另类第一区_成人免费在线播放视频_亚洲永久精品ww.7491进入_久久这里有精品视频_久久精品一级片_日韩av在线网页_波多野结衣不卡视频

MVC模式在j2me項目中的應用一_JSP教程

編輯Tag賺U幣
教程Tag:暫無Tag,歡迎添加,賺取U幣!

推薦:J2ME中使用記錄存儲系統RMS存儲信息
在MIDP中,沒有文件的概念,所以永久存儲一般只能依靠記錄存儲系統實現,關于記錄存儲系統的簡介,可以參看教程:http://www-900.ibm.com/developerWorks/cn/java/j-wi-rms/index.sht

版權聲明:本文同時發表在www.j2medev.com和我的Blog(blog.csdn.net/alikeboy)上,如果需要轉載,有三個途徑:1)聯系我并經我同意;2)和www.j2medev.com有轉載文章合作協議的 3)通過Rss聚合我的Blog。另外網上轉載需要全文轉發(包括文章的頭部的聲明),不要斷章取義。

正文:

初識MVC模式

第一次認識到MVC模式是從Microsoft MFC框架所采用的“文檔-視圖”模型開始的。第一次接觸到這個概念讓我興奮不已,很長時間困擾我的程序框架問題似乎迎刃而解了。而后我翻閱了GOF一書中對MVC模式的描述,增進了對這個模式的一些理解。應該說MVC框架是程序設計領域的常青樹,也是GOF模式中最為重要的模式之一。這一經典的模式被廣泛的使用,有太多的程序構架在這一框架之下,從早期的卓面Application到現在流行的Web。并因各自的需求不同,MVC有了很多的變種。了解MVC是每個程序設計人員的必修課,最好能夠達到熟練運用的程度。

我并不打算詳細介紹這一模式,因為細節比較復雜,我口舌拙笨也不容易說清楚,大家應該參閱一下有關模式的書籍,任何一本都比我要講的清楚。所以此處就一帶而過。MVC模式是Model-View-Controller的縮寫,中文譯為“模型-視圖-控制器”。MVC的核心思想是分離。Model就是對實體類的抽象;View就是Model在屏幕上的表示;Controller就是協調者?赡苡信笥寻l現Controller的描述多少有些含糊,不要著急,這個一會還要談到。大概因為太過有名,MVC模式的每個實現都出處很大,但他們卻都叫做MVC!搞得初學者一頭霧水。往往濫用,最后搞得M.V.C.三者之間的協調很混亂。這其實并不是他們的錯,理清思路的關鍵還是剛剛提到的一個詞“分離”。盡管MVC實現不同,但是思想是一致的。

MVC模式的利與弊

先談優點:

1)將M.V.C.分離可以讓不同的專家負責不同的模塊,一般情況下,M部分由熟悉數據庫,網絡傳輸的專家來負責;V則交給對UI有研究的專家。這對于項目的管理者而言是多么的誘人,分工意味著可以提高效率并可以按照傳統的責任劃分來處理軟件開發過程。對開發者而言也可以專心于一個領域。這樣做的前提是接口要明確,MVC的分離思想正為其提供了基礎。

2)一旦V的部分發生變化,可以迅速的重構而不必引起整個工程的返工。如今的軟件表現層的部分變化實在是太快了…

3)M的部分,因為足夠抽象,可以方便的重復利用,符合OO的思想。另一方面我們可以利用JUnit等單元測試工具對M進行測試,保證工程質量。

談完了優點再來看看缺點:

1)利用MVC模式(也包括近代的其他一些模式)暗示我們通過多產生一些類,來提高程序的可讀性與健壯性。附帶來的缺點就是類的數量的膨脹。說句笑話,MVC就好像是發面時用的速效粉一樣,是最為方便的代碼膨脹劑,相信大家都深有體會:)

2)MVC雖然定義了M.V.C.個個部件的含義,但并不具體,而且沒有非常明確的固定三者之間的聯系。所以一直以來除了View沒有爭論外,其他方面都有很多爭論,大家都想把自己的理解作為正解。尤其是“Model到底是屏幕數據的集合還是實體數據”、“控制器的作用”是兩個經常爭論的問題。前面提過MVC變種很多,這也給初學者留下了不少的陷阱。后面結合實例將會分析幾種常見的做法。

3)MVC的實現成本偏高。但請注意是這是相對的,一般而言項目越大,越可以看出其優勢。

常見的MVC模式實踐

下面將會介紹在midp平臺幾種常見的實踐,最后是我習慣的做法

M—V形式(或者MC—V、M—VC

這也是在j2me中一種慣用的方法,精煉的說這種方法是以屏幕為組織單位的,因而很適合RAD工具的開發思路。一個屏幕及其控制被抽象成一個VC類,而這個類中有一個私有的Model對象來代表屏幕上要用到的數據元素。屏幕對象并不保存任何的實體數據,這些數據被組織在了Model對象中。大概因為屏幕對象很直觀,控制器的作用也不明晰(它絕大部分的功能被view或是model取代,具體取決于你的實現),所以也常常稱呼為model-view模式。形式如下:

class MyFrame extend Frame{

private Model model;

private StringItem name;

MyFrame(Model model){

this.model=model;

name=new StringItem(model.getName());//請求模型的數據

append(name);

}

}

class Model{

private String name="M-C pattern";

public String getName(){//這是一個服務接口

return name;

}

}

上面看到的是個典型的M—V模型,我們可以理解這種以屏幕為核心的分離的含義。Model組織起屏幕的數據,view向Model索要其希望顯示的數據,注意這一操作一定要通過預先協商好的接口訪問,而不是直接操作。如果出現復雜的事務邏輯(用戶選擇的某種操作),有人將其放在Model端,也有人放在View端,但一般上放在Model端,這時Model帶有嚴重的Controller的色彩。

這種形式的優點是非常的直觀,也有限的分離了顯示和數據。如果?磈2medev.com站長Mingjava的文章,可以看到大部分他寫的例子都是這種模式。并且這種模式也常常用于RAD工具。

這種模式的缺點是它與RAD工具一樣鼓勵你從屏幕開始思考問題,這往往讓你陷入RAD的陷阱——不先考慮事務的流程,而是從用戶接口直接下手去分析問題,這往往扼殺了你的全局構思。

Sun blueprints: Smart Ticket中使用的MVC模式

著名的藍圖程序Smart Ticket中使用了MVC模式,并且這一模式幫助Sun的程序員在MIDP2發布時,快速的將Smart Ticket的view部分從MIDP1.0 更新到MIDP2.0。

Sun針對MIDP的特點,設計并改進了這一模式,在SUN的解決方法中是一個很標準的方法,只是 Controller變成了一個巨大的事務處理器,所有由UI對象收集到的用戶的需求都轉發給Controller處理。Controller內部保存了一組常量。在一個dispose(int id)形式的方法里一個巨大的switch case語句根據比較不同的常量,處理不同的請求。這種技術有時也將Controller稱為處理器,或者屏幕導航器。這種模式的提出者主要是要集中處理j2me里頻繁的畫面導航。

很多人都覺得,在j2me中將Controller改造成巨大的事務處理器是一個很好的方法。我對此持保留意見。

iFeedback中簡化的MVC

為了大大減少類的數量,iFeedback的作者,將MVC封裝到一個類中,用不同的方法來代表對這三者的分離,這種舉動證明對減少類的數量又很大幫助。

public abstract class MVCComponent implements CommandListener {

// Set from outside at beginning

public static Display display;

// Returns the screen object from the derived class

public abstract Displayable getScreen();

public Displayable prepareScreen () throws Exception {

if ( getScreen() == null ) {

initModel();

createView();

} else {

updateView();

}

getScreen().setCommandListener ( (CommandListener) this );

return getScreen ();

}

public void showScreen() {

try {

display.setCurrent( prepareScreen() );

} catch (Exception e) {

e.printStackTrace();

Alert a = new Alert("Error in showing screen");

a.setTimeout(Alert.FOREVER);

display.setCurrent(a);

}

}

// Initialize. If a data member is not backed by RMS, make sure

// it is uninitilzed (null) before you put in values.

protected abstract void initModel () throws Exception;

protected abstract void createView () throws Exception;

protected abstract void updateView () throws Exception;

public abstract void commandAction(Command c, Displayable s);

}

因為都在一個類里面,你在也不必被MVC三者之間的關系操心了,這種退化的做法,是對MIDP有限資源的妥協。

我的習慣做法

下面結合我對MVC的理解和大家交流一下。我使用的是一種UML標準的做法,最大程度上對的體現分離的思想。首先和大家交流一下詞匯表:

View代表屏幕。

View通過預先商定好的接口向Controller索要數據,View同時收集用戶的輸入,View并不處理這些輸入,而是根據不同的輸入回調Controller不同的方法。通常View的子類使用UI后綴。

Controller 控制器

提供View調用的接口,負責和model交流?刂破骱蚔iew共同擔負起和用戶交流的作用。

Model 泛指一系列的實體對象

需要注意的是我理解的Model并不是屏幕數據的組織單位。Model代表一系列的實體對象。由Controller跟Model交流。我覺得RAD工具中常常將Model代表屏幕數據的集合正式導致MVC概念混亂的一個原因。RAD工具中Model,大體相當于這里的Controller所起的作用。

MVC模式在j2me項目中的應用(一)(圖一)

控制器并不總是聯系著Model,有時只是依賴關系。并且Controller往往通過Model的對應的生命期類來獲得Model對象。在這種形式中,層層隔離,View與Controller緊密相連,而Model有很高的獨立性,可以很好的重用。

一般的結合UML設計的過程,對MVC的各個類有相應的命名習慣。

View 稱為Boundary類(邊界類) 以UI結尾

Controller 稱為 Controller(控制類) 以Workflow結尾

Model 稱為Entity(實體類) 以Entity結尾或者沒有尾綴

Model對應的Lifecycle類(生命周期類) 以Locator結尾

MVC模式在j2me項目中的應用(一)(圖二)

邊界類和控制類的基礎類如下

BaseView.java

/**

* @author Favo

*

* 視圖類

*/

public abstract class BaseView {

public abstract Display getDisplay();

/**

* 簡單的返回包裝的屏幕對象,不要做任何準備屏幕的操作!

*/

public abstract Displayable getScreen();

/**

* 創建屏幕

*/

protected abstract void createView() throws Exception;

/**

* 更新屏幕

*/

public abstract void updateView() throws Exception;

/**

* 返回控制器

*/

public abstract BaseController getController();

/**

* 準備屏幕

* 返回準備好的屏幕對象

*/

public Displayable prepareScreen() throws Exception {

if(getScreen()==null){

createView();

} else {

updateView();

}

return getScreen();

}

/**

* 顯示當前屏幕

*/

public void displayScreen(){

try{

getDisplay().setCurrent(prepareScreen());

} catch (Exception e) {

e.printStackTrace();

Alert al=new Alert("Error",

e.toString() '\n' e.getMessage(),null,AlertType.ERROR);

al.setTimeout(Alert.FOREVER);

getDisplay().setCurrent(al);

}

}

}

BaseController.java

/**

* @author Favo

*

* 控制類

*/

public abstract class BaseController {

public abstract BaseView getView();

public abstract void setView(BaseView view);

}

注意到這些基礎的類并沒有向MFC框架那樣產生完整的框架,而是設計成了抽象類,一來希望強迫大家實現抽象類(防止出錯);二來希望增加一點靈活性。所以兩個類之間的通信就要靠大家撰寫的子類的構造函數了。一般我的習慣是,初始化好控制器,然后將控制器作為參數傳給邊界類的構造函數,由邊界類的構造函數來回調控制器的setView()來實現的。這些步驟是一定要有的,不然會NULLpointerExcpetion哦。

盡管理論上可能很清晰,但實踐帶來的復雜性是驚人的。這正是軟件開發的問題,太多的細節困擾這開發者對大局的把握。本文接下來,將結合最后這種設計思想,給出一個完整的設計實例。幫助大家從實踐的角度理解運用這一模式。敬請大家期待。

編輯推薦:MVC模式在j2me項目中的應用(二)   

分享:J2ME與MIDP開發1
MIDP是Mobile Information Devices Profile(移動信息設備簡表)的簡稱,而遵照 MIDP和CLDC規范編寫的 Java應用程序我們就稱其為 MIDlet。 你可以從MIDP這個規范的英文名稱的含義推測

來源:模板無憂//所屬分類:JSP教程/更新時間:2008-08-22
相關JSP教程
日韩中文视频免费在线观看| 欧美大片在线看免费观看| 欧美亚洲国产视频小说| 国产成年人在线观看| 乳色吐息在线观看| 自拍偷拍福利视频| 久久久久久日产精品| 欧美日韩激情在线| 国产精品69久久| 在线观看高清免费视频| 无码人妻久久一区二区三区| eeuss鲁片一区二区三区在线观看| 欧美亚洲日本国产| 国产欧美精品一区二区三区-老狼 国产欧美精品一区二区三区介绍 国产欧美精品一区二区 | 亚洲国产中文字幕久久网| 91亚洲精华国产精华| 三级黄色片免费观看| 天天操天天干天天爽| 欧洲一区在线电影| 97操在线视频| 日日操免费视频| 99国产精品99久久久久久| 日韩亚洲精品视频| 日本熟妇人妻xxxxx| 亚洲一区精品在线观看| 欧美午夜www高清视频| 亚洲最大福利视频网站| 极品蜜桃臀肥臀-x88av| 久久伊99综合婷婷久久伊| 欧美裸身视频免费观看| 久热在线视频观看| 麻豆精品在线观看| 中文字幕日韩欧美在线| 男人的天堂日韩| 蜜桃久久久久久久| 中文字幕日韩av电影| 伊人色在线视频| 岛国av在线一区| 亚洲欧美激情四射在线日| 日韩区在线观看| 一区二区精品国产| 中文字幕在线观看免费| 日韩一级片在线观看| 无码熟妇人妻av在线电影| а√天堂资源在线| 中文字幕精品一区久久久久| 日韩视频在线免费看| 国产精品中文字幕日韩精品| 高清一区二区三区四区五区| av在线网站观看| 成人欧美一区二区三区| 国产一区免费| 日本成人一级片| 欧美主播福利视频| 亚洲天堂最新地址| 国产精品美女久久福利网站| 精品久久久久99| 欧美爱爱视频网站| 免费在线观看成人| 国产精品久久久精品| 久久久久久久久久久久久女国产乱 | 奇米视频888战线精品播放| 国产美女免费无遮挡| 国产蜜臀av在线一区二区三区| 中文字幕久久亚洲| 精品人妻一区二区三区蜜桃视频| 成人激情免费电影网址| 国内精品久久久久伊人av| aaaaaaaa毛片| 国产拍欧美日韩视频二区| 国产乱码一区| 97精品久久人人爽人人爽| 精品国产三级a在线观看| 久久这里只有精品18| 精品一区二区无码| 少妇高潮久久久久久潘金莲| 日本天堂中文字幕| 亚洲女人被黑人巨大进入| 国产无遮挡又黄又爽| 精品国产精品网麻豆系列| 2018国产精品| 国产精品天天看| www.-级毛片线天内射视视| 日本在线视频免费观看| 日韩在线观看免费全| 久久久一二三区| 日韩一区二区在线播放| 国产成人av影视| 国产欧美一区二区精品性色| 精品人妻一区二区三区四区在线| 一区二区三区在线观看网站| 中文字幕 欧美日韩| 亚洲欧洲在线观看av| 色哟哟日韩精品| 亚洲欧美日韩三级| 欧美人与禽zozo性伦| av漫画在线观看| 日韩亚洲欧美在线| 精品一区在线观看视频| 日韩有码视频在线| 国产精品伦理一区| 亚洲xxxxx电影| 久久国产福利国产秒拍| 日韩电影免费观看在| 国产天堂亚洲国产碰碰| 91蝌蚪视频在线观看| 一区二区三区免费网站| 一区二区三区 欧美| 欧美一级视频精品观看| 精品视频在线观看免费| 欧美专区在线观看| 久久成人免费日本黄色| 99色这里只有精品| 9191久久久久久久久久久| 日本妇女毛茸茸| 国产欧亚日韩视频| 成人在线视频首页| 亚洲制服中文字幕| 国产精品美女久久久久av爽| 国产自产视频一区二区三区| 成人短视频在线观看免费| 欧美日韩亚洲天堂| 国产天堂av在线| 成人淫片在线看| 最新国产成人在线观看| 亚洲乱熟女一区二区| 亚洲第一综合网站| 欧美性猛交xxx| 日韩 欧美 亚洲| 在线成人性视频| 精品久久久久一区二区国产| 国产黄a三级三级看三级| 欧美一级特黄aaaaaa在线看片| 91精品国产福利在线观看| 精品国产亚洲一区二区麻豆| 国产精品无码av在线播放| 亚洲香蕉伊综合在人在线视看| 免费国产精品视频| 一二三级黄色片| 日本精品久久久久影院| 亚洲美女在线国产| 99热在线观看免费精品| 国产精品88久久久久久妇女| 日韩精品在线免费观看| 狠狠色综合播放一区二区| 爱爱免费小视频| 精品免费视频123区| 日韩一级高清毛片| 紧缚奴在线一区二区三区| 波多野结衣a v在线| 久久综合色一本| 国产亚洲精品美女久久久| 久久综合久久鬼色| 日韩精品――中文字幕| 成人在线视频一区二区三区| 日韩在线中文字| 亚洲视频一区在线| 在线播放精品视频| 亚洲最大成人在线观看| 国产精品普通话| 精品国产青草久久久久福利| 99久久精品情趣| 中文字幕乱伦视频| xxx中文字幕| 久久资源亚洲| 久久久精品久久久| 精品久久久久久亚洲精品| 久久久久.com| 久久97人妻无码一区二区三区| 国产亚洲精品久久久久久久| 久久久最新网址| 欧美一区二区三区在线看| 91麻豆swag| 亚洲第一色视频| 黄色免费看视频| 中文字幕在线亚洲精品| 久久久久久免费精品| 欧美日韩一区二区免费在线观看| 懂色av一区二区三区四区| 美国精品一区二区| 啊啊啊国产视频| 欧美日韩一区二区三区在线视频 | 日日摸夜夜添夜夜添亚洲女人| 成人无码精品1区2区3区免费看 | 麻豆91精品视频| 波多野结衣在线观看一区| 影音先锋黄色资源| 可以免费观看av毛片| 蜜桃av久久久亚洲精品| 色999日韩欧美国产| 亚洲一区二区在线播放相泽| 久久99热这里只有精品| 久久狠狠高潮亚洲精品| 免费看的黄色录像| 男人的天堂免费| 国产精品50p| 天堂v在线视频| 日本精品视频在线| 在线播放国产一区二区三区| 欧美三级中文字| 精品福利一区二区| 国产日本一区二区| 国产大片一区二区| 日韩精品午夜视频| 五月激情婷婷综合| 亚洲天堂五月天| 亚洲高清毛片一区二区| 欧美在线视频第一页| www.88av| 91 视频免费观看| 午夜免费看毛片| 天天色综合天天色| 丰满人妻中伦妇伦精品app| 黄色一级片国产| 欧美一区二区三区四区五区六区 | 久久久久99精品成人片我成大片| 女教师淫辱の教室蜜臀av软件| 国产不卡一二三| 久久午夜福利电影| 日本一区二区视频在线播放| 亚洲国产精品毛片av不卡在线| 国产毛片久久久久久国产毛片| 中文字幕制服丝袜在线| 亚洲精品中文字幕在线| 日韩欧美亚洲v片| 天堂社区 天堂综合网 天堂资源最新版| 欧美精品久久久| 在线免费观看成人| 在线不卡视频一区二区| av动漫在线播放| 中文字幕视频三区| www.污网站| 日韩在线视频免费看| 337p粉嫩色噜噜噜大肥臀| 91麻豆成人精品国产免费网站| 手机看片1024国产| 中文字幕视频免费观看| 探花国产精品一区二区| 精品黑人一区二区三区在线观看| 奇米色777欧美一区二区| av资源网一区| 亚洲精品国产成人久久av盗摄| 欧美日韩精品国产| 亚洲精品一线二线三线无人区| 久久九九精品99国产精品| 日本免费久久高清视频| 欧美激情专区| 91小视频网站| 久久久久久久国产精品毛片| 中文在线字幕免费观| 久久精品国产久精国产爱| 国产精品国产三级国产普通话蜜臀| 一本大道久久a久久精品综合| 日韩欧美国产电影| 久久久久久久久久久免费| 欧美美女一区二区| 日韩免费中文专区| 久久久天堂国产精品| 亚洲成色www.777999| 午夜精品久久久久99蜜桃最新版| 亚洲图片小说视频| 国产成人免费在线观看| 91成人国产精品| 欧美—级a级欧美特级ar全黄| 国产伦精品一区二区三区视频免费| 免费无码不卡视频在线观看| 黄色片子在线观看| 青青青爽久久午夜综合久久午夜| 精品国产31久久久久久| 久久久久久久久久久免费精品| 在线观看欧美一区| 亚洲欧美卡通动漫| 麻豆一区二区三| 欧美日韩一区小说| 国产精品久久久久久久天堂| 冲田杏梨av在线| 无码人妻av免费一区二区三区| 大陆成人av片| 亚洲第一成年人网站| 久久精品国产网站| 7777精品伊人久久久大香线蕉完整版 | 色噜噜夜夜夜综合网| 91极品女神在线| 手机av在线网| 成人爽a毛片一区二区| 欧美日韩亚洲一区二| 国产精品人成电影| 原创真实夫妻啪啪av| 天天操天天爱天天干| 日韩三级.com| 牛人盗摄一区二区三区视频| 99热在线国产| 啪啪一区二区三区| 久久久久久久久一| 久久偷看各类女兵18女厕嘘嘘| 玩弄中年熟妇正在播放| 99精品人妻国产毛片| 欧美日韩亚洲91| 精品在线观看一区二区| 久久中文字幕在线观看| 亚洲夂夂婷婷色拍ww47| 国产成人极品视频| 国产精品九九九九九| av一区二区三区| 人人爽久久涩噜噜噜网站| 麻豆av免费看| 久久久精品tv| 日韩精品视频免费| 亚洲欧美欧美一区二区三区| 清纯唯美亚洲综合| 性欧美13一14内谢| 国产人成一区二区三区影院| 奇门遁甲1982国语版免费观看高清| 性生活一级大片| 国产精品一区一区| 日韩av快播网址| 久久久久久久久久久久国产| 一区二区三区中文字幕精品精品| 九九热这里只有在线精品视| 日韩在线一区视频| 成人精品一区二区三区中文字幕| 精品不卡在线| av大全在线观看| 91精品久久久久久久91蜜桃| 精品欧美一区免费观看α√| 玖玖在线精品| 久久天天躁狠狠躁夜夜av| 国产精成人品免费观看| 黑人巨大精品欧美一区二区| 成人国产1314www色视频| 波多野结衣视频网址| 亚洲日韩中文字幕| 97在线观看免费视频| 欧美丰满少妇xxxbbb| 黄色a级三级三级三级| 亚洲视频网在线直播| 天天做天天爱天天高潮| 国产sm精品调教视频网站| 91丨九色丨国产| 日韩高清在线观看| 51精品国产人成在线观看| 神马久久久久久久久久| 国产欧美一区二区| 国产欧美久久久精品免费| 91超碰caoporn97人人| 中文字幕777| 国产成人精品视频在线| 国产乱码77777777| 久久久久久久久久久久av| 波多野结衣在线电影| 九色精品美女在线| 国产精品国产三级国产aⅴ| 日本一本a高清免费不卡| 亚洲xxx在线| 成人在线免费观看一区| 国产精品88av| 日韩欧美一级在线| 中文字幕一区二区三区不卡| 久久精品国产精品亚洲色婷婷| √…a在线天堂一区| 天天影视色综合| 欧美日韩不卡一区二区| 性欧美13一14内谢| 亚洲网站在线播放| 日韩精品一区二区三区国语自制| 欧美成人合集magnet| 国产精品视频久久久久久| 成人性生交大片免费看小说| 日韩国产精品久久| 亚洲欧美日韩精品综合在线观看| 成人一区二区三区在线观看| 精品一区二区三区毛片| 欧美性猛交xxxx黑人| 蜜臀久久99精品久久久久久| 国产视频久久久久| 在线播放国产一区| 日韩国产欧美一区| 夜夜揉揉日日人人青青一国产精品| 精品人妻一区二区三区日产| 亚洲欧美三级伦理| 四虎永久在线精品免费网址| 欧美一区二区三区四区夜夜大片 | 亚洲欧美综合自拍| 成人性生交大片免费观看嘿嘿视频| 色婷婷在线视频| www.射射射| 精品粉嫩aⅴ一区二区三区四区| 四虎成人永久免费视频| www.久久艹| 精品日韩视频在线观看| 天天看片中文字幕| 精品久久久久久亚洲综合网| 亚洲在线欧美| 自拍视频在线观看一区二区| 日韩av福利在线观看| 在线中文字幕日韩| 国产美女精品在线| 男人的天堂日韩| 在线精品国产欧美| 麻豆视频一区二区| 日韩精品在线播放视频| 欧美精品videossex88| 日韩不卡免费视频| www.成人黄色| 91精品国产一区| 综合激情成人伊人| 中文字幕人妻一区二| 日韩成人在线资源| 欧美成人一级视频| 日本少妇一区二区|