久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

2W 字详解设计模式!

發(fā)布時間:2025/3/16 asp.net 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 2W 字详解设计模式! 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.


-? ? ?前言??? -

設(shè)計(jì)模式是對大家實(shí)際工作中寫的各種代碼進(jìn)行高層次抽象的總結(jié),其中最出名的當(dāng)屬?Gang of Four?(GoF) 的分類了,他們將設(shè)計(jì)模式分類為 23 種經(jīng)典的模式,根據(jù)用途我們又可以分為三大類,分別為創(chuàng)建型模式、結(jié)構(gòu)型模式和行為型模式。

有一些重要的設(shè)計(jì)原則在開篇和大家分享下,這些原則將貫通全文:

  • 面向接口編程,而不是面向?qū)崿F(xiàn)。這個很重要,也是優(yōu)雅的、可擴(kuò)展的代碼的第一步,這就不需要多說了吧。

  • 職責(zé)單一原則。每個類都應(yīng)該只有一個單一的功能,并且該功能應(yīng)該由這個類完全封裝起來。

  • 對修改關(guān)閉,對擴(kuò)展開放。對修改關(guān)閉是說,我們辛辛苦苦加班寫出來的代碼,該實(shí)現(xiàn)的功能和該修復(fù)的 bug 都完成了,別人可不能說改就改;對擴(kuò)展開放就比較好理解了,也就是說在我們寫好的代碼基礎(chǔ)上,很容易實(shí)現(xiàn)擴(kuò)展。

  • 創(chuàng)建型模式比較簡單,但是會比較沒有意思,結(jié)構(gòu)型和行為型比較有意思。

    創(chuàng)建型模式

    創(chuàng)建型模式的作用就是創(chuàng)建對象,說到創(chuàng)建一個對象,最熟悉的就是 new 一個對象,然后 set 相關(guān)屬性。但是,在很多場景下,我們需要給客戶端提供更加友好的創(chuàng)建對象的方式,尤其是那種我們定義了類,但是需要提供給其他開發(fā)者用的時候。

    簡單工廠模式

    和名字一樣簡單,非常簡單,直接上代碼吧:

    public?class?FoodFactory?{public?static?Food?makeFood(String?name)?{if?(name.equals("noodle"))?{Food?noodle?=?new?LanZhouNoodle();noodle.addSpicy("more");return?noodle;}?else?if?(name.equals("chicken"))?{Food?chicken?=?new?HuangMenChicken();chicken.addCondiment("potato");return?chicken;}?else?{return?null;}} }

    其中,LanZhouNoodle 和 HuangMenChicken 都繼承自 Food。

    簡單地說,簡單工廠模式通常就是這樣,一個工廠類 XxxFactory,里面有一個靜態(tài)方法,根據(jù)我們不同的參數(shù),返回不同的派生自同一個父類(或?qū)崿F(xiàn)同一接口)的實(shí)例對象。

    我們強(qiáng)調(diào)職責(zé)單一原則,一個類只提供一種功能,FoodFactory 的功能就是只要負(fù)責(zé)生產(chǎn)各種 Food。


    -? ? ?工廠模式??? -

    簡單工廠模式很簡單,如果它能滿足我們的需要,我覺得就不要折騰了。之所以需要引入工廠模式,是因?yàn)槲覀兺枰褂脙蓚€或兩個以上的工廠。

    public?interface?FoodFactory?{Food?makeFood(String?name); } public?class?ChineseFoodFactory?implements?FoodFactory?{@Overridepublic?Food?makeFood(String?name)?{if?(name.equals("A"))?{return?new?ChineseFoodA();}?else?if?(name.equals("B"))?{return?new?ChineseFoodB();}?else?{return?null;}} } public?class?AmericanFoodFactory?implements?FoodFactory?{@Overridepublic?Food?makeFood(String?name)?{if?(name.equals("A"))?{return?new?AmericanFoodA();}?else?if?(name.equals("B"))?{return?new?AmericanFoodB();}?else?{return?null;}} }

    其中,ChineseFoodA、ChineseFoodB、AmericanFoodA、AmericanFoodB 都派生自 Food。

    客戶端調(diào)用:

    public?class?APP?{public?static?void?main(String[]?args)?{//?先選擇一個具體的工廠FoodFactory?factory?=?new?ChineseFoodFactory();//?由第一步的工廠產(chǎn)生具體的對象,不同的工廠造出不一樣的對象Food?food?=?factory.makeFood("A");} }

    雖然都是調(diào)用 makeFood("A") 制作 A 類食物,但是,不同的工廠生產(chǎn)出來的完全不一樣。

    第一步,我們需要選取合適的工廠,然后第二步基本上和簡單工廠一樣。

    核心在于,我們需要在第一步選好我們需要的工廠。比如,我們有 LogFactory 接口,實(shí)現(xiàn)類有 FileLogFactory 和 KafkaLogFactory,分別對應(yīng)將日志寫入文件和寫入 Kafka 中,顯然,我們客戶端第一步就需要決定到底要實(shí)例化 FileLogFactory 還是 KafkaLogFactory,這將決定之后的所有的操作。

    雖然簡單,不過我也把所有的構(gòu)件都畫到一張圖上,這樣讀者看著比較清晰:


    抽象工廠模式

    當(dāng)涉及到產(chǎn)品族的時候,就需要引入抽象工廠模式了。

    一個經(jīng)典的例子是造一臺電腦。我們先不引入抽象工廠模式,看看怎么實(shí)現(xiàn)。

    因?yàn)殡娔X是由許多的構(gòu)件組成的,我們將 CPU 和主板進(jìn)行抽象,然后 CPU 由 CPUFactory 生產(chǎn),主板由 MainBoardFactory 生產(chǎn),然后,我們再將 CPU 和主板搭配起來組合在一起,如下圖:

    這個時候的客戶端調(diào)用是這樣的:

    //?得到?Intel?的?CPU CPUFactory?cpuFactory?=?new?IntelCPUFactory(); CPU?cpu?=?intelCPUFactory.makeCPU();//?得到?AMD?的主板 MainBoardFactory?mainBoardFactory?=?new?AmdMainBoardFactory(); MainBoard?mainBoard?=?mainBoardFactory.make();//?組裝?CPU?和主板 Computer?computer?=?new?Computer(cpu,?mainBoard);

    單獨(dú)看 CPU 工廠和主板工廠,它們分別是前面我們說的工廠模式。這種方式也容易擴(kuò)展,因?yàn)橐o電腦加硬盤的話,只需要加一個 HardDiskFactory 和相應(yīng)的實(shí)現(xiàn)即可,不需要修改現(xiàn)有的工廠。

    但是,這種方式有一個問題,那就是如果 Intel 家產(chǎn)的 CPU 和 AMD 產(chǎn)的主板不能兼容使用,那么這代碼就容易出錯,因?yàn)榭蛻舳瞬⒉恢浪鼈儾患嫒?#xff0c;也就會錯誤地出現(xiàn)隨意組合。

    下面就是我們要說的產(chǎn)品族的概念,它代表了組成某個產(chǎn)品的一系列附件的集合:

    當(dāng)涉及到這種產(chǎn)品族的問題的時候,就需要抽象工廠模式來支持了。我們不再定義 CPU 工廠、主板工廠、硬盤工廠、顯示屏工廠等等,我們直接定義電腦工廠,每個電腦工廠負(fù)責(zé)生產(chǎn)所有的設(shè)備,這樣能保證肯定不存在兼容問題。

    這個時候,對于客戶端來說,不再需要單獨(dú)挑選 CPU廠商、主板廠商、硬盤廠商等,直接選擇一家品牌工廠,品牌工廠會負(fù)責(zé)生產(chǎn)所有的東西,而且能保證肯定是兼容可用的。

    public?static?void?main(String[]?args)?{//?第一步就要選定一個“大廠”ComputerFactory?cf?=?new?AmdFactory();//?從這個大廠造?CPUCPU?cpu?=?cf.makeCPU();//?從這個大廠造主板MainBoard?board?=?cf.makeMainBoard();//?從這個大廠造硬盤HardDisk?hardDisk?=?cf.makeHardDisk();//?將同一個廠子出來的?CPU、主板、硬盤組裝在一起Computer?result?=?new?Computer(cpu,?board,?hardDisk); }

    當(dāng)然,抽象工廠的問題也是顯而易見的,比如我們要加個顯示器,就需要修改所有的工廠,給所有的工廠都加上制造顯示器的方法。這有點(diǎn)違反了對修改關(guān)閉,對擴(kuò)展開放這個設(shè)計(jì)原則。

    單例模式

    單例模式用得最多,錯得最多。

    餓漢模式最簡單:

    public?class?Singleton?{//?首先,將?new?Singleton()?堵死private?Singleton()?{};//?創(chuàng)建私有靜態(tài)實(shí)例,意味著這個類第一次使用的時候就會進(jìn)行創(chuàng)建private?static?Singleton?instance?=?new?Singleton();public?static?Singleton?getInstance()?{return?instance;}//?瞎寫一個靜態(tài)方法。這里想說的是,如果我們只是要調(diào)用 Singleton.getDate(...),//?本來是不想要生成?Singleton?實(shí)例的,不過沒辦法,已經(jīng)生成了public?static?Date?getDate(String?mode)?{return?new?Date();} }

    很多人都能說出餓漢模式的缺點(diǎn),可是我覺得生產(chǎn)過程中,很少碰到這種情況:你定義了一個單例的類,不需要其實(shí)例,可是你卻把一個或幾個你會用到的靜態(tài)方法塞到這個類中。

    飽漢模式最容易出錯:

    public?class?Singleton?{//?首先,也是先堵死?new?Singleton()?這條路private?Singleton()?{}//?和餓漢模式相比,這邊不需要先實(shí)例化出來,注意這里的?volatile,它是必須的private?static?volatile?Singleton?instance?=?null;public?static?Singleton?getInstance()?{if?(instance?==?null)?{//?加鎖synchronized?(Singleton.class)?{//?這一次判斷也是必須的,不然會有并發(fā)問題if?(instance?==?null)?{instance?=?new?Singleton();}}}return?instance;} }

    雙重檢查,指的是兩次檢查 instance 是否為 null。

    volatile 在這里是需要的,希望能引起讀者的關(guān)注。

    很多人不知道怎么寫,直接就在 getInstance() 方法簽名上加上 synchronized,這就不多說了,性能太差。

    嵌套類最經(jīng)典,以后大家就用它吧:

    public?class?Singleton3?{private?Singleton3()?{}//?主要是使用了?嵌套類可以訪問外部類的靜態(tài)屬性和靜態(tài)方法?的特性private?static?class?Holder?{private?static?Singleton3?instance?=?new?Singleton3();}public?static?Singleton3?getInstance()?{return?Holder.instance;} }

    注意,很多人都會把這個嵌套類說成是靜態(tài)內(nèi)部類,嚴(yán)格地說,內(nèi)部類和嵌套類是不一樣的,它們能訪問的外部類權(quán)限也是不一樣的。

    最后,我們說一下枚舉,枚舉很特殊,它在類加載的時候會初始化里面的所有的實(shí)例,而且 JVM 保證了它們不會再被實(shí)例化,所以它天生就是單例的。

    雖然我們平時很少看到用枚舉來實(shí)現(xiàn)單例,但是在 RxJava 的源碼中,有很多地方都用了枚舉來實(shí)現(xiàn)單例。

    建造者模式

    經(jīng)常碰見的 XxxBuilder 的類,通常都是建造者模式的產(chǎn)物。建造者模式其實(shí)有很多的變種,但是對于客戶端來說,我們的使用通常都是一個模式的:

    Food?food?=?new?FoodBuilder().a().b().c().build(); Food?food?=?Food.builder().a().b().c().build();

    套路就是先 new 一個 Builder,然后可以鏈?zhǔn)降卣{(diào)用一堆方法,最后再調(diào)用一次 build() 方法,我們需要的對象就有了。

    來一個中規(guī)中矩的建造者模式:

    class?User?{//?下面是“一堆”的屬性private?String?name;private?String?password;private?String?nickName;private?int?age;//?構(gòu)造方法私有化,不然客戶端就會直接調(diào)用構(gòu)造方法了private?User(String?name,?String?password,?String?nickName,?int?age)?{this.name?=?name;this.password?=?password;this.nickName?=?nickName;this.age?=?age;}//?靜態(tài)方法,用于生成一個?Builder,這個不一定要有,不過寫這個方法是一個很好的習(xí)慣,//?有些代碼要求別人寫?new?User.UserBuilder().a()...build()?看上去就沒那么好public?static?UserBuilder?builder()?{return?new?UserBuilder();}public?static?class?UserBuilder?{//?下面是和?User?一模一樣的一堆屬性private?String??name;private?String?password;private?String?nickName;private?int?age;private?UserBuilder()?{}//?鏈?zhǔn)秸{(diào)用設(shè)置各個屬性值,返回?this,即?UserBuilderpublic?UserBuilder?name(String?name)?{this.name?=?name;return?this;}public?UserBuilder?password(String?password)?{this.password?=?password;return?this;}public?UserBuilder?nickName(String?nickName)?{this.nickName?=?nickName;return?this;}public?UserBuilder?age(int?age)?{this.age?=?age;return?this;}// build()?方法負(fù)責(zé)將 UserBuilder 中設(shè)置好的屬性“復(fù)制”到 User 中。//?當(dāng)然,可以在?“復(fù)制”?之前做點(diǎn)檢驗(yàn)public?User?build()?{if?(name?==?null?||?password?==?null)?{throw?new?RuntimeException("用戶名和密碼必填");}if?(age?<=?0?||?age?>=?150)?{throw?new?RuntimeException("年齡不合法");}//?還可以做賦予”默認(rèn)值“的功能if?(nickName?==?null)?{nickName?=?name;}return?new?User(name,?password,?nickName,?age);}} }

    核心是:先把所有的屬性都設(shè)置給 Builder,然后 build() 方法的時候,將這些屬性復(fù)制給實(shí)際產(chǎn)生的對象。

    看看客戶端的調(diào)用:

    public?class?APP?{public?static?void?main(String[]?args)?{User?d?=?User.builder().name("foo").password("pAss12345").age(25).build();} }

    說實(shí)話,建造者模式的鏈?zhǔn)綄懛ê芪?#xff0c;但是,多寫了很多“無用”的 builder 的代碼,感覺這個模式?jīng)]什么用。不過,當(dāng)屬性很多,而且有些必填,有些選填的時候,這個模式會使代碼清晰很多。我們可以在 Builder 的構(gòu)造方法中強(qiáng)制讓調(diào)用者提供必填字段,還有,在 build() 方法中校驗(yàn)各個參數(shù)比在 User 的構(gòu)造方法中校驗(yàn),代碼要優(yōu)雅一些。

    題外話,強(qiáng)烈建議讀者使用 lombok,用了 lombok 以后,上面的一大堆代碼會變成如下這樣:

    @Builder class?User?{private?String??name;private?String?password;private?String?nickName;private?int?age; }

    怎么樣,省下來的時間是不是又可以干點(diǎn)別的了。

    當(dāng)然,如果你只是想要鏈?zhǔn)綄懛?#xff0c;不想要建造者模式,有個很簡單的辦法,User 的 getter 方法不變,所有的 setter 方法都讓其?return this?就可以了,然后就可以像下面這樣調(diào)用:

    User?user?=?new?User().setName("").setPassword("").setAge(20);

    很多人是這么用的,但是筆者覺得其實(shí)這種寫法非常地不優(yōu)雅,不是很推薦使用。

    原型模式

    這是我要說的創(chuàng)建型模式的最后一個設(shè)計(jì)模式了。

    原型模式很簡單:有一個原型實(shí)例,基于這個原型實(shí)例產(chǎn)生新的實(shí)例,也就是“克隆”了。

    Object 類中有一個 clone() 方法,它用于生成一個新的對象,當(dāng)然,如果我們要調(diào)用這個方法,java 要求我們的類必須先實(shí)現(xiàn) Cloneable 接口,此接口沒有定義任何方法,但是不這么做的話,在 clone() 的時候,會拋出 CloneNotSupportedException 異常。

    protected?native?Object?clone()?throws?CloneNotSupportedException;

    java 的克隆是淺克隆,碰到對象引用的時候,克隆出來的對象和原對象中的引用將指向同一個對象。通常實(shí)現(xiàn)深克隆的方法是將對象進(jìn)行序列化,然后再進(jìn)行反序列化。

    原型模式了解到這里我覺得就夠了,各種變著法子說這種代碼或那種代碼是原型模式,沒什么意義。

    創(chuàng)建型模式總結(jié)

    創(chuàng)建型模式總體上比較簡單,它們的作用就是為了產(chǎn)生實(shí)例對象,算是各種工作的第一步了,因?yàn)槲覀儗懙氖敲嫦驅(qū)ο蟮拇a,所以我們第一步當(dāng)然是需要創(chuàng)建一個對象了。

    簡單工廠模式最簡單;工廠模式在簡單工廠模式的基礎(chǔ)上增加了選擇工廠的維度,需要第一步選擇合適的工廠;抽象工廠模式有產(chǎn)品族的概念,如果各個產(chǎn)品是存在兼容性問題的,就要用抽象工廠模式。單例模式就不說了,為了保證全局使用的是同一對象,一方面是安全性考慮,一方面是為了節(jié)省資源;建造者模式專門對付屬性很多的那種類,為了讓代碼更優(yōu)美;原型模式用得最少,了解和 Object 類中的 clone() 方法相關(guān)的知識即可。

    結(jié)構(gòu)型模式

    前面創(chuàng)建型模式介紹了創(chuàng)建對象的一些設(shè)計(jì)模式,這節(jié)介紹的結(jié)構(gòu)型模式旨在通過改變代碼結(jié)構(gòu)來達(dá)到解耦的目的,使得我們的代碼容易維護(hù)和擴(kuò)展。

    代理模式

    第一個要介紹的代理模式是最常使用的模式之一了,用一個代理來隱藏具體實(shí)現(xiàn)類的實(shí)現(xiàn)細(xì)節(jié),通常還用于在真實(shí)的實(shí)現(xiàn)的前后添加一部分邏輯。

    既然說是代理,那就要對客戶端隱藏真實(shí)實(shí)現(xiàn),由代理來負(fù)責(zé)客戶端的所有請求。當(dāng)然,代理只是個代理,它不會完成實(shí)際的業(yè)務(wù)邏輯,而是一層皮而已,但是對于客戶端來說,它必須表現(xiàn)得就是客戶端需要的真實(shí)實(shí)現(xiàn)。

    理解代理這個詞,這個模式其實(shí)就簡單了。

    public?interface?FoodService?{Food?makeChicken();Food?makeNoodle(); }public?class?FoodServiceImpl?implements?FoodService?{public?Food?makeChicken()?{Food?f?=?new?Chicken()f.setChicken("1kg");f.setSpicy("1g");f.setSalt("3g");return?f;}public?Food?makeNoodle()?{Food?f?=?new?Noodle();f.setNoodle("500g");f.setSalt("5g");return?f;} }//?代理要表現(xiàn)得“就像是”真實(shí)實(shí)現(xiàn)類,所以需要實(shí)現(xiàn)?FoodService public?class?FoodServiceProxy?implements?FoodService?{//?內(nèi)部一定要有一個真實(shí)的實(shí)現(xiàn)類,當(dāng)然也可以通過構(gòu)造方法注入private?FoodService?foodService?=?new?FoodServiceImpl();public?Food?makeChicken()?{System.out.println("我們馬上要開始制作雞肉了");//?如果我們定義這句為核心代碼的話,那么,核心代碼是真實(shí)實(shí)現(xiàn)類做的,//?代理只是在核心代碼前后做些“無足輕重”的事情Food?food?=?foodService.makeChicken();System.out.println("雞肉制作完成啦,加點(diǎn)胡椒粉");?//?增強(qiáng)food.addCondiment("pepper");return?food;}public?Food?makeNoodle()?{System.out.println("準(zhǔn)備制作拉面~");Food?food?=?foodService.makeNoodle();System.out.println("制作完成啦")return?food;} }

    客戶端調(diào)用,注意,我們要用代理來實(shí)例化接口:

    //?這里用代理類來實(shí)例化 FoodService?foodService?=?new?FoodServiceProxy(); foodService.makeChicken();

    proxy

    我們發(fā)現(xiàn)沒有,代理模式說白了就是做?“方法包裝”?或做?“方法增強(qiáng)”。在面向切面編程中,其實(shí)就是動態(tài)代理的過程。比如 Spring 中,我們自己不定義代理類,但是 Spring 會幫我們動態(tài)來定義代理,然后把我們定義在 @Before、@After、@Around 中的代碼邏輯動態(tài)添加到代理中。

    說到動態(tài)代理,又可以展開說,Spring 中實(shí)現(xiàn)動態(tài)代理有兩種,一種是如果我們的類定義了接口,如 UserService 接口和 UserServiceImpl 實(shí)現(xiàn),那么采用 JDK 的動態(tài)代理,感興趣的讀者可以去看看 java.lang.reflect.Proxy 類的源碼;另一種是我們自己沒有定義接口的,Spring 會采用 CGLIB 進(jìn)行動態(tài)代理,它是一個 jar 包,性能還不錯。

    適配器模式

    說完代理模式,說適配器模式,是因?yàn)樗鼈兒芟嗨?#xff0c;這里可以做個比較。

    適配器模式做的就是,有一個接口需要實(shí)現(xiàn),但是我們現(xiàn)成的對象都不滿足,需要加一層適配器來進(jìn)行適配。

    適配器模式總體來說分三種:默認(rèn)適配器模式、對象適配器模式、類適配器模式。先不急著分清楚這幾個,先看看例子再說。

    默認(rèn)適配器模式

    首先,我們先看看最簡單的適配器模式默認(rèn)適配器模式(Default Adapter)是怎么樣的。

    我們用 Appache commons-io 包中的 FileAlterationListener 做例子,此接口定義了很多的方法,用于對文件或文件夾進(jìn)行監(jiān)控,一旦發(fā)生了對應(yīng)的操作,就會觸發(fā)相應(yīng)的方法。

    public?interface?FileAlterationListener?{void?onStart(final?FileAlterationObserver?observer);void?onDirectoryCreate(final?File?directory);void?onDirectoryChange(final?File?directory);void?onDirectoryDelete(final?File?directory);void?onFileCreate(final?File?file);void?onFileChange(final?File?file);void?onFileDelete(final?File?file);void?onStop(final?FileAlterationObserver?observer); }

    此接口的一大問題是抽象方法太多了,如果我們要用這個接口,意味著我們要實(shí)現(xiàn)每一個抽象方法,如果我們只是想要監(jiān)控文件夾中的文件創(chuàng)建和文件刪除事件,可是我們還是不得不實(shí)現(xiàn)所有的方法,很明顯,這不是我們想要的。

    所以,我們需要下面的一個適配器,它用于實(shí)現(xiàn)上面的接口,但是所有的方法都是空方法,這樣,我們就可以轉(zhuǎn)而定義自己的類來繼承下面這個類即可。

    public?class?FileAlterationListenerAdaptor?implements?FileAlterationListener?{public?void?onStart(final?FileAlterationObserver?observer)?{}public?void?onDirectoryCreate(final?File?directory)?{}public?void?onDirectoryChange(final?File?directory)?{}public?void?onDirectoryDelete(final?File?directory)?{}public?void?onFileCreate(final?File?file)?{}public?void?onFileChange(final?File?file)?{}public?void?onFileDelete(final?File?file)?{}public?void?onStop(final?FileAlterationObserver?observer)?{} }

    比如我們可以定義以下類,我們僅僅需要實(shí)現(xiàn)我們想實(shí)現(xiàn)的方法就可以了:

    public?class?FileMonitor?extends?FileAlterationListenerAdaptor?{public?void?onFileCreate(final?File?file)?{//?文件創(chuàng)建doSomething();}public?void?onFileDelete(final?File?file)?{//?文件刪除doSomething();} }

    當(dāng)然,上面說的只是適配器模式的其中一種,也是最簡單的一種,無需多言。下面,再介紹“正統(tǒng)的”適配器模式。

    對象適配器模式

    來看一個《Head First 設(shè)計(jì)模式》中的一個例子,我稍微修改了一下,看看怎么將雞適配成鴨,這樣雞也能當(dāng)鴨來用。因?yàn)?#xff0c;現(xiàn)在鴨這個接口,我們沒有合適的實(shí)現(xiàn)類可以用,所以需要適配器。

    public?interface?Duck?{public?void?quack();?//?鴨的呱呱叫public?void?fly();?//?飛 }public?interface?Cock?{public?void?gobble();?//?雞的咕咕叫public?void?fly();?//?飛 }public?class?WildCock?implements?Cock?{public?void?gobble()?{System.out.println("咕咕叫");}public?void?fly()?{System.out.println("雞也會飛哦");} }

    鴨接口有 fly() 和 quare() 兩個方法,雞 Cock 如果要冒充鴨,fly() 方法是現(xiàn)成的,但是雞不會鴨的呱呱叫,沒有 quack() 方法。這個時候就需要適配了:

    //?毫無疑問,首先,這個適配器肯定需要?implements?Duck,這樣才能當(dāng)做鴨來用 public?class?CockAdapter?implements?Duck?{Cock?cock;//?構(gòu)造方法中需要一個雞的實(shí)例,此類就是將這只雞適配成鴨來用public?CockAdapter(Cock?cock)?{this.cock?=?cock;}//?實(shí)現(xiàn)鴨的呱呱叫方法@Overridepublic?void?quack()?{//?內(nèi)部其實(shí)是一只雞的咕咕叫cock.gobble();}@Overridepublic?void?fly()?{cock.fly();} }

    客戶端調(diào)用很簡單了:

    public?static?void?main(String[]?args)?{//?有一只野雞Cock?wildCock?=?new?WildCock();//?成功將野雞適配成鴨Duck?duck?=?new?CockAdapter(wildCock);... }

    到這里,大家也就知道了適配器模式是怎么回事了。無非是我們需要一只鴨,但是我們只有一只雞,這個時候就需要定義一個適配器,由這個適配器來充當(dāng)鴨,但是適配器里面的方法還是由雞來實(shí)現(xiàn)的。

    我們用一個圖來簡單說明下:

    上圖應(yīng)該還是很容易理解的,我就不做更多的解釋了。下面,我們看看類適配模式怎么樣的。

    類適配器模式

    廢話少說,直接上圖:

    adapter-1

    看到這個圖,大家應(yīng)該很容易理解的吧,通過繼承的方法,適配器自動獲得了所需要的大部分方法。這個時候,客戶端使用更加簡單,直接?Target t = new SomeAdapter();?就可以了。

    適配器模式總結(jié)

    類適配和對象適配的異同

    一個采用繼承,一個采用組合;

    類適配屬于靜態(tài)實(shí)現(xiàn),對象適配屬于組合的動態(tài)實(shí)現(xiàn),對象適配需要多實(shí)例化一個對象。

    總體來說,對象適配用得比較多。

    適配器模式和代理模式的異同

    比較這兩種模式,其實(shí)是比較對象適配器模式和代理模式,在代碼結(jié)構(gòu)上,它們很相似,都需要一個具體的實(shí)現(xiàn)類的實(shí)例。但是它們的目的不一樣,代理模式做的是增強(qiáng)原方法的活;適配器做的是適配的活,為的是提供“把雞包裝成鴨,然后當(dāng)做鴨來使用”,而雞和鴨它們之間原本沒有繼承關(guān)系。

    橋梁模式

    理解橋梁模式,其實(shí)就是理解代碼抽象和解耦。

    我們首先需要一個橋梁,它是一個接口,定義提供的接口方法。

    public?interface?DrawAPI?{public?void?draw(int?radius,?int?x,?int?y); }

    然后是一系列實(shí)現(xiàn)類:

    public?class?RedPen?implements?DrawAPI?{@Overridepublic?void?draw(int?radius,?int?x,?int?y)?{System.out.println("用紅色筆畫圖,radius:"?+?radius?+?",?x:"?+?x?+?",?y:"?+?y);} } public?class?GreenPen?implements?DrawAPI?{@Overridepublic?void?draw(int?radius,?int?x,?int?y)?{System.out.println("用綠色筆畫圖,radius:"?+?radius?+?",?x:"?+?x?+?",?y:"?+?y);} } public?class?BluePen?implements?DrawAPI?{@Overridepublic?void?draw(int?radius,?int?x,?int?y)?{System.out.println("用藍(lán)色筆畫圖,radius:"?+?radius?+?",?x:"?+?x?+?",?y:"?+?y);} }

    定義一個抽象類,此類的實(shí)現(xiàn)類都需要使用 DrawAPI:

    public?abstract?class?Shape?{protected?DrawAPI?drawAPI;protected?Shape(DrawAPI?drawAPI)?{this.drawAPI?=?drawAPI;}public?abstract?void?draw(); }

    定義抽象類的子類:

    //?圓形 public?class?Circle?extends?Shape?{private?int?radius;public?Circle(int?radius,?DrawAPI?drawAPI)?{super(drawAPI);this.radius?=?radius;}public?void?draw()?{drawAPI.draw(radius,?0,?0);} } //?長方形 public?class?Rectangle?extends?Shape?{private?int?x;private?int?y;public?Rectangle(int?x,?int?y,?DrawAPI?drawAPI)?{super(drawAPI);this.x?=?x;this.y?=?y;}public?void?draw()?{drawAPI.draw(0,?x,?y);} }

    最后,我們來看客戶端演示:

    public?static?void?main(String[]?args)?{Shape?greenCircle?=?new?Circle(10,?new?GreenPen());Shape?redRectangle?=?new?Rectangle(4,?8,?new?RedPen());greenCircle.draw();redRectangle.draw(); }

    可能大家看上面一步步還不是特別清晰,我把所有的東西整合到一張圖上:

    這回大家應(yīng)該就知道抽象在哪里,怎么解耦了吧。橋梁模式的優(yōu)點(diǎn)也是顯而易見的,就是非常容易進(jìn)行擴(kuò)展。

    本節(jié)引用了這里的例子,并對其進(jìn)行了修改。

    裝飾模式

    要把裝飾模式說清楚明白,不是件容易的事情。也許讀者知道?Java IO?中的幾個類是典型的裝飾模式的應(yīng)用,但是讀者不一定清楚其中的關(guān)系,也許看完就忘了,希望看完這節(jié)后,讀者可以對其有更深的感悟。

    首先,我們先看一個簡單的圖,看這個圖的時候,了解下層次結(jié)構(gòu)就可以了:

    我們來說說裝飾模式的出發(fā)點(diǎn),從圖中可以看到,接口?Component?其實(shí)已經(jīng)有了?ConcreteComponentA?和?ConcreteComponentB?兩個實(shí)現(xiàn)類了,但是,如果我們要增強(qiáng)這兩個實(shí)現(xiàn)類的話,我們就可以采用裝飾模式,用具體的裝飾器來裝飾實(shí)現(xiàn)類,以達(dá)到增強(qiáng)的目的。

    從名字來簡單解釋下裝飾器。既然說是裝飾,那么往往就是添加小功能這種,而且,我們要滿足可以添加多個小功能。最簡單的,代理模式就可以實(shí)現(xiàn)功能的增強(qiáng),但是代理不容易實(shí)現(xiàn)多個功能的增強(qiáng),當(dāng)然你可以說用代理包裝代理的多層包裝方式,但是那樣的話代碼就復(fù)雜了。

    首先明白一些簡單的概念,從圖中我們看到,所有的具體裝飾者們 ConcreteDecorator*?都可以作為 Component 來使用,因?yàn)樗鼈兌紝?shí)現(xiàn)了 Component 中的所有接口。它們和 Component 實(shí)現(xiàn)類 ConcreteComponent* 的區(qū)別是,它們只是裝飾者,起裝飾作用,也就是即使它們看上去牛逼轟轟,但是它們都只是在具體的實(shí)現(xiàn)中加了層皮來裝飾而已。

    注意這段話中混雜在各個名詞中的 Component 和 Decorator,別搞混了。

    下面來看看一個例子,先把裝飾模式弄清楚,然后再介紹下 java io 中的裝飾模式的應(yīng)用。

    最近大街上流行起來了“快樂檸檬”,我們把快樂檸檬的飲料分為三類:紅茶、綠茶、咖啡,在這三大類的基礎(chǔ)上,又增加了許多的口味,什么金桔檸檬紅茶、金桔檸檬珍珠綠茶、芒果紅茶、芒果綠茶、芒果珍珠紅茶、烤珍珠紅茶、烤珍珠芒果綠茶、椰香胚芽咖啡、焦糖可可咖啡等等,每家店都有很長的菜單,但是仔細(xì)看下,其實(shí)原料也沒幾樣,但是可以搭配出很多組合,如果顧客需要,很多沒出現(xiàn)在菜單中的飲料他們也是可以做的。

    在這個例子中,紅茶、綠茶、咖啡是最基礎(chǔ)的飲料,其他的像金桔檸檬、芒果、珍珠、椰果、焦糖等都屬于裝飾用的。當(dāng)然,在開發(fā)中,我們確實(shí)可以像門店一樣,開發(fā)這些類:LemonBlackTea、LemonGreenTea、MangoBlackTea、MangoLemonGreenTea……但是,很快我們就發(fā)現(xiàn),這樣子干肯定是不行的,這會導(dǎo)致我們需要組合出所有的可能,而且如果客人需要在紅茶中加雙份檸檬怎么辦?三份檸檬怎么辦?

    不說廢話了,上代碼。

    首先,定義飲料抽象基類:

    public?abstract?class?Beverage?{//?返回描述public?abstract?String?getDescription();//?返回價格public?abstract?double?cost(); }

    然后是三個基礎(chǔ)飲料實(shí)現(xiàn)類,紅茶、綠茶和咖啡:

    public?class?BlackTea?extends?Beverage?{public?String?getDescription()?{return?"紅茶";}public?double?cost()?{return?10;} } public?class?GreenTea?extends?Beverage?{public?String?getDescription()?{return?"綠茶";}public?double?cost()?{return?11;} } ...//?咖啡省略

    定義調(diào)料,也就是裝飾者的基類,此類必須繼承自 Beverage:

    //?調(diào)料 public?abstract?class?Condiment?extends?Beverage?{}

    然后我們來定義檸檬、芒果等具體的調(diào)料,它們屬于裝飾者,毫無疑問,這些調(diào)料肯定都需要繼承調(diào)料 Condiment 類:

    public?class?Lemon?extends?Condiment?{private?Beverage?bevarage;//?這里很關(guān)鍵,需要傳入具體的飲料,如需要傳入沒有被裝飾的紅茶或綠茶,//?當(dāng)然也可以傳入已經(jīng)裝飾好的芒果綠茶,這樣可以做芒果檸檬綠茶public?Lemon(Beverage?bevarage)?{this.bevarage?=?bevarage;}public?String?getDescription()?{//?裝飾return?bevarage.getDescription()?+?",?加檸檬";}public?double?cost()?{//?裝飾return?beverage.cost()?+?2;?//?加檸檬需要?2?元} }public?class?Mango?extends?Condiment?{private?Beverage?bevarage;public?Mango(Beverage?bevarage)?{this.bevarage?=?bevarage;}public?String?getDescription()?{return?bevarage.getDescription()?+?",?加芒果";}public?double?cost()?{return?beverage.cost()?+?3;?//?加芒果需要?3?元} } ...//?給每一種調(diào)料都加一個類

    看客戶端調(diào)用:

    public?static?void?main(String[]?args)?{//?首先,我們需要一個基礎(chǔ)飲料,紅茶、綠茶或咖啡Beverage?beverage?=?new?GreenTea();//?開始裝飾beverage?=?new?Lemon(beverage);?//?先加一份檸檬beverage?=?new?Mongo(beverage);?//?再加一份芒果System.out.println(beverage.getDescription()?+?"?價格:¥"?+?beverage.cost());//"綠茶, 加檸檬, 加芒果?價格:¥16" }

    如果我們需要芒果-珍珠-雙份檸檬-紅茶:

    Beverage?beverage?=?new?Mongo(new?Pearl(new?Lemon(new?Lemon(new?BlackTea()))));

    是不是很變態(tài)?

    看看下圖可能會清晰一些:

    到這里,大家應(yīng)該已經(jīng)清楚裝飾模式了吧。

    下面,我們再來說說 java IO 中的裝飾模式。看下圖 InputStream 派生出來的部分類:

    我們知道 InputStream 代表了輸入流,具體的輸入來源可以是文件(FileInputStream)、管道(PipedInputStream)、數(shù)組(ByteArrayInputStream)等,這些就像前面奶茶的例子中的紅茶、綠茶,屬于基礎(chǔ)輸入流。

    FilterInputStream 承接了裝飾模式的關(guān)鍵節(jié)點(diǎn),它的實(shí)現(xiàn)類是一系列裝飾器,比如 BufferedInputStream 代表用緩沖來裝飾,也就使得輸入流具有了緩沖的功能,LineNumberInputStream 代表用行號來裝飾,在操作的時候就可以取得行號了,DataInputStream 的裝飾,使得我們可以從輸入流轉(zhuǎn)換為 java 中的基本類型值。

    當(dāng)然,在 java IO 中,如果我們使用裝飾器的話,就不太適合面向接口編程了,如:

    InputStream?inputStream?=?new?LineNumberInputStream(new?BufferedInputStream(new?FileInputStream("")));

    這樣的結(jié)果是,InputStream 還是不具有讀取行號的功能,因?yàn)樽x取行號的方法定義在 LineNumberInputStream 類中。

    我們應(yīng)該像下面這樣使用:

    DataInputStream?is?=?new?DataInputStream(new?BufferedInputStream(new?FileInputStream("")));

    所以說嘛,要找到純的嚴(yán)格符合設(shè)計(jì)模式的代碼還是比較難的。

    門面模式

    門面模式(也叫外觀模式,Facade Pattern)在許多源碼中有使用,比如 slf4j 就可以理解為是門面模式的應(yīng)用。這是一個簡單的設(shè)計(jì)模式,我們直接上代碼再說吧。

    首先,我們定義一個接口:

    public?interface?Shape?{void?draw(); }

    定義幾個實(shí)現(xiàn)類:

    public?class?Circle?implements?Shape?{@Overridepublic?void?draw()?{System.out.println("Circle::draw()");} }public?class?Rectangle?implements?Shape?{@Overridepublic?void?draw()?{System.out.println("Rectangle::draw()");} }

    客戶端調(diào)用:

    public?static?void?main(String[]?args)?{//?畫一個圓形Shape?circle?=?new?Circle();circle.draw();//?畫一個長方形Shape?rectangle?=?new?Rectangle();rectangle.draw(); }

    以上是我們常寫的代碼,我們需要畫圓就要先實(shí)例化圓,畫長方形就需要先實(shí)例化一個長方形,然后再調(diào)用相應(yīng)的 draw() 方法。

    下面,我們看看怎么用門面模式來讓客戶端調(diào)用更加友好一些。

    我們先定義一個門面:

    public?class?ShapeMaker?{private?Shape?circle;private?Shape?rectangle;private?Shape?square;public?ShapeMaker()?{circle?=?new?Circle();rectangle?=?new?Rectangle();square?=?new?Square();}/***?下面定義一堆方法,具體應(yīng)該調(diào)用什么方法,由這個門面來決定*/public?void?drawCircle(){circle.draw();}public?void?drawRectangle(){rectangle.draw();}public?void?drawSquare(){square.draw();} }

    看看現(xiàn)在客戶端怎么調(diào)用:

    public?static?void?main(String[]?args)?{ShapeMaker?shapeMaker?=?new?ShapeMaker();//?客戶端調(diào)用現(xiàn)在更加清晰了shapeMaker.drawCircle();shapeMaker.drawRectangle();shapeMaker.drawSquare();???????? }

    門面模式的優(yōu)點(diǎn)顯而易見,客戶端不再需要關(guān)注實(shí)例化時應(yīng)該使用哪個實(shí)現(xiàn)類,直接調(diào)用門面提供的方法就可以了,因?yàn)殚T面類提供的方法的方法名對于客戶端來說已經(jīng)很友好了。

    組合模式

    組合模式用于表示具有層次結(jié)構(gòu)的數(shù)據(jù),使得我們對單個對象和組合對象的訪問具有一致性。

    直接看一個例子吧,每個員工都有姓名、部門、薪水這些屬性,同時還有下屬員工集合(雖然可能集合為空),而下屬員工和自己的結(jié)構(gòu)是一樣的,也有姓名、部門這些屬性,同時也有他們的下屬員工集合。

    public?class?Employee?{private?String?name;private?String?dept;private?int?salary;private?List<Employee>?subordinates;?//?下屬public?Employee(String?name,String?dept,?int?sal)?{this.name?=?name;this.dept?=?dept;this.salary?=?sal;subordinates?=?new?ArrayList<Employee>();}public?void?add(Employee?e)?{subordinates.add(e);}public?void?remove(Employee?e)?{subordinates.remove(e);}public?List<Employee>?getSubordinates(){return?subordinates;}public?String?toString(){return?("Employee?:[?Name?:?"?+?name?+?",?dept?:?"?+?dept?+?",?salary?:"?+?salary+"?]");}??? }

    通常,這種類需要定義 add(node)、remove(node)、getChildren() 這些方法。

    這說的其實(shí)就是組合模式,這種簡單的模式我就不做過多介紹了,相信各位讀者也不喜歡看我寫廢話。

    享元模式

    英文是 Flyweight Pattern,不知道是誰最先翻譯的這個詞,感覺這翻譯真的不好理解,我們試著強(qiáng)行關(guān)聯(lián)起來吧。Flyweight 是輕量級的意思,享元分開來說就是 共享 元器件,也就是復(fù)用已經(jīng)生成的對象,這種做法當(dāng)然也就是輕量級的了。

    復(fù)用對象最簡單的方式是,用一個 HashMap 來存放每次新生成的對象。每次需要一個對象的時候,先到 HashMap 中看看有沒有,如果沒有,再生成新的對象,然后將這個對象放入 HashMap 中。

    這種簡單的代碼我就不演示了。

    結(jié)構(gòu)型模式總結(jié)

    前面,我們說了代理模式、適配器模式、橋梁模式、裝飾模式、門面模式、組合模式和享元模式。讀者是否可以分別把這幾個模式說清楚了呢?在說到這些模式的時候,心中是否有一個清晰的圖或處理流程在腦海里呢?

    代理模式是做方法增強(qiáng)的,適配器模式是把雞包裝成鴨這種用來適配接口的,橋梁模式做到了很好的解耦,裝飾模式從名字上就看得出來,適合于裝飾類或者說是增強(qiáng)類的場景,門面模式的優(yōu)點(diǎn)是客戶端不需要關(guān)心實(shí)例化過程,只要調(diào)用需要的方法即可,組合模式用于描述具有層次結(jié)構(gòu)的數(shù)據(jù),享元模式是為了在特定的場景中緩存已經(jīng)創(chuàng)建的對象,用于提高性能。

    行為型模式

    行為型模式關(guān)注的是各個類之間的相互作用,將職責(zé)劃分清楚,使得我們的代碼更加地清晰。

    策略模式

    策略模式太常用了,所以把它放到最前面進(jìn)行介紹。它比較簡單,我就不廢話,直接用代碼說事吧。

    下面設(shè)計(jì)的場景是,我們需要畫一個圖形,可選的策略就是用紅色筆來畫,還是綠色筆來畫,或者藍(lán)色筆來畫。

    首先,先定義一個策略接口:

    public?interface?Strategy?{public?void?draw(int?radius,?int?x,?int?y); }

    然后我們定義具體的幾個策略:

    public?class?RedPen?implements?Strategy?{@Overridepublic?void?draw(int?radius,?int?x,?int?y)?{System.out.println("用紅色筆畫圖,radius:"?+?radius?+?",?x:"?+?x?+?",?y:"?+?y);} } public?class?GreenPen?implements?Strategy?{@Overridepublic?void?draw(int?radius,?int?x,?int?y)?{System.out.println("用綠色筆畫圖,radius:"?+?radius?+?",?x:"?+?x?+?",?y:"?+?y);} } public?class?BluePen?implements?Strategy?{@Overridepublic?void?draw(int?radius,?int?x,?int?y)?{System.out.println("用藍(lán)色筆畫圖,radius:"?+?radius?+?",?x:"?+?x?+?",?y:"?+?y);} }

    使用策略的類:

    public?class?Context?{private?Strategy?strategy;public?Context(Strategy?strategy){this.strategy?=?strategy;}public?int?executeDraw(int?radius,?int?x,?int?y){return?strategy.draw(radius,?x,?y);} }

    客戶端演示:

    public?static?void?main(String[]?args)?{Context?context?=?new?Context(new?BluePen());?//?使用綠色筆來畫context.executeDraw(10,?0,?0); }

    放到一張圖上,讓大家看得清晰些:

    這個時候,大家有沒有聯(lián)想到結(jié)構(gòu)型模式中的橋梁模式,它們其實(shí)非常相似,我把橋梁模式的圖拿過來大家對比下:

    要我說的話,它們非常相似,橋梁模式在左側(cè)加了一層抽象而已。橋梁模式的耦合更低,結(jié)構(gòu)更復(fù)雜一些。

    觀察者模式

    觀察者模式對于我們來說,真是再簡單不過了。無外乎兩個操作,觀察者訂閱自己關(guān)心的主題和主題有數(shù)據(jù)變化后通知觀察者們。

    首先,需要定義主題,每個主題需要持有觀察者列表的引用,用于在數(shù)據(jù)變更的時候通知各個觀察者:

    public?class?Subject?{private?List<Observer>?observers?=?new?ArrayList<Observer>();private?int?state;public?int?getState()?{return?state;}public?void?setState(int?state)?{this.state?=?state;//?數(shù)據(jù)已變更,通知觀察者們notifyAllObservers();}//?注冊觀察者public?void?attach(Observer?observer)?{observers.add(observer);}//?通知觀察者們public?void?notifyAllObservers()?{for?(Observer?observer?:?observers)?{observer.update();}} }

    定義觀察者接口:

    public?abstract?class?Observer?{protected?Subject?subject;public?abstract?void?update(); }

    其實(shí)如果只有一個觀察者類的話,接口都不用定義了,不過,通常場景下,既然用到了觀察者模式,我們就是希望一個事件出來了,會有多個不同的類需要處理相應(yīng)的信息。比如,訂單修改成功事件,我們希望發(fā)短信的類得到通知、發(fā)郵件的類得到通知、處理物流信息的類得到通知等。

    我們來定義具體的幾個觀察者類:

    public?class?BinaryObserver?extends?Observer?{//?在構(gòu)造方法中進(jìn)行訂閱主題public?BinaryObserver(Subject?subject)?{this.subject?=?subject;//?通常在構(gòu)造方法中將?this?發(fā)布出去的操作一定要小心this.subject.attach(this);}//?該方法由主題類在數(shù)據(jù)變更的時候進(jìn)行調(diào)用@Overridepublic?void?update()?{String?result?=?Integer.toBinaryString(subject.getState());System.out.println("訂閱的數(shù)據(jù)發(fā)生變化,新的數(shù)據(jù)處理為二進(jìn)制值為:"?+?result);} }public?class?HexaObserver?extends?Observer?{public?HexaObserver(Subject?subject)?{this.subject?=?subject;this.subject.attach(this);}@Overridepublic?void?update()?{String?result?=?Integer.toHexString(subject.getState()).toUpperCase();System.out.println("訂閱的數(shù)據(jù)發(fā)生變化,新的數(shù)據(jù)處理為十六進(jìn)制值為:"?+?result);} }

    客戶端使用也非常簡單:

    public?static?void?main(String[]?args)?{//?先定義一個主題Subject?subject1?=?new?Subject();//?定義觀察者new?BinaryObserver(subject1);new?HexaObserver(subject1);//?模擬數(shù)據(jù)變更,這個時候,觀察者們的?update?方法將會被調(diào)用subject.setState(11); }

    output:

    訂閱的數(shù)據(jù)發(fā)生變化,新的數(shù)據(jù)處理為二進(jìn)制值為:1011 訂閱的數(shù)據(jù)發(fā)生變化,新的數(shù)據(jù)處理為十六進(jìn)制值為:B

    當(dāng)然,jdk 也提供了相似的支持,具體的大家可以參考 java.util.Observable 和 java.util.Observer 這兩個類。

    實(shí)際生產(chǎn)過程中,觀察者模式往往用消息中間件來實(shí)現(xiàn),如果要實(shí)現(xiàn)單機(jī)觀察者模式,筆者建議讀者使用 Guava 中的 EventBus,它有同步實(shí)現(xiàn)也有異步實(shí)現(xiàn),本文主要介紹設(shè)計(jì)模式,就不展開說了。

    還有,即使是上面的這個代碼,也會有很多變種,大家只要記住核心的部分,那就是一定有一個地方存放了所有的觀察者,然后在事件發(fā)生的時候,遍歷觀察者,調(diào)用它們的回調(diào)函數(shù)。

    責(zé)任鏈模式

    責(zé)任鏈通常需要先建立一個單向鏈表,然后調(diào)用方只需要調(diào)用頭部節(jié)點(diǎn)就可以了,后面會自動流轉(zhuǎn)下去。比如流程審批就是一個很好的例子,只要終端用戶提交申請,根據(jù)申請的內(nèi)容信息,自動建立一條責(zé)任鏈,然后就可以開始流轉(zhuǎn)了。

    有這么一個場景,用戶參加一個活動可以領(lǐng)取獎品,但是活動需要進(jìn)行很多的規(guī)則校驗(yàn)然后才能放行,比如首先需要校驗(yàn)用戶是否是新用戶、今日參與人數(shù)是否有限額、全場參與人數(shù)是否有限額等等。設(shè)定的規(guī)則都通過后,才能讓用戶領(lǐng)走獎品。

    如果產(chǎn)品給你這個需求的話,我想大部分人一開始肯定想的就是,用一個 List 來存放所有的規(guī)則,然后 foreach 執(zhí)行一下每個規(guī)則就好了。不過,讀者也先別急,看看責(zé)任鏈模式和我們說的這個有什么不一樣?

    首先,我們要定義流程上節(jié)點(diǎn)的基類:

    public?abstract?class?RuleHandler?{//?后繼節(jié)點(diǎn)protected?RuleHandler?successor;public?abstract?void?apply(Context?context);public?void?setSuccessor(RuleHandler?successor)?{this.successor?=?successor;}public?RuleHandler?getSuccessor()?{return?successor;} }

    接下來,我們需要定義具體的每個節(jié)點(diǎn)了。

    校驗(yàn)用戶是否是新用戶:

    public?class?NewUserRuleHandler?extends?RuleHandler?{public?void?apply(Context?context)?{if?(context.isNewUser())?{//?如果有后繼節(jié)點(diǎn)的話,傳遞下去if?(this.getSuccessor()?!=?null)?{this.getSuccessor().apply(context);}}?else?{throw?new?RuntimeException("該活動僅限新用戶參與");}} }

    校驗(yàn)用戶所在地區(qū)是否可以參與:

    public?class?LocationRuleHandler?extends?RuleHandler?{public?void?apply(Context?context)?{boolean?allowed?=?activityService.isSupportedLocation(context.getLocation);if?(allowed)?{if?(this.getSuccessor()?!=?null)?{this.getSuccessor().apply(context);}}?else?{throw?new?RuntimeException("非常抱歉,您所在的地區(qū)無法參與本次活動");}} }

    校驗(yàn)獎品是否已領(lǐng)完:

    public?class?LimitRuleHandler?extends?RuleHandler?{public?void?apply(Context?context)?{int?remainedTimes?=?activityService.queryRemainedTimes(context);?//?查詢剩余獎品if?(remainedTimes?>?0)?{if?(this.getSuccessor()?!=?null)?{this.getSuccessor().apply(userInfo);}}?else?{throw?new?RuntimeException("您來得太晚了,獎品被領(lǐng)完了");}} }

    客戶端:

    public?static?void?main(String[]?args)?{RuleHandler?newUserHandler?=?new?NewUserRuleHandler();RuleHandler?locationHandler?=?new?LocationRuleHandler();RuleHandler?limitHandler?=?new?LimitRuleHandler();//?假設(shè)本次活動僅校驗(yàn)地區(qū)和獎品數(shù)量,不校驗(yàn)新老用戶locationHandler.setSuccessor(limitHandler);locationHandler.apply(context); }

    代碼其實(shí)很簡單,就是先定義好一個鏈表,然后在通過任意一節(jié)點(diǎn)后,如果此節(jié)點(diǎn)有后繼節(jié)點(diǎn),那么傳遞下去。

    至于它和我們前面說的用一個 List 存放需要執(zhí)行的規(guī)則的做法有什么異同,留給讀者自己琢磨吧。

    模板方法模式

    在含有繼承結(jié)構(gòu)的代碼中,模板方法模式是非常常用的。

    通常會有一個抽象類:

    public?abstract?class?AbstractTemplate?{//?這就是模板方法public?void?templateMethod()?{init();apply();?//?這個是重點(diǎn)end();?//?可以作為鉤子方法}protected?void?init()?{System.out.println("init?抽象層已經(jīng)實(shí)現(xiàn),子類也可以選擇覆寫");}//?留給子類實(shí)現(xiàn)protected?abstract?void?apply();protected?void?end()?{} }

    模板方法中調(diào)用了 3 個方法,其中 apply() 是抽象方法,子類必須實(shí)現(xiàn)它,其實(shí)模板方法中有幾個抽象方法完全是自由的,我們也可以將三個方法都設(shè)置為抽象方法,讓子類來實(shí)現(xiàn)。也就是說,模板方法只負(fù)責(zé)定義第一步應(yīng)該要做什么,第二步應(yīng)該做什么,第三步應(yīng)該做什么,至于怎么做,由子類來實(shí)現(xiàn)。

    我們寫一個實(shí)現(xiàn)類:

    public?class?ConcreteTemplate?extends?AbstractTemplate?{public?void?apply()?{System.out.println("子類實(shí)現(xiàn)抽象方法?apply");}public?void?end()?{System.out.println("我們可以把?method3?當(dāng)做鉤子方法來使用,需要的時候覆寫就可以了");} }

    客戶端調(diào)用演示:

    public?static?void?main(String[]?args)?{AbstractTemplate?t?=?new?ConcreteTemplate();//?調(diào)用模板方法t.templateMethod(); }

    代碼其實(shí)很簡單,基本上看到就懂了,關(guān)鍵是要學(xué)會用到自己的代碼中。

    狀態(tài)模式

    廢話我就不說了,我們說一個簡單的例子。商品庫存中心有個最基本的需求是減庫存和補(bǔ)庫存,我們看看怎么用狀態(tài)模式來寫。

    核心在于,我們的關(guān)注點(diǎn)不再是 Context 是該進(jìn)行哪種操作,而是關(guān)注在這個 Context 會有哪些操作。

    定義狀態(tài)接口:

    public?interface?State?{public?void?doAction(Context?context); }

    定義減庫存的狀態(tài):

    public?class?DeductState?implements?State?{public?void?doAction(Context?context)?{System.out.println("商品賣出,準(zhǔn)備減庫存");context.setState(this);//...?執(zhí)行減庫存的具體操作}public?String?toString()?{return?"Deduct?State";} }

    定義補(bǔ)庫存狀態(tài):

    public?class?RevertState?implements?State?{public?void?doAction(Context?context)?{System.out.println("給此商品補(bǔ)庫存");context.setState(this);//...?執(zhí)行加庫存的具體操作}public?String?toString()?{return?"Revert?State";} }

    前面用到了 context.setState(this),我們來看看怎么定義 Context 類:

    public?class?Context?{private?State?state;private?String?name;public?Context(String?name)?{this.name?=?name;}public?void?setState(State?state)?{this.state?=?state;}public?void?getState()?{return?this.state;} }

    我們來看下客戶端調(diào)用,大家就一清二楚了:

    public?static?void?main(String[]?args)?{//?我們需要操作的是?iPhone?XContext?context?=?new?Context("iPhone?X");//?看看怎么進(jìn)行補(bǔ)庫存操作State?revertState?=?new?RevertState();revertState.doAction(context);//?同樣的,減庫存操作也非常簡單State?deductState?=?new?DeductState();deductState.doAction(context);//?如果需要我們可以獲取當(dāng)前的狀態(tài)//?context.getState().toString(); }

    讀者可能會發(fā)現(xiàn),在上面這個例子中,如果我們不關(guān)心當(dāng)前 context 處于什么狀態(tài),那么 Context 就可以不用維護(hù) state 屬性了,那樣代碼會簡單很多。

    不過,商品庫存這個例子畢竟只是個例,我們還有很多實(shí)例是需要知道當(dāng)前 context 處于什么狀態(tài)的。


    -? ? ?行為型模式總結(jié)??? -

    行為型模式部分介紹了策略模式、觀察者模式、責(zé)任鏈模式、模板方法模式和狀態(tài)模式,其實(shí),經(jīng)典的行為型模式還包括備忘錄模式、命令模式等,但是它們的使用場景比較有限,而且本文篇幅也挺大了,我就不進(jìn)行介紹了。


    -? ? ?總結(jié)??? -

    學(xué)習(xí)設(shè)計(jì)模式的目的是為了讓我們的代碼更加的優(yōu)雅、易維護(hù)、易擴(kuò)展。這次整理這篇文章,讓我重新審視了一下各個設(shè)計(jì)模式,對我自己而言收獲還是挺大的。我想,文章的最大收益者一般都是作者本人,為了寫一篇文章,需要鞏固自己的知識,需要尋找各種資料,而且,自己寫過的才最容易記住,也算是我給讀者的建議吧。

    作者:javadoop

    來源:javadoop.com/post/design-pattern

    推薦閱讀

    阿里立秋:淘寶如何做智能化UI測試?

    2021-08-03

    李偉山:金融撮合架構(gòu)

    2021-05-31

    Francisco: 構(gòu)建前瞻性應(yīng)用架構(gòu)的優(yōu)秀實(shí)踐

    2021-03-31

    滕云:DDD實(shí)現(xiàn)之路

    2021-03-25

    DDD專家張逸:復(fù)雜與架構(gòu)演進(jìn)的關(guān)系

    2021-03-29

    領(lǐng)域驅(qū)動設(shè)計(jì)(DDD):領(lǐng)域和子域

    2021-03-18

    阿里忘禪:螞蟻集團(tuán)分布式注冊中心建設(shè)分享

    2021-08-16

    谷歌程序員少輸一個“&”,差點(diǎn)讓全球Chrome筆記本變磚

    2021-08-16

    架構(gòu)師的職責(zé)、核心能力、能力修煉手冊

    2021-08-09

    右軍:為張逸《解構(gòu)領(lǐng)域驅(qū)動設(shè)計(jì)》推薦序

    2021-08-09

    阿里修冶:微服務(wù)拆分之道

    2021-08-24

    萬字長文剖析 APM 系統(tǒng)?如何設(shè)計(jì)與實(shí)現(xiàn)?

    2021-08-20

    微信淘寶等平臺要互通!?騰訊阿里字節(jié)回應(yīng)

    2021-09-14

    一文詳解 API 設(shè)計(jì)最佳實(shí)踐

    2021-09-12

    12 種經(jīng)典億級流量架構(gòu)之資源隔離思想與方法論

    2021-09-09

    拼夕夕訂單超時未支付自動關(guān)閉實(shí)現(xiàn)方案!

    2021-09-08

    新人創(chuàng)作打卡挑戰(zhàn)賽發(fā)博客就能抽獎!定制產(chǎn)品紅包拿不停!

    總結(jié)

    以上是生活随笔為你收集整理的2W 字详解设计模式!的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

    欧美猛少妇色xxxxx | 久久综合九色综合欧美狠狠 | 少妇人妻偷人精品无码视频 | 亚洲国产av精品一区二区蜜芽 | 国产无遮挡吃胸膜奶免费看 | 欧美日韩一区二区免费视频 | 无码免费一区二区三区 | 久久午夜夜伦鲁鲁片无码免费 | 久久久中文字幕日本无吗 | 日本乱偷人妻中文字幕 | 人妻体内射精一区二区三四 | 久久99精品久久久久久动态图 | 国产又爽又黄又刺激的视频 | 丰满岳乱妇在线观看中字无码 | 国产精品久久福利网站 | 女人和拘做爰正片视频 | 国产精品久久久av久久久 | 高清不卡一区二区三区 | 国产精品久久久久9999小说 | 无码国产乱人伦偷精品视频 | 久久99热只有频精品8 | 99久久久无码国产精品免费 | 亚洲欧洲日本综合aⅴ在线 | 欧美35页视频在线观看 | 亚洲日本va中文字幕 | 国产熟妇另类久久久久 | 精品久久久久久亚洲精品 | 人人妻人人澡人人爽欧美一区 | 国产成人人人97超碰超爽8 | 成人免费无码大片a毛片 | 六月丁香婷婷色狠狠久久 | 国产内射老熟女aaaa | 色一情一乱一伦一视频免费看 | 黑人巨大精品欧美一区二区 | 亚洲精品久久久久avwww潮水 | 久久国产自偷自偷免费一区调 | 香蕉久久久久久av成人 | 理论片87福利理论电影 | 久久 国产 尿 小便 嘘嘘 | 国内精品久久毛片一区二区 | 无码人妻少妇伦在线电影 | 无码av免费一区二区三区试看 | 欧美激情一区二区三区成人 | 一本一道久久综合久久 | 日本肉体xxxx裸交 | www国产亚洲精品久久久日本 | 给我免费的视频在线观看 | 亚洲精品国产a久久久久久 | 男女下面进入的视频免费午夜 | 在线 国产 欧美 亚洲 天堂 | 久久午夜夜伦鲁鲁片无码免费 | 亚洲码国产精品高潮在线 | 欧美变态另类xxxx | 少妇厨房愉情理9仑片视频 | 色综合久久中文娱乐网 | 久久99精品久久久久久动态图 | 熟妇女人妻丰满少妇中文字幕 | 在线播放亚洲第一字幕 | 少妇久久久久久人妻无码 | 久久久久久av无码免费看大片 | 伊在人天堂亚洲香蕉精品区 | 一本色道久久综合亚洲精品不卡 | 国产一区二区三区日韩精品 | 国产亚洲精品久久久久久 | 色一情一乱一伦一视频免费看 | 亚洲中文字幕va福利 | 亚洲人亚洲人成电影网站色 | 欧美日韩一区二区综合 | v一区无码内射国产 | 免费无码的av片在线观看 | 99久久人妻精品免费二区 | 国产成人综合在线女婷五月99播放 | 波多野结衣av一区二区全免费观看 | 99麻豆久久久国产精品免费 | 亚洲国产精品成人久久蜜臀 | 丰满岳乱妇在线观看中字无码 | 欧洲欧美人成视频在线 | 99久久精品日本一区二区免费 | 久久伊人色av天堂九九小黄鸭 | 好男人www社区 | 久久久久免费看成人影片 | 人人妻人人澡人人爽精品欧美 | 色五月丁香五月综合五月 | 成人性做爰aaa片免费看 | 永久黄网站色视频免费直播 | 亚洲七七久久桃花影院 | 国产精品a成v人在线播放 | 日日躁夜夜躁狠狠躁 | 国产国产精品人在线视 | 久久午夜夜伦鲁鲁片无码免费 | 水蜜桃av无码 | 一区二区传媒有限公司 | 2019nv天堂香蕉在线观看 | 亚洲中文字幕无码中字 | 伊人色综合久久天天小片 | www国产亚洲精品久久久日本 | 色综合久久88色综合天天 | 久久97精品久久久久久久不卡 | 无码人妻出轨黑人中文字幕 | 99国产欧美久久久精品 | 2019nv天堂香蕉在线观看 | 人人妻人人澡人人爽人人精品浪潮 | 嫩b人妻精品一区二区三区 | 中文字幕乱妇无码av在线 | 丰满少妇人妻久久久久久 | 性生交大片免费看女人按摩摩 | 国产精品久久久久7777 | 女人高潮内射99精品 | 啦啦啦www在线观看免费视频 | 激情国产av做激情国产爱 | 丰满少妇弄高潮了www | 欧美 丝袜 自拍 制服 另类 | 狠狠色丁香久久婷婷综合五月 | 国产人妖乱国产精品人妖 | 一二三四社区在线中文视频 | 九九久久精品国产免费看小说 | 中文无码精品a∨在线观看不卡 | 精品人妻中文字幕有码在线 | 精品亚洲成av人在线观看 | 亚洲国产精品久久久久久 | 99久久99久久免费精品蜜桃 | 亚洲の无码国产の无码步美 | 亚洲a无码综合a国产av中文 | 久久综合香蕉国产蜜臀av | 亚洲中文字幕在线观看 | 亚洲国产精品美女久久久久 | 国产人妻精品午夜福利免费 | 亚洲精品国产精品乱码视色 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 色狠狠av一区二区三区 | 天天摸天天碰天天添 | 国产卡一卡二卡三 | 精品无码一区二区三区的天堂 | 欧美三级a做爰在线观看 | 国产精品18久久久久久麻辣 | 人人澡人人妻人人爽人人蜜桃 | 无码任你躁久久久久久久 | 欧美日韩综合一区二区三区 | 免费无码午夜福利片69 | 奇米影视7777久久精品人人爽 | 丁香啪啪综合成人亚洲 | 日韩精品成人一区二区三区 | 在线 国产 欧美 亚洲 天堂 | 中文字幕乱码人妻二区三区 | 欧洲熟妇色 欧美 | 亚洲色偷偷男人的天堂 | 中文字幕 人妻熟女 | 特级做a爰片毛片免费69 | 人人妻人人澡人人爽人人精品浪潮 | 亚洲综合无码久久精品综合 | 亚洲国产av精品一区二区蜜芽 | 久久精品中文闷骚内射 | 天天躁夜夜躁狠狠是什么心态 | 台湾无码一区二区 | 久久久久久久人妻无码中文字幕爆 | 日日噜噜噜噜夜夜爽亚洲精品 | 性欧美videos高清精品 | 亚洲色欲久久久综合网东京热 | 久久国语露脸国产精品电影 | 久久人人爽人人人人片 | 欧美精品无码一区二区三区 | 亚洲精品综合一区二区三区在线 | 亚洲精品国产精品乱码视色 | 一区二区三区乱码在线 | 欧洲 | 国产又粗又硬又大爽黄老大爷视 | 欧美熟妇另类久久久久久不卡 | 99久久婷婷国产综合精品青草免费 | 未满成年国产在线观看 | 青青青手机频在线观看 | a片免费视频在线观看 | 亚洲精品综合五月久久小说 | 国产精品va在线播放 | 日韩精品一区二区av在线 | 亚洲精品鲁一鲁一区二区三区 | 伊人色综合久久天天小片 | 亚洲精品一区三区三区在线观看 | 精品国产一区二区三区四区在线看 | 欧美性猛交xxxx富婆 | 亚洲国产高清在线观看视频 | 亚洲成av人片在线观看无码不卡 | 国产人妻精品一区二区三区 | 国产情侣作爱视频免费观看 | 久久人人97超碰a片精品 | 大地资源网第二页免费观看 | 日韩精品乱码av一区二区 | 色婷婷av一区二区三区之红樱桃 | 中文精品久久久久人妻不卡 | 亚洲一区二区三区无码久久 | 熟妇激情内射com | 在教室伦流澡到高潮hnp视频 | 最近中文2019字幕第二页 | 欧美 日韩 人妻 高清 中文 | 老熟女重囗味hdxx69 | 国产欧美精品一区二区三区 | 少女韩国电视剧在线观看完整 | 狠狠色色综合网站 | 美女张开腿让人桶 | 欧美亚洲国产一区二区三区 | 国产欧美亚洲精品a | 性欧美疯狂xxxxbbbb | 亚洲国产av美女网站 | 曰韩无码二三区中文字幕 | 97久久国产亚洲精品超碰热 | 99精品无人区乱码1区2区3区 | 激情国产av做激情国产爱 | 精品水蜜桃久久久久久久 | 亚洲精品国偷拍自产在线观看蜜桃 | 欧美激情综合亚洲一二区 | 2020最新国产自产精品 | 国产又粗又硬又大爽黄老大爷视 | 精品夜夜澡人妻无码av蜜桃 | 国产精品亚洲lv粉色 | 色婷婷综合激情综在线播放 | 色综合久久中文娱乐网 | 日韩视频 中文字幕 视频一区 | 美女毛片一区二区三区四区 | 亚洲 高清 成人 动漫 | 欧美日韩在线亚洲综合国产人 | 精品亚洲韩国一区二区三区 | 在线观看国产一区二区三区 | 国产色精品久久人妻 | 久青草影院在线观看国产 | 国精品人妻无码一区二区三区蜜柚 | 精品无码国产一区二区三区av | 狂野欧美性猛xxxx乱大交 | 人人澡人人透人人爽 | 日韩精品a片一区二区三区妖精 | 久久精品女人天堂av免费观看 | 一本无码人妻在中文字幕免费 | 中文字幕人妻丝袜二区 | 中文无码精品a∨在线观看不卡 | 久久精品视频在线看15 | 国产精品久久精品三级 | 国产又粗又硬又大爽黄老大爷视 | 帮老师解开蕾丝奶罩吸乳网站 | 奇米影视888欧美在线观看 | 一个人看的www免费视频在线观看 | 初尝人妻少妇中文字幕 | 日韩欧美群交p片內射中文 | 人妻体内射精一区二区三四 | 国产无遮挡又黄又爽免费视频 | 亚洲国产av精品一区二区蜜芽 | 亚洲七七久久桃花影院 | 亚洲精品一区三区三区在线观看 | 亚洲日韩av片在线观看 | 亚洲无人区午夜福利码高清完整版 | 欧美xxxxx精品 | 欧美三级a做爰在线观看 | 性做久久久久久久久 | 色一情一乱一伦一视频免费看 | √8天堂资源地址中文在线 | 又湿又紧又大又爽a视频国产 | 国产人妻精品午夜福利免费 | 亚洲呦女专区 | 99久久无码一区人妻 | 强伦人妻一区二区三区视频18 | 日本护士毛茸茸高潮 | 亚洲色欲色欲天天天www | 色狠狠av一区二区三区 | 香港三级日本三级妇三级 | 天堂а√在线中文在线 | 少妇性俱乐部纵欲狂欢电影 | 99久久精品国产一区二区蜜芽 | 人妻少妇精品视频专区 | 久久久国产精品无码免费专区 | 四十如虎的丰满熟妇啪啪 | 成人三级无码视频在线观看 | 97人妻精品一区二区三区 | 国产国语老龄妇女a片 | 精品久久久久久亚洲精品 | 免费观看激色视频网站 | 亚洲性无码av中文字幕 | 中文无码成人免费视频在线观看 | 国产性生交xxxxx无码 | 18无码粉嫩小泬无套在线观看 | 高清国产亚洲精品自在久久 | 无码人妻精品一区二区三区下载 | 日韩视频 中文字幕 视频一区 | 国产在线aaa片一区二区99 | 久久人妻内射无码一区三区 | 伊人色综合久久天天小片 | 久久久久国色av免费观看性色 | 国产熟妇高潮叫床视频播放 | 欧美zoozzooz性欧美 | 久久人人97超碰a片精品 | 国产精品高潮呻吟av久久 | 67194成是人免费无码 | 精品亚洲成av人在线观看 | 国产色精品久久人妻 | 女人被男人躁得好爽免费视频 | 性生交大片免费看l | 蜜臀av在线播放 久久综合激激的五月天 | 熟妇人妻激情偷爽文 | 久久亚洲a片com人成 | 中国大陆精品视频xxxx | 日日摸日日碰夜夜爽av | 亚洲爆乳精品无码一区二区三区 | 久久久久久九九精品久 | 一个人看的视频www在线 | 荫蒂被男人添的好舒服爽免费视频 | 亚洲啪av永久无码精品放毛片 | 天下第一社区视频www日本 | 国产精品人人妻人人爽 | 日本熟妇大屁股人妻 | 亚洲日韩av一区二区三区中文 | 国产亚洲美女精品久久久2020 | 性史性农村dvd毛片 | 亚洲国产精品成人久久蜜臀 | 日本精品久久久久中文字幕 | 一本久久a久久精品亚洲 | 国产又爽又黄又刺激的视频 | v一区无码内射国产 | 国产人妻人伦精品1国产丝袜 | 99久久精品国产一区二区蜜芽 | 人妻人人添人妻人人爱 | www国产亚洲精品久久久日本 | 国产av久久久久精东av | 成人影院yy111111在线观看 | 欧美日韩一区二区三区自拍 | 免费播放一区二区三区 | 麻豆人妻少妇精品无码专区 | 老熟妇乱子伦牲交视频 | 人妻插b视频一区二区三区 | 在线观看欧美一区二区三区 | 欧美日韩一区二区三区自拍 | 76少妇精品导航 | 成年美女黄网站色大免费全看 | 水蜜桃色314在线观看 | 最新国产乱人伦偷精品免费网站 | 亚洲国产精品成人久久蜜臀 | 性欧美熟妇videofreesex | 国产莉萝无码av在线播放 | 国产乱人伦偷精品视频 | 色综合久久久久综合一本到桃花网 | 台湾无码一区二区 | 97无码免费人妻超级碰碰夜夜 | 成 人影片 免费观看 | 亚洲va欧美va天堂v国产综合 | 粗大的内捧猛烈进出视频 | 三上悠亚人妻中文字幕在线 | 国产精品无码久久av | 国产成人综合色在线观看网站 | 丰满护士巨好爽好大乳 | а√天堂www在线天堂小说 | 97久久超碰中文字幕 | 小sao货水好多真紧h无码视频 | 亚洲啪av永久无码精品放毛片 | 国产精品igao视频网 | 一本色道久久综合狠狠躁 | 欧美日韩综合一区二区三区 | 少妇人妻av毛片在线看 | 香港三级日本三级妇三级 | 无码纯肉视频在线观看 | 久久精品视频在线看15 | 午夜免费福利小电影 | 图片小说视频一区二区 | 丰满岳乱妇在线观看中字无码 | 午夜肉伦伦影院 | av人摸人人人澡人人超碰下载 | 国产97人人超碰caoprom | 女人被男人爽到呻吟的视频 | 亚洲精品鲁一鲁一区二区三区 | 亚洲成av人片天堂网无码】 | 性开放的女人aaa片 | 亚洲国产综合无码一区 | 国产精品二区一区二区aⅴ污介绍 | 国产精品沙发午睡系列 | 国产精品igao视频网 | 精品欧美一区二区三区久久久 | 精品一区二区三区波多野结衣 | 精品国产一区二区三区av 性色 | 国产在线无码精品电影网 | 久久久精品人妻久久影视 | 亚洲国产成人av在线观看 | 亚洲成a人一区二区三区 | 美女黄网站人色视频免费国产 | v一区无码内射国产 | 国产精品无码永久免费888 | 国产精品无码永久免费888 | 最近中文2019字幕第二页 | 捆绑白丝粉色jk震动捧喷白浆 | 天天做天天爱天天爽综合网 | 一本一道久久综合久久 | 亚洲熟妇色xxxxx欧美老妇 | 亚洲一区二区三区四区 | 老熟妇乱子伦牲交视频 | 曰本女人与公拘交酡免费视频 | 久久亚洲国产成人精品性色 | 亚洲中文字幕久久无码 | 久久综合网欧美色妞网 | 久9re热视频这里只有精品 | 国产区女主播在线观看 | 无码av岛国片在线播放 | 成熟人妻av无码专区 | 亚洲 日韩 欧美 成人 在线观看 | 欧美 丝袜 自拍 制服 另类 | 午夜男女很黄的视频 | 天堂无码人妻精品一区二区三区 | 亚洲中文字幕无码中字 | 日韩人妻系列无码专区 | 日日鲁鲁鲁夜夜爽爽狠狠 | 久久久精品欧美一区二区免费 | 青春草在线视频免费观看 | 精品国产一区二区三区四区在线看 | 亚洲爆乳大丰满无码专区 | 国产精品久久久久无码av色戒 | 精品国产一区二区三区av 性色 | 国产成人一区二区三区别 | 青青草原综合久久大伊人精品 | 欧洲欧美人成视频在线 | 午夜男女很黄的视频 | 牲欲强的熟妇农村老妇女视频 | 亚洲 欧美 激情 小说 另类 | 亚洲精品午夜无码电影网 | 国产亚洲精品久久久久久大师 | 久久综合九色综合欧美狠狠 | 四虎永久在线精品免费网址 | 一本久道久久综合婷婷五月 | 国产精品亚洲综合色区韩国 | 亚洲精品国产精品乱码不卡 | 日本护士毛茸茸高潮 | 国产亚洲精品久久久久久 | 激情内射日本一区二区三区 | 色综合久久88色综合天天 | 国产精品久久久av久久久 | 国产亚洲视频中文字幕97精品 | 久久久久久av无码免费看大片 | 久久久久99精品国产片 | 亚洲成a人片在线观看无码 | 免费无码av一区二区 | 久久99精品国产麻豆蜜芽 | 在线а√天堂中文官网 | 天天躁夜夜躁狠狠是什么心态 | 亚洲人成人无码网www国产 | 免费无码的av片在线观看 | 成人影院yy111111在线观看 | 少妇的肉体aa片免费 | 无码吃奶揉捏奶头高潮视频 | 国产亚洲欧美日韩亚洲中文色 | 日韩精品a片一区二区三区妖精 | 曰本女人与公拘交酡免费视频 | 国产激情一区二区三区 | 中文无码伦av中文字幕 | 一二三四在线观看免费视频 | 狠狠cao日日穞夜夜穞av | 一个人看的视频www在线 | 亚洲国产欧美国产综合一区 | 欧美成人高清在线播放 | 丰满少妇人妻久久久久久 | 日日鲁鲁鲁夜夜爽爽狠狠 | 日本爽爽爽爽爽爽在线观看免 | 国产av无码专区亚洲a∨毛片 | 99久久久无码国产aaa精品 | 成人无码视频免费播放 | 日本xxxx色视频在线观看免费 | 国产精品久久久一区二区三区 | 欧美野外疯狂做受xxxx高潮 | 人人妻人人藻人人爽欧美一区 | 色老头在线一区二区三区 | 免费看男女做好爽好硬视频 | 亚洲精品中文字幕久久久久 | 美女毛片一区二区三区四区 | 97无码免费人妻超级碰碰夜夜 | 又粗又大又硬又长又爽 | 日韩人妻无码一区二区三区久久99 | 男人的天堂av网站 | 国产精品亚洲综合色区韩国 | 无码人妻出轨黑人中文字幕 | 亚洲乱码日产精品bd | 水蜜桃av无码 | 国产色视频一区二区三区 | 免费网站看v片在线18禁无码 | 午夜福利一区二区三区在线观看 | 国产成人精品久久亚洲高清不卡 | 日韩人妻少妇一区二区三区 | 日日摸夜夜摸狠狠摸婷婷 | 呦交小u女精品视频 | 荫蒂被男人添的好舒服爽免费视频 | 国内精品一区二区三区不卡 | 日日摸日日碰夜夜爽av | 久久久久久a亚洲欧洲av冫 | 中文字幕日韩精品一区二区三区 | 四十如虎的丰满熟妇啪啪 | 亚洲 日韩 欧美 成人 在线观看 | 欧美亚洲日韩国产人成在线播放 | 人人爽人人爽人人片av亚洲 | 自拍偷自拍亚洲精品被多人伦好爽 | 中文字幕 人妻熟女 | 人妻无码久久精品人妻 | 黑人大群体交免费视频 | 强伦人妻一区二区三区视频18 | 女人和拘做爰正片视频 | 欧美 日韩 人妻 高清 中文 | 国产suv精品一区二区五 | 欧美熟妇另类久久久久久多毛 | 国产极品美女高潮无套在线观看 | 中文字幕无码免费久久9一区9 | 亚洲国产精品久久久天堂 | 国产乱人偷精品人妻a片 | 乱码午夜-极国产极内射 | 国产av无码专区亚洲a∨毛片 | 亚洲成a人片在线观看无码3d | 一个人免费观看的www视频 | 精品少妇爆乳无码av无码专区 | 亚洲精品无码国产 | 97夜夜澡人人双人人人喊 | 亚洲精品一区二区三区在线 | 狠狠躁日日躁夜夜躁2020 | 日日躁夜夜躁狠狠躁 | 国产麻豆精品一区二区三区v视界 | 国产真实乱对白精彩久久 | 无码纯肉视频在线观看 | 日本一卡二卡不卡视频查询 | 色综合久久久久综合一本到桃花网 | 一个人看的www免费视频在线观看 | 欧美丰满熟妇xxxx性ppx人交 | 激情国产av做激情国产爱 | 成 人影片 免费观看 | 99re在线播放 | 午夜性刺激在线视频免费 | 又色又爽又黄的美女裸体网站 | 久久www免费人成人片 | 99久久久无码国产精品免费 | 亚洲国产成人a精品不卡在线 | 亚洲成色在线综合网站 | 精品久久8x国产免费观看 | 国内综合精品午夜久久资源 | 动漫av一区二区在线观看 | 国产精品亚洲а∨无码播放麻豆 | 久久综合给久久狠狠97色 | 日本一区二区三区免费高清 | 久久99精品久久久久久动态图 | 亚洲国产精品毛片av不卡在线 | 久久久久99精品国产片 | 丰满少妇熟乱xxxxx视频 | 蜜桃视频韩日免费播放 | 97人妻精品一区二区三区 | 日韩人妻无码一区二区三区久久99 | 两性色午夜视频免费播放 | 人妻与老人中文字幕 | 国产亚洲精品久久久久久久 | 亚洲人成人无码网www国产 | 免费看少妇作爱视频 | 1000部啪啪未满十八勿入下载 | 亚洲综合在线一区二区三区 | 国产亚洲欧美日韩亚洲中文色 | 中文字幕无码av波多野吉衣 | 成熟人妻av无码专区 | 最新版天堂资源中文官网 | 中文字幕无码免费久久99 | 亚洲色无码一区二区三区 | 日韩欧美群交p片內射中文 | 久久伊人色av天堂九九小黄鸭 | 天天拍夜夜添久久精品 | 亚洲乱亚洲乱妇50p | 精品一二三区久久aaa片 | 夫妻免费无码v看片 | 九九久久精品国产免费看小说 | 欧美成人家庭影院 | 亚洲天堂2017无码 | 学生妹亚洲一区二区 | 人妻有码中文字幕在线 | 国产午夜手机精彩视频 | 蜜桃无码一区二区三区 | 久久国产自偷自偷免费一区调 | 澳门永久av免费网站 | 久久综合给合久久狠狠狠97色 | 亚洲精品午夜无码电影网 | 国产一区二区三区四区五区加勒比 | 在线成人www免费观看视频 | 一本大道久久东京热无码av | 麻豆果冻传媒2021精品传媒一区下载 | 亚欧洲精品在线视频免费观看 | 荡女精品导航 | 大地资源中文第3页 | 日韩在线不卡免费视频一区 | 精品国产一区二区三区av 性色 | 色婷婷久久一区二区三区麻豆 | 午夜无码人妻av大片色欲 | 性色欲网站人妻丰满中文久久不卡 | 美女毛片一区二区三区四区 | 波多野结衣aⅴ在线 | 男人和女人高潮免费网站 | 免费观看黄网站 | 欧美freesex黑人又粗又大 | 国产综合久久久久鬼色 | 亚洲人成影院在线观看 | 日韩精品乱码av一区二区 | 色一情一乱一伦一视频免费看 | 国产精品18久久久久久麻辣 | av在线亚洲欧洲日产一区二区 | 无码人中文字幕 | 欧美老熟妇乱xxxxx | 男女作爱免费网站 | 国产成人人人97超碰超爽8 | 俄罗斯老熟妇色xxxx | 极品尤物被啪到呻吟喷水 | 无遮挡国产高潮视频免费观看 | 中文字幕乱码亚洲无线三区 | 国产精品人人爽人人做我的可爱 | 欧美野外疯狂做受xxxx高潮 | 高清无码午夜福利视频 | 天天摸天天碰天天添 | 中文字幕无码日韩欧毛 | 男女下面进入的视频免费午夜 | 国产小呦泬泬99精品 | 日本一本二本三区免费 | 中文字幕久久久久人妻 | 夜夜高潮次次欢爽av女 | 国产亚洲精品久久久久久大师 | 国产午夜福利亚洲第一 | 亚洲精品综合一区二区三区在线 | 国产精品亚洲五月天高清 | 最近的中文字幕在线看视频 | 国产又爽又黄又刺激的视频 | 巨爆乳无码视频在线观看 | 欧美肥老太牲交大战 | 麻豆蜜桃av蜜臀av色欲av | 日韩av无码一区二区三区不卡 | 人妻少妇被猛烈进入中文字幕 | 亚洲区欧美区综合区自拍区 | 中文久久乱码一区二区 | 人人妻人人澡人人爽欧美一区九九 | 久久99精品国产麻豆蜜芽 | 无码av岛国片在线播放 | 成人精品一区二区三区中文字幕 | 无码播放一区二区三区 | 狂野欧美性猛xxxx乱大交 | 成人动漫在线观看 | 日欧一片内射va在线影院 | 乌克兰少妇性做爰 | 麻豆果冻传媒2021精品传媒一区下载 | 欧美性猛交内射兽交老熟妇 | 纯爱无遮挡h肉动漫在线播放 | 国产亚洲人成在线播放 | 免费观看黄网站 | 亚洲熟妇色xxxxx欧美老妇y | 日本精品久久久久中文字幕 | 日韩精品乱码av一区二区 | 精品偷自拍另类在线观看 | 又大又硬又黄的免费视频 | 久久国内精品自在自线 | 久久这里只有精品视频9 | 亚洲成av人片天堂网无码】 | 国产乱码精品一品二品 | 一本一道久久综合久久 | 久久精品99久久香蕉国产色戒 | 久久久精品人妻久久影视 | 国产莉萝无码av在线播放 | 国产精品国产三级国产专播 | 欧美变态另类xxxx | 日韩视频 中文字幕 视频一区 | 亚洲一区二区三区香蕉 | aⅴ在线视频男人的天堂 | 无码人妻久久一区二区三区不卡 | 欧美性生交xxxxx久久久 | 午夜福利一区二区三区在线观看 | 日本乱人伦片中文三区 | 激情综合激情五月俺也去 | 亚洲成a人片在线观看无码 | 亚洲国产精品一区二区第一页 | 日本精品人妻无码77777 天堂一区人妻无码 | 亚洲国产综合无码一区 | 午夜福利一区二区三区在线观看 | 亚洲国产日韩a在线播放 | 4hu四虎永久在线观看 | 宝宝好涨水快流出来免费视频 | 国产美女精品一区二区三区 | 国内精品一区二区三区不卡 | 人妻中文无码久热丝袜 | 老熟妇仑乱视频一区二区 | 免费网站看v片在线18禁无码 | 夜夜夜高潮夜夜爽夜夜爰爰 | av在线亚洲欧洲日产一区二区 | 自拍偷自拍亚洲精品10p | 性欧美疯狂xxxxbbbb | 中文字幕人妻丝袜二区 | 欧洲熟妇色 欧美 | 内射巨臀欧美在线视频 | 国精产品一区二区三区 | 四十如虎的丰满熟妇啪啪 | 性欧美熟妇videofreesex | 中文精品久久久久人妻不卡 | 国产性生交xxxxx无码 | 亚洲爆乳无码专区 | 国精品人妻无码一区二区三区蜜柚 | 日日噜噜噜噜夜夜爽亚洲精品 | 3d动漫精品啪啪一区二区中 | 5858s亚洲色大成网站www | 天天拍夜夜添久久精品 | 97精品国产97久久久久久免费 | 天堂无码人妻精品一区二区三区 | 青青草原综合久久大伊人精品 | 内射后入在线观看一区 | 国产人妻久久精品二区三区老狼 | 奇米影视888欧美在线观看 | 国产成人精品三级麻豆 | 夜精品a片一区二区三区无码白浆 | 国产亚av手机在线观看 | 国产精品国产三级国产专播 | 中文字幕av伊人av无码av | 国产精品99爱免费视频 | 国产亚洲精品久久久久久大师 | 亚洲国产av美女网站 | 日韩亚洲欧美中文高清在线 | 麻豆国产97在线 | 欧洲 | 国产精品久久久久久亚洲影视内衣 | 激情五月综合色婷婷一区二区 | 欧美成人免费全部网站 | 国产av一区二区精品久久凹凸 | 亚洲 日韩 欧美 成人 在线观看 | 午夜男女很黄的视频 | 99久久婷婷国产综合精品青草免费 | 领导边摸边吃奶边做爽在线观看 | 亚洲无人区一区二区三区 | 国产人妻大战黑人第1集 | 日韩av无码中文无码电影 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 5858s亚洲色大成网站www | 国产亚洲精品久久久久久大师 | 亚洲国产精华液网站w | 极品嫩模高潮叫床 | 婷婷丁香六月激情综合啪 | 国产一区二区三区精品视频 | 亚洲国产午夜精品理论片 | 最新国产麻豆aⅴ精品无码 | 精品久久久久久人妻无码中文字幕 | 成人无码精品1区2区3区免费看 | 国产精品香蕉在线观看 | 爆乳一区二区三区无码 | 天堂亚洲2017在线观看 | 国产精品久久久久久久9999 | 正在播放东北夫妻内射 | 国产综合久久久久鬼色 | 国产亚洲美女精品久久久2020 | 亚洲熟妇色xxxxx欧美老妇y | 欧美刺激性大交 | 无码任你躁久久久久久久 | 国产精品久久久久久亚洲影视内衣 | 亚洲爆乳无码专区 | 狠狠色欧美亚洲狠狠色www | 中文无码成人免费视频在线观看 | 亚洲精品无码人妻无码 | 国产精品无套呻吟在线 | 成人动漫在线观看 | 东京一本一道一二三区 | 欧美性猛交内射兽交老熟妇 | 网友自拍区视频精品 | 日本精品久久久久中文字幕 | 国产精品二区一区二区aⅴ污介绍 | 国产成人精品优优av | 老熟妇乱子伦牲交视频 | 伊在人天堂亚洲香蕉精品区 | 久久精品人人做人人综合试看 | 久久无码中文字幕免费影院蜜桃 | 性欧美大战久久久久久久 | 久久午夜无码鲁丝片 | 色欲久久久天天天综合网精品 | 人妻熟女一区 | 亚洲国产精品成人久久蜜臀 | 国产精品亚洲а∨无码播放麻豆 | 欧美黑人性暴力猛交喷水 | 水蜜桃av无码 | 日日鲁鲁鲁夜夜爽爽狠狠 | 欧美一区二区三区视频在线观看 | 国产极品美女高潮无套在线观看 | 色综合久久久久综合一本到桃花网 | 人妻体内射精一区二区三四 | 性啪啪chinese东北女人 | 日韩 欧美 动漫 国产 制服 | 7777奇米四色成人眼影 | 日韩人妻系列无码专区 | 欧美性生交活xxxxxdddd | 乌克兰少妇xxxx做受 | 亚洲人成影院在线观看 | 国产精品第一区揄拍无码 | 无遮挡国产高潮视频免费观看 | 欧美成人午夜精品久久久 | 久久人人97超碰a片精品 | 国产精品久久久久久亚洲影视内衣 | 免费人成网站视频在线观看 | 国产成人无码午夜视频在线观看 | 亚洲中文字幕av在天堂 | 亚洲精品久久久久中文第一幕 | 国产成人无码午夜视频在线观看 | 国产激情精品一区二区三区 | 久久国产精品精品国产色婷婷 | 亚洲欧美国产精品专区久久 | 精品 日韩 国产 欧美 视频 | 国产在线aaa片一区二区99 | 伊人久久婷婷五月综合97色 | 欧美亚洲国产一区二区三区 | 国产精品二区一区二区aⅴ污介绍 | 黑人大群体交免费视频 | 人人妻人人藻人人爽欧美一区 | 久久 国产 尿 小便 嘘嘘 | 亚洲国产av美女网站 | 天天拍夜夜添久久精品大 | 丰满护士巨好爽好大乳 | 中文字幕无线码免费人妻 | 永久黄网站色视频免费直播 | 亚洲日韩av一区二区三区四区 | 网友自拍区视频精品 | 欧美国产亚洲日韩在线二区 | 国产精品国产自线拍免费软件 | 日本高清一区免费中文视频 | 大肉大捧一进一出视频出来呀 | 久久精品丝袜高跟鞋 | 国产xxx69麻豆国语对白 | 久久久久亚洲精品中文字幕 | 亚洲综合在线一区二区三区 | 人人妻人人澡人人爽欧美精品 | 精品欧洲av无码一区二区三区 | 国产精品人妻一区二区三区四 | 久久精品成人欧美大片 | 白嫩日本少妇做爰 | 性欧美videos高清精品 | 丰满人妻一区二区三区免费视频 | 红桃av一区二区三区在线无码av | 中国大陆精品视频xxxx | 精品无人区无码乱码毛片国产 | 亚洲自偷自拍另类第1页 | 人人妻人人澡人人爽欧美精品 | 久久久av男人的天堂 | 国产精品久久久久久无码 | 国产熟妇高潮叫床视频播放 | 久久综合狠狠综合久久综合88 | 久久五月精品中文字幕 | 日本va欧美va欧美va精品 | 亚洲综合伊人久久大杳蕉 | 中文字幕乱妇无码av在线 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 中文字幕人妻无码一夲道 | 少妇愉情理伦片bd | 中文字幕久久久久人妻 | 波多野结衣乳巨码无在线观看 | 熟女体下毛毛黑森林 | 无码吃奶揉捏奶头高潮视频 | 国产成人午夜福利在线播放 | 成人无码精品一区二区三区 | 国产人妻精品一区二区三区 | 熟女少妇人妻中文字幕 | 九月婷婷人人澡人人添人人爽 | 天天做天天爱天天爽综合网 | 亚拍精品一区二区三区探花 | 亚洲色偷偷偷综合网 | 久久99精品久久久久久 | 精品无码国产一区二区三区av | 国产精品二区一区二区aⅴ污介绍 | 亚洲精品欧美二区三区中文字幕 | 最近的中文字幕在线看视频 | 高清国产亚洲精品自在久久 | 午夜无码区在线观看 | 国产乱人伦av在线无码 | 中文亚洲成a人片在线观看 | 免费视频欧美无人区码 | 久久综合香蕉国产蜜臀av | 国产亚洲精品久久久ai换 | 伊人久久婷婷五月综合97色 | 青草视频在线播放 | 欧美变态另类xxxx | 亚洲自偷自拍另类第1页 | 无码福利日韩神码福利片 | 久久亚洲中文字幕无码 | 日日鲁鲁鲁夜夜爽爽狠狠 | 中文毛片无遮挡高清免费 | 亚洲中文字幕无码一久久区 | 少妇性荡欲午夜性开放视频剧场 | 丁香啪啪综合成人亚洲 | 色综合久久网 | 久久精品国产一区二区三区 | 国内精品九九久久久精品 | 性生交大片免费看女人按摩摩 | 88国产精品欧美一区二区三区 | 亚洲色成人中文字幕网站 | 日韩av无码一区二区三区不卡 | 日韩视频 中文字幕 视频一区 | 一本色道婷婷久久欧美 | 最新版天堂资源中文官网 | 天天做天天爱天天爽综合网 | 性欧美牲交在线视频 | 婷婷色婷婷开心五月四房播播 | 人人澡人人妻人人爽人人蜜桃 | 精品厕所偷拍各类美女tp嘘嘘 | 老太婆性杂交欧美肥老太 | 色婷婷久久一区二区三区麻豆 | 一本久久a久久精品亚洲 | 亚洲中文字幕成人无码 | 丁香花在线影院观看在线播放 | 乱人伦中文视频在线观看 | 久久国产劲爆∧v内射 | 国产在线精品一区二区高清不卡 | 人妻夜夜爽天天爽三区 | 免费国产黄网站在线观看 | 中文字幕无码免费久久99 | 国产 精品 自在自线 | 国产成人av免费观看 | 激情爆乳一区二区三区 | 国产成人精品久久亚洲高清不卡 | 无码国模国产在线观看 | 国产人成高清在线视频99最全资源 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 亚洲成色在线综合网站 | 亚洲精品一区二区三区四区五区 | 国产精品美女久久久久av爽李琼 | 国产av一区二区精品久久凹凸 | 久久精品中文字幕大胸 | 欧美大屁股xxxxhd黑色 | 日本熟妇人妻xxxxx人hd | 内射后入在线观看一区 | 精品无码国产一区二区三区av | 国产莉萝无码av在线播放 | 人妻互换免费中文字幕 | 人人妻人人澡人人爽欧美一区 | 欧美日本免费一区二区三区 | 一本久久a久久精品vr综合 | 午夜男女很黄的视频 | 国产人妻精品一区二区三区 | 中文字幕人成乱码熟女app | 欧美第一黄网免费网站 | 少妇人妻偷人精品无码视频 | 婷婷丁香五月天综合东京热 | 亚洲精品www久久久 | 97久久超碰中文字幕 | 美女毛片一区二区三区四区 | 97精品国产97久久久久久免费 | 中文字幕乱码人妻无码久久 | 国产亚洲精品久久久久久久久动漫 | 少妇性l交大片 | 76少妇精品导航 | 欧美性猛交内射兽交老熟妇 | 国产人妻人伦精品1国产丝袜 | 青青青爽视频在线观看 | 国产免费观看黄av片 | 亚洲 日韩 欧美 成人 在线观看 | 中文字幕av无码一区二区三区电影 | 激情国产av做激情国产爱 | 国产无遮挡又黄又爽又色 | 久久熟妇人妻午夜寂寞影院 | 久久综合香蕉国产蜜臀av | 精品久久8x国产免费观看 | 国产亚洲美女精品久久久2020 | 曰本女人与公拘交酡免费视频 | 欧美丰满熟妇xxxx | 黄网在线观看免费网站 | 欧美丰满老熟妇xxxxx性 | 久久久久99精品国产片 | 东北女人啪啪对白 | 中文字幕色婷婷在线视频 | 亚洲爆乳无码专区 | 亚洲日本在线电影 | 18禁止看的免费污网站 | 国产精品久久精品三级 | 久久精品中文字幕大胸 | 精品无码国产自产拍在线观看蜜 | 精品国产av色一区二区深夜久久 | 精品乱码久久久久久久 | 久久久久久av无码免费看大片 | 中文无码精品a∨在线观看不卡 | 无码播放一区二区三区 | 亚洲中文字幕无码中字 | 无码av最新清无码专区吞精 | 亚洲欧洲无卡二区视頻 | 中文字幕无码热在线视频 | 国产乱子伦视频在线播放 | 国产精品二区一区二区aⅴ污介绍 | 国产真实乱对白精彩久久 | 秋霞特色aa大片 | 中文字幕无码乱人伦 | 老熟妇仑乱视频一区二区 | 国产一区二区三区影院 | 乱人伦人妻中文字幕无码久久网 | 久久精品女人天堂av免费观看 | 国产亲子乱弄免费视频 | www国产精品内射老师 | 日本丰满护士爆乳xxxx | 曰本女人与公拘交酡免费视频 | 国产精品久久久午夜夜伦鲁鲁 | 国产精品亚洲专区无码不卡 | 日本xxxx色视频在线观看免费 | 2020久久香蕉国产线看观看 | 国产午夜亚洲精品不卡 | 欧美性生交xxxxx久久久 | 亚洲爆乳无码专区 | 丝袜足控一区二区三区 | 无码吃奶揉捏奶头高潮视频 | 亚洲色在线无码国产精品不卡 | 日韩欧美中文字幕公布 | 中文字幕无码视频专区 | 亚洲a无码综合a国产av中文 | 国产精品丝袜黑色高跟鞋 | 亚洲国产精品久久久久久 | 俄罗斯老熟妇色xxxx | 欧美熟妇另类久久久久久多毛 | 又大又黄又粗又爽的免费视频 | 国产热a欧美热a在线视频 | 欧美性生交xxxxx久久久 | 亚洲欧美日韩成人高清在线一区 | 夜夜夜高潮夜夜爽夜夜爰爰 | 亚洲成av人片天堂网无码】 | 天下第一社区视频www日本 | 国产精品va在线播放 | 亚洲最大成人网站 | 18无码粉嫩小泬无套在线观看 | 国产亚洲精品精品国产亚洲综合 | 国产亚洲精品久久久久久大师 | 成人女人看片免费视频放人 | 少妇性俱乐部纵欲狂欢电影 | 欧美性猛交内射兽交老熟妇 | 国产av一区二区精品久久凹凸 | 国产精品久久久午夜夜伦鲁鲁 | 久久99精品久久久久婷婷 | 香蕉久久久久久av成人 | 日韩精品久久久肉伦网站 | 国产成人精品视频ⅴa片软件竹菊 | 国产香蕉97碰碰久久人人 | 成人精品天堂一区二区三区 | 欧美xxxxx精品 | 精品成人av一区二区三区 | 18禁止看的免费污网站 | 国产肉丝袜在线观看 | 色综合久久久无码中文字幕 | 色诱久久久久综合网ywww | 国产黄在线观看免费观看不卡 | 一区二区三区高清视频一 | 成人三级无码视频在线观看 | 欧美日本精品一区二区三区 | 国产口爆吞精在线视频 | 久久午夜无码鲁丝片午夜精品 | 99久久无码一区人妻 | 激情国产av做激情国产爱 | 国产电影无码午夜在线播放 | 牲欲强的熟妇农村老妇女 | 日本丰满护士爆乳xxxx | 狠狠综合久久久久综合网 | 亚洲成色在线综合网站 | 成人亚洲精品久久久久 | 久久久久久国产精品无码下载 | 老熟女重囗味hdxx69 | 国产97人人超碰caoprom | 亚洲国产一区二区三区在线观看 | 中文字幕乱码亚洲无线三区 | 成人免费视频在线观看 | 男女下面进入的视频免费午夜 | 人妻无码αv中文字幕久久琪琪布 | 亚洲欧美国产精品专区久久 | 综合网日日天干夜夜久久 | 国产成人一区二区三区在线观看 | 真人与拘做受免费视频 | 精品国产av色一区二区深夜久久 | 国产超碰人人爽人人做人人添 | 免费无码一区二区三区蜜桃大 | 国产人妻精品一区二区三区 | 欧美国产日产一区二区 | 亚洲精品欧美二区三区中文字幕 | 综合网日日天干夜夜久久 | 67194成是人免费无码 | 妺妺窝人体色www在线小说 | 欧美 丝袜 自拍 制服 另类 | 精品欧洲av无码一区二区三区 | 真人与拘做受免费视频 | 国内精品人妻无码久久久影院 | 中文字幕乱码中文乱码51精品 | 国产舌乚八伦偷品w中 | 九一九色国产 | 永久免费观看国产裸体美女 | 99国产欧美久久久精品 | 国产女主播喷水视频在线观看 | 捆绑白丝粉色jk震动捧喷白浆 | 台湾无码一区二区 | 国产成人无码a区在线观看视频app | 午夜嘿嘿嘿影院 | 人人澡人人妻人人爽人人蜜桃 | 内射白嫩少妇超碰 | 亚洲成a人一区二区三区 | 成人综合网亚洲伊人 | 亚洲欧美日韩综合久久久 | 亚洲小说图区综合在线 | 国产精品怡红院永久免费 | www国产亚洲精品久久久日本 | 麻豆国产人妻欲求不满 | 好爽又高潮了毛片免费下载 | 中文精品无码中文字幕无码专区 | 最近免费中文字幕中文高清百度 | 久久国产精品_国产精品 | 国产黄在线观看免费观看不卡 | 亚洲精品久久久久久久久久久 | 久久国产精品偷任你爽任你 | 欧美自拍另类欧美综合图片区 | 无码av最新清无码专区吞精 | 久久熟妇人妻午夜寂寞影院 | 亚洲精品成人福利网站 | 国产 精品 自在自线 | 国产va免费精品观看 | 亚洲高清偷拍一区二区三区 | 欧美黑人性暴力猛交喷水 | 国产一区二区三区精品视频 | 爆乳一区二区三区无码 | 成年女人永久免费看片 | 亚洲日本va中文字幕 | 久青草影院在线观看国产 | 亚洲乱码国产乱码精品精 | 国产片av国语在线观看 | 色婷婷综合激情综在线播放 | 伊人久久大香线焦av综合影院 | 黄网在线观看免费网站 | 精品一二三区久久aaa片 | 97精品人妻一区二区三区香蕉 | 国产在线aaa片一区二区99 | 国产麻豆精品精东影业av网站 | 超碰97人人射妻 | 国产又爽又猛又粗的视频a片 | 亚洲午夜福利在线观看 | 奇米影视7777久久精品人人爽 | 欧美亚洲国产一区二区三区 | 色综合久久中文娱乐网 | 99精品无人区乱码1区2区3区 | 成人精品一区二区三区中文字幕 | 亲嘴扒胸摸屁股激烈网站 | 国产女主播喷水视频在线观看 | 久久亚洲精品中文字幕无男同 | 图片区 小说区 区 亚洲五月 | 性色欲网站人妻丰满中文久久不卡 | 蜜桃臀无码内射一区二区三区 | 99视频精品全部免费免费观看 | v一区无码内射国产 | 久久精品国产日本波多野结衣 | 欧美午夜特黄aaaaaa片 | 无码国内精品人妻少妇 | 日韩av无码一区二区三区 | 国产真实伦对白全集 | 国产av无码专区亚洲awww | 中文字幕无码视频专区 | 乱码av麻豆丝袜熟女系列 | 欧美人与禽zoz0性伦交 | 国产特级毛片aaaaaa高潮流水 | 黑人玩弄人妻中文在线 | 午夜精品一区二区三区的区别 | 人妻尝试又大又粗久久 | 欧美日韩综合一区二区三区 | 国产亚洲精品久久久久久大师 | 国产精品香蕉在线观看 | 性做久久久久久久久 | 国产精品久久久一区二区三区 | 色综合久久网 | 99精品视频在线观看免费 | 久久久久成人精品免费播放动漫 | 精品人人妻人人澡人人爽人人 | 日韩视频 中文字幕 视频一区 | 狠狠色噜噜狠狠狠7777奇米 | 午夜理论片yy44880影院 | 久久成人a毛片免费观看网站 | 麻豆国产丝袜白领秘书在线观看 | 内射老妇bbwx0c0ck | 免费无码午夜福利片69 | 国产熟女一区二区三区四区五区 | 麻豆果冻传媒2021精品传媒一区下载 | 久久国产精品_国产精品 | 一二三四社区在线中文视频 | 国产精品久久久久久亚洲毛片 | 澳门永久av免费网站 | 亚洲国产精品毛片av不卡在线 | 国产超碰人人爽人人做人人添 | 牲欲强的熟妇农村老妇女视频 | 俺去俺来也www色官网 | 国产精品久久久av久久久 | 狂野欧美激情性xxxx | 亚洲中文字幕无码一久久区 | 精品久久久久香蕉网 | 成人aaa片一区国产精品 | 精品人妻av区 | 在线精品亚洲一区二区 | 精品久久久久久人妻无码中文字幕 | www国产亚洲精品久久网站 | 四虎国产精品免费久久 | 日日鲁鲁鲁夜夜爽爽狠狠 | 国产亚洲视频中文字幕97精品 | 色婷婷欧美在线播放内射 | 中文无码精品a∨在线观看不卡 | 精品夜夜澡人妻无码av蜜桃 | 377p欧洲日本亚洲大胆 | 亚洲精品久久久久久一区二区 | 在线а√天堂中文官网 | 国产激情无码一区二区 | 亚洲欧美日韩国产精品一区二区 | 超碰97人人做人人爱少妇 | 日本精品人妻无码77777 天堂一区人妻无码 | 麻豆国产97在线 | 欧洲 | 久久伊人色av天堂九九小黄鸭 | 成人免费视频视频在线观看 免费 | 欧美性生交活xxxxxdddd | 老熟妇乱子伦牲交视频 | 国产另类ts人妖一区二区 | 国产亚洲精品久久久久久久 | 国产亚洲日韩欧美另类第八页 | 久久久精品456亚洲影院 | 成人亚洲精品久久久久软件 | 麻豆果冻传媒2021精品传媒一区下载 | 日韩精品乱码av一区二区 | 亚无码乱人伦一区二区 | 亚洲欧美综合区丁香五月小说 | aa片在线观看视频在线播放 | 国产精品久免费的黄网站 | 久久精品中文闷骚内射 | 国产9 9在线 | 中文 | 亚洲自偷自拍另类第1页 | 男女猛烈xx00免费视频试看 | 天天av天天av天天透 | 亚洲小说图区综合在线 | 久久久精品456亚洲影院 | 漂亮人妻洗澡被公强 日日躁 | 欧美freesex黑人又粗又大 | 国产精品va在线观看无码 | 色情久久久av熟女人妻网站 | 少妇久久久久久人妻无码 | 国产乱码精品一品二品 | 国产内射老熟女aaaa | 国产激情艳情在线看视频 | 国语自产偷拍精品视频偷 | 水蜜桃色314在线观看 | 中文字幕精品av一区二区五区 | 色情久久久av熟女人妻网站 | 一个人看的www免费视频在线观看 | 日本一卡2卡3卡四卡精品网站 | 久久亚洲国产成人精品性色 | 西西人体www44rt大胆高清 | 亚洲欧美中文字幕5发布 | 日日天干夜夜狠狠爱 | 日本一区二区更新不卡 | 美女张开腿让人桶 | 欧美成人免费全部网站 | 精品国偷自产在线视频 | 国产精品久久久久久亚洲毛片 | 领导边摸边吃奶边做爽在线观看 | 波多野结衣aⅴ在线 | 中国女人内谢69xxxxxa片 | 中文字幕无码视频专区 | 国产极品美女高潮无套在线观看 | 国产人妻精品一区二区三区不卡 | 好爽又高潮了毛片免费下载 | 日日鲁鲁鲁夜夜爽爽狠狠 | 欧美日韩一区二区综合 | 亚洲码国产精品高潮在线 | 麻花豆传媒剧国产免费mv在线 | av无码久久久久不卡免费网站 | 亚洲成av人片在线观看无码不卡 | 激情内射日本一区二区三区 | 荫蒂被男人添的好舒服爽免费视频 | 荫蒂被男人添的好舒服爽免费视频 | 久久久国产精品无码免费专区 | aⅴ亚洲 日韩 色 图网站 播放 | 欧美日韩视频无码一区二区三 | 亚洲中文字幕va福利 | 国精品人妻无码一区二区三区蜜柚 | 免费看男女做好爽好硬视频 | 欧美性生交xxxxx久久久 | 在线亚洲高清揄拍自拍一品区 | 一个人免费观看的www视频 | 在线成人www免费观看视频 | 高潮喷水的毛片 | 亚洲人成影院在线无码按摩店 | 成年美女黄网站色大免费全看 | 黑人巨大精品欧美一区二区 | 又粗又大又硬又长又爽 | 国产精品久久久久影院嫩草 | 国产农村乱对白刺激视频 | 偷窥村妇洗澡毛毛多 | 国内精品人妻无码久久久影院 | 99riav国产精品视频 | 丰满妇女强制高潮18xxxx | 97无码免费人妻超级碰碰夜夜 | 精品久久8x国产免费观看 | 国产在热线精品视频 | 中文字幕无码乱人伦 | 日韩成人一区二区三区在线观看 | 波多野42部无码喷潮在线 | 中文字幕久久久久人妻 | 久久久中文久久久无码 | 乱人伦人妻中文字幕无码 | 久久99精品国产麻豆蜜芽 | 无码人妻出轨黑人中文字幕 | 日本精品人妻无码77777 天堂一区人妻无码 | 国产精品对白交换视频 | 日韩人妻少妇一区二区三区 | 国产黄在线观看免费观看不卡 | 日日橹狠狠爱欧美视频 | 亚洲a无码综合a国产av中文 | 日本www一道久久久免费榴莲 | 久久综合给合久久狠狠狠97色 | 久久久久99精品成人片 | 精品国产精品久久一区免费式 | 中文精品久久久久人妻不卡 | 亚洲无人区午夜福利码高清完整版 | 欧美日韩在线亚洲综合国产人 | 中文字幕日韩精品一区二区三区 | 日本欧美一区二区三区乱码 | 丰满少妇熟乱xxxxx视频 | 九九久久精品国产免费看小说 | 夜先锋av资源网站 | 成 人 免费观看网站 | 国产明星裸体无码xxxx视频 | 久久久久成人精品免费播放动漫 | 全球成人中文在线 | 综合激情五月综合激情五月激情1 | 亚洲精品一区二区三区大桥未久 | 日韩精品无码免费一区二区三区 | 精品一区二区三区无码免费视频 | 一本加勒比波多野结衣 | 久久久国产精品无码免费专区 | 一二三四社区在线中文视频 | 国产97在线 | 亚洲 | 久久天天躁夜夜躁狠狠 | 日韩精品一区二区av在线 | 久久精品丝袜高跟鞋 | 久久久婷婷五月亚洲97号色 | 熟妇人妻激情偷爽文 | 成年女人永久免费看片 | 日本丰满熟妇videos | 久久国产自偷自偷免费一区调 | 丰满人妻被黑人猛烈进入 | 亚洲欧美精品aaaaaa片 | 成人欧美一区二区三区黑人免费 | 欧美精品一区二区精品久久 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 国产精品人人妻人人爽 | 人人爽人人爽人人片av亚洲 | а天堂中文在线官网 | 无码福利日韩神码福利片 | 国内丰满熟女出轨videos | 久久精品中文字幕大胸 | 亚洲日韩av一区二区三区中文 | 国产一区二区不卡老阿姨 | 性色av无码免费一区二区三区 | 最新国产乱人伦偷精品免费网站 | 国产在热线精品视频 | 中文精品久久久久人妻不卡 | 自拍偷自拍亚洲精品被多人伦好爽 | 亚洲成a人一区二区三区 | 天天摸天天碰天天添 | 97无码免费人妻超级碰碰夜夜 | 国产精品久久福利网站 | 清纯唯美经典一区二区 | 国产精品亚洲а∨无码播放麻豆 | 国产综合色产在线精品 | 国产av无码专区亚洲a∨毛片 | 国产精品多人p群无码 | 免费观看又污又黄的网站 | 无码国模国产在线观看 | 亚洲啪av永久无码精品放毛片 | 影音先锋中文字幕无码 | 大色综合色综合网站 | 欧美熟妇另类久久久久久不卡 | 成人性做爰aaa片免费看不忠 | av无码电影一区二区三区 | 精品欧美一区二区三区久久久 | 成人女人看片免费视频放人 | 亚洲人成人无码网www国产 | 亚洲国产精品无码久久久久高潮 | 又粗又大又硬又长又爽 | 日日噜噜噜噜夜夜爽亚洲精品 | 欧美人与物videos另类 | 成人免费视频在线观看 | 玩弄中年熟妇正在播放 | 国产精品久久久久久无码 | 日韩人妻少妇一区二区三区 | 国产免费久久精品国产传媒 | 亚洲第一无码av无码专区 | 亚洲精品综合五月久久小说 | aⅴ在线视频男人的天堂 | 黑人巨大精品欧美一区二区 | 中文字幕无码免费久久9一区9 | 无码av中文字幕免费放 | 奇米影视7777久久精品人人爽 | 成人一在线视频日韩国产 | 日韩视频 中文字幕 视频一区 | 大地资源网第二页免费观看 | 久久精品国产亚洲精品 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 色诱久久久久综合网ywww | av小次郎收藏 | 成熟妇人a片免费看网站 | 亚洲精品午夜无码电影网 | 人人爽人人澡人人高潮 | 日韩精品久久久肉伦网站 | 亚洲综合在线一区二区三区 | 亚洲国产精品久久久久久 | 日韩av激情在线观看 | 欧美乱妇无乱码大黄a片 | 国产肉丝袜在线观看 | 久久精品国产精品国产精品污 | 精品久久综合1区2区3区激情 | 狠狠cao日日穞夜夜穞av | 99久久无码一区人妻 | 清纯唯美经典一区二区 | 亚洲精品国产精品乱码视色 | 一个人看的视频www在线 | 亚洲の无码国产の无码步美 | 国产精品igao视频网 | а天堂中文在线官网 | 午夜无码人妻av大片色欲 | 少女韩国电视剧在线观看完整 | 亚洲国产午夜精品理论片 | 国产精品久久久久久亚洲毛片 | 人妻少妇精品视频专区 | 国产精品二区一区二区aⅴ污介绍 | 人妻熟女一区 | 人妻少妇精品无码专区二区 | 国产黑色丝袜在线播放 | 亚洲精品一区二区三区在线 | 中文字幕亚洲情99在线 | 国产乱人伦av在线无码 | 国色天香社区在线视频 | 欧美自拍另类欧美综合图片区 | 97久久精品无码一区二区 | 国产另类ts人妖一区二区 | 国产精品无码久久av | 漂亮人妻洗澡被公强 日日躁 | 女人高潮内射99精品 | 国产无套内射久久久国产 | 亚洲欧美日韩成人高清在线一区 | 久久国产自偷自偷免费一区调 | 亚洲中文字幕av在天堂 | 亚洲精品无码国产 | 亚洲第一无码av无码专区 | 精品人人妻人人澡人人爽人人 | 成人欧美一区二区三区 | 99精品视频在线观看免费 | 88国产精品欧美一区二区三区 | 熟妇激情内射com | 久久人人爽人人爽人人片ⅴ | 免费无码的av片在线观看 | 在线播放无码字幕亚洲 | 欧美亚洲日韩国产人成在线播放 | 国产在线一区二区三区四区五区 | 亚洲爆乳大丰满无码专区 | 亚洲日本一区二区三区在线 | √8天堂资源地址中文在线 | 国产农村妇女高潮大叫 | 真人与拘做受免费视频一 | 欧美日本日韩 | 白嫩日本少妇做爰 | 福利一区二区三区视频在线观看 | 日本丰满熟妇videos | 色欲综合久久中文字幕网 | a片在线免费观看 | 中国大陆精品视频xxxx | 欧美日韩亚洲国产精品 | 丰满人妻被黑人猛烈进入 | 欧美黑人巨大xxxxx | 任你躁在线精品免费 | 色爱情人网站 | 日本熟妇大屁股人妻 | 又大又硬又黄的免费视频 | 欧美黑人性暴力猛交喷水 | 国产无av码在线观看 | 色欲久久久天天天综合网精品 | 精品人妻中文字幕有码在线 | 亚洲区小说区激情区图片区 | 午夜精品久久久内射近拍高清 | 亚洲色欲色欲欲www在线 | 精品国偷自产在线视频 | 久久久久免费看成人影片 | 人妻体内射精一区二区三四 | 成人精品一区二区三区中文字幕 | 免费国产成人高清在线观看网站 | 水蜜桃亚洲一二三四在线 | 奇米影视7777久久精品人人爽 | 99久久无码一区人妻 | 亚洲国产av美女网站 | 玩弄人妻少妇500系列视频 | 精品人妻中文字幕有码在线 | 国产农村乱对白刺激视频 | 国产在线一区二区三区四区五区 | 国产无遮挡又黄又爽免费视频 | 又大又黄又粗又爽的免费视频 | 国产精品自产拍在线观看 | 亚洲熟妇色xxxxx亚洲 | 亚洲色无码一区二区三区 | 极品嫩模高潮叫床 | 无码播放一区二区三区 | 女高中生第一次破苞av | 男人的天堂2018无码 | av在线亚洲欧洲日产一区二区 | 国产精品18久久久久久麻辣 | 亚洲色欲久久久综合网东京热 | 又色又爽又黄的美女裸体网站 | 成人影院yy111111在线观看 | 黑森林福利视频导航 | 国产特级毛片aaaaaaa高清 | 久久久中文字幕日本无吗 | 一本无码人妻在中文字幕免费 | 性欧美熟妇videofreesex | 亚洲一区av无码专区在线观看 | 色综合久久网 | 久久久久久a亚洲欧洲av冫 | 国产精品怡红院永久免费 | 97夜夜澡人人双人人人喊 | 国产精品99久久精品爆乳 | 又大又黄又粗又爽的免费视频 | 国产国产精品人在线视 | 欧美freesex黑人又粗又大 | 欧美人与牲动交xxxx | 99久久婷婷国产综合精品青草免费 | 国产婷婷色一区二区三区在线 | 免费看男女做好爽好硬视频 | 久久国产精品萌白酱免费 | 日本大乳高潮视频在线观看 | 中文字幕无线码免费人妻 | 无码精品人妻一区二区三区av | 天天燥日日燥 | 国产精品亚洲一区二区三区喷水 | 在线天堂新版最新版在线8 | 少妇人妻偷人精品无码视频 | 国产激情综合五月久久 | 天干天干啦夜天干天2017 | 无码av最新清无码专区吞精 | 老子影院午夜精品无码 | 无遮挡国产高潮视频免费观看 | 精品国产国产综合精品 | 久久无码专区国产精品s | 欧美性猛交xxxx富婆 | 帮老师解开蕾丝奶罩吸乳网站 | 97精品国产97久久久久久免费 | 青青久在线视频免费观看 | 亚洲乱码国产乱码精品精 | 亚洲综合色区中文字幕 | 亚洲综合在线一区二区三区 | 成人一区二区免费视频 | 国产综合色产在线精品 | 久久精品国产日本波多野结衣 | 久久精品丝袜高跟鞋 | 波多野结衣高清一区二区三区 | 宝宝好涨水快流出来免费视频 | 狠狠噜狠狠狠狠丁香五月 | 男人扒开女人内裤强吻桶进去 | 久久久久免费精品国产 | 色一情一乱一伦一区二区三欧美 | 色一情一乱一伦一视频免费看 | 一本久道久久综合狠狠爱 | √天堂资源地址中文在线 | 亚洲性无码av中文字幕 | 国产成人精品久久亚洲高清不卡 | 亚洲成av人综合在线观看 | 国产av剧情md精品麻豆 | 亚洲va中文字幕无码久久不卡 | 色综合久久88色综合天天 | 亚洲gv猛男gv无码男同 | 亚洲va欧美va天堂v国产综合 | 久久综合久久自在自线精品自 | 精品成人av一区二区三区 | 欧美一区二区三区视频在线观看 | 亚洲国产一区二区三区在线观看 | 日本又色又爽又黄的a片18禁 | 18无码粉嫩小泬无套在线观看 | 国产亚洲日韩欧美另类第八页 | 亚洲精品中文字幕乱码 | 亚洲日韩av一区二区三区四区 | 人妻中文无码久热丝袜 | 色欲人妻aaaaaaa无码 | 欧洲美熟女乱又伦 | 捆绑白丝粉色jk震动捧喷白浆 | 在教室伦流澡到高潮hnp视频 | 国语精品一区二区三区 | 男人的天堂av网站 | 巨爆乳无码视频在线观看 | 亚洲欧美中文字幕5发布 | 亚洲成a人一区二区三区 | 99视频精品全部免费免费观看 | 5858s亚洲色大成网站www | 久久 国产 尿 小便 嘘嘘 | 中国大陆精品视频xxxx | 久久久久久久久蜜桃 | 日本精品久久久久中文字幕 | 亚洲日韩av一区二区三区四区 | 人妻天天爽夜夜爽一区二区 | 麻豆国产97在线 | 欧洲 | 国产乱人无码伦av在线a | 天堂а√在线中文在线 | 中国女人内谢69xxxxxa片 | 精品一区二区三区无码免费视频 | 婷婷综合久久中文字幕蜜桃三电影 | 欧洲极品少妇 | 日本精品人妻无码免费大全 | 国产av人人夜夜澡人人爽麻豆 | 18无码粉嫩小泬无套在线观看 | 亚洲日韩av片在线观看 | 国产av一区二区三区最新精品 | 日本一区二区三区免费播放 | 亚洲区小说区激情区图片区 | 亚洲中文字幕成人无码 | 中文字幕 人妻熟女 | 性啪啪chinese东北女人 | 亚洲精品欧美二区三区中文字幕 | 欧美日韩综合一区二区三区 | 女人和拘做爰正片视频 | 午夜精品一区二区三区在线观看 | 亚洲精品久久久久久一区二区 | 在线欧美精品一区二区三区 | 亚洲精品国产精品乱码不卡 | 国产精品.xx视频.xxtv | 无码人妻av免费一区二区三区 | 97夜夜澡人人爽人人喊中国片 | 欧美性生交xxxxx久久久 | 国产在线精品一区二区高清不卡 | 亚洲国产成人a精品不卡在线 | 久久综合香蕉国产蜜臀av | 日本精品人妻无码免费大全 | 精品人人妻人人澡人人爽人人 | 国产午夜亚洲精品不卡 | 成人试看120秒体验区 | 国产一精品一av一免费 | 日韩人妻无码中文字幕视频 | 国产一区二区不卡老阿姨 | 亚洲成av人片天堂网无码】 | 精品久久8x国产免费观看 | 国产精品亚洲lv粉色 | 亚洲午夜无码久久 | 国産精品久久久久久久 | 亚洲毛片av日韩av无码 | 亚洲爆乳大丰满无码专区 | 四虎国产精品一区二区 | 野狼第一精品社区 | 人妻少妇被猛烈进入中文字幕 | 国产九九九九九九九a片 | 国产精品视频免费播放 | 欧美午夜特黄aaaaaa片 | 国产av一区二区精品久久凹凸 | aa片在线观看视频在线播放 | 97无码免费人妻超级碰碰夜夜 | 欧美性猛交xxxx富婆 | 无码人妻久久一区二区三区不卡 | 国产凸凹视频一区二区 | 熟女俱乐部五十路六十路av | 亚洲精品久久久久中文第一幕 | 97se亚洲精品一区 | 国产黄在线观看免费观看不卡 | 日韩欧美群交p片內射中文 | 日韩精品a片一区二区三区妖精 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 欧美老妇交乱视频在线观看 | 国产精品va在线播放 | 欧美黑人巨大xxxxx | aa片在线观看视频在线播放 | 国产色在线 | 国产 | 任你躁国产自任一区二区三区 | 2019nv天堂香蕉在线观看 | 国产精品久久久久无码av色戒 | 成 人 免费观看网站 | 国产 精品 自在自线 | 夜夜躁日日躁狠狠久久av | 精品国产一区二区三区四区 | 夜夜高潮次次欢爽av女 | 无人区乱码一区二区三区 | 国产亚洲美女精品久久久2020 | 精品无码一区二区三区爱欲 | 99国产欧美久久久精品 | 国产小呦泬泬99精品 | 久久久久久亚洲精品a片成人 | 无套内射视频囯产 | 色诱久久久久综合网ywww | 亚洲精品一区国产 | 久久久久亚洲精品中文字幕 | 精品人妻中文字幕有码在线 | 久久亚洲国产成人精品性色 | 国产精品人妻一区二区三区四 | 国产欧美熟妇另类久久久 | 国产超级va在线观看视频 | 国产超级va在线观看视频 | 国产精品久久久久无码av色戒 | 亚洲国产高清在线观看视频 | 男女性色大片免费网站 | 精品人妻人人做人人爽 | 少妇人妻av毛片在线看 | 白嫩日本少妇做爰 | 无遮挡国产高潮视频免费观看 | 国产亚洲精品精品国产亚洲综合 |