精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

淺談Java 7的閉包與Lambda表達式之優劣

開發 后端
前幾天Oracle推出了Java 7官方的閉包與Lambda表達式的第一個實現,這基本上也是最終在正式版中的樣式了。看了這個實現之后,我的第一感覺便是“丑”,后來再仔細看了看又想了想,發現Java 7的實現也并非毫無可取之處,但似乎又感到某些做法上有一些問題。

前幾天Oracle推出了Java 7官方的閉包Lambda表達式的第一個實現,這基本上也是最終在正式版中的樣式了。看了這個實現之后,我的第一感覺便是“丑”,當然不排除這是因為看慣了其他語言中實現的緣故。后來再仔細看了看又想了想,發現Java 7的實現也并非毫無可取之處,但似乎又感到某些做法上有一些問題。總之整個過程頗為有趣,決定將我的想法記錄下來,希望可以吸引人來一起討論一下。

Java 7中的Lambda表達式

Java 7中的Lambda表達式有兩種形式,首先是第一種:

  1. #int() func1 = #()(3); // "func1.()" returns 3  
  2. #int(int) func2 = #(int x)(x + 1); // "func2.(3)" returns 4  
  3. #int(int, int) func3 = #(int x, int y)(x - y); // "func3.(5, 3)" returns 2 

然后是第二種,含義與上面等價:

  1. #int() func1 = #(){ return 3; };  
  2. #int(int) func2 = #(int x){ return x + 1; };  
  3. #int(int, int) func3 = #(int x, int y){ return x – y; }; 

如果Lambda的body是“單個表達式”的話,便可以使用“小括號”,并省去最后的return關鍵字;如果body中需要包含多條語句的話,則必須使用“大括號”,而大括號內部可以包含多條語句,就像一個普通的方法體一樣。這兩種寫法在C#中也有對應物,如在“單個表達式”的情況下:

  1. // C#  
  2. Func<int> func1 = () => 3; // "func1()" returns 3  
  3. Func<int, int> func2 = x => x + 1; // "func2(3)" returns 4   
  4. Func<int, int, int> func3 = (x, y) => x - y; // "func3(5, 3)" returns 2  

第二種,即多條語句:

  1. // C#  
  2. Func<int> func1 = () => { return 3; };  
  3. Func<int, int> func2 = x => { return x + 1; };  
  4. Func<int, int, int> func3 = (x, y) => { return x – y; };  
  5.  

Java和C#的Lambda表達式都由兩部分組成:“參數列表”和“表達式體”,但是它們有如下區別:

◆在Java中參數列表和表達式體之間沒有分隔符號,而C#使用“=>”分隔。

◆對于“單個表達式”的Lambda來說,C#可以無需使用括號包含表達式體,而Java必須使用小括號。

◆如果只有單個參數,那么C#的參數列表可以省去小括號,而Java必須保留。

◆C#對參數列表會進行“類型推斷”,而Java必須寫清參數類型。

這些區別說大可大,說小可小,但是Java語言的設計的確讓我感覺較C#為“丑”,這可能是個人主觀因素,但我認為也不盡然。例如,如果我們需要對一個用戶對象數組按照“年齡”進行排序,在C#里可以寫作:

  1. // C#  
  2. users.Sort(u => u.Age);  
  3.  

而在Java中則必須寫為:

  1. Arrays.sort(users, #(User u)(u.Age));  
  2.  
  3.    

這句C#代碼語義清晰:按照“u的Age進行排序”,而在Java代碼中便顯得比較累贅,語義似乎也不夠清晰。Anders在設計C#語法的時候非常注重“聲明式”代碼,由此可見一斑。此外,我不明白為什么Java選擇不對參數進行類型推斷,在我看來這對于寫出優雅代碼十分重要(關于這點,在“Why Java Sucks and C# Rocks”系列中會有更詳細的討論)。不過Java也不是沒有“推斷”,例如從上面的代碼片斷中可以得知,Java對于Lambda表達式的返回值還是進行了類型推斷。事實上,Java還推斷了“異常類型”,這點稍后會有更多討論。

當然,Java中可以“無中生有”地定義“匿名函數類型”(這點和VB.NET相對更為接近),而不需要像C#一樣需要基于特定的“委托類型”,顯得更為靈活。

#p#

SAM類型支持及閉包

SAM的全稱是Single Abstract Method,如果一個類型為SAM類型,則意味著它 1) 是抽象類型(即接口或抽象類),且 2) 只有一個未實現的方法。例如這樣一個Java接口便是個SAM類型:

  1. public interface Func<T, R> {  
  2.     R invoke(T arg);  
  3. }  
  4.  
  5.    
  6.  

于是我們便可以:

  1. Func<int, int>[] array = new Func<int, int>[10];  
  2. for (int i = 0; i < array.length; i++) {  
  3.     final int temp = i;  
  4.     array[i] = #(int x)(x + temp);  
  5. }  
  6.  
  7.  
  8.  

可見,我們使用Lambda表達式創建了Func接口的實例,這點是C#所不具備的。這點十分關鍵,因為在Java類庫中已經有相當多的代碼使用了SAM類型。不過我發現,在某些使用SAM的方式下似乎會產生一些“歧義”,例如這段代碼:

  1. public class MyClass {  
  2.     @Override  
  3.     public int hashCode() {  
  4.         throw new RuntimeException();  
  5.     }  
  6.  
  7.     public void MyMethod() {  
  8.         Func<int, int> func = #(int x)(x * hashCode());  
  9.         int r = func.invoke(5); // throw or not?  
  10.     }  
  11. }  
  12.  
  13.    

在這里我們覆蓋(override)了MyClass的hashCode方法,使它拋出RuntimeException,那么在調用MyMethod中定義的func1對象時會不會拋出異常?答案是否定的,因為在這個Lambda表達式中,隱藏的“this引用”代表了func對象,調用它的hashCode不會拋出RuntimeException。那么,假如我們要調用MyClass的hashCode怎么辦?那就稍微有些麻煩了:

  1. Func<int, int> func = #(int x)(x * MyClass.this.hashCode());  
  2.  
  3.    
  4.  

不過從另一段示例代碼上看:

  1. public class MyClass {  
  2.  
  3.     public int n = 3;  
  4.  
  5.     public void MyMethod() {  
  6.         Func<int, int> func = #(int x)(x + n);  
  7.         int r = func.invoke(5); // 8  
  8.     }  
  9. }  

由于Func對象上沒有n,因此這里的n便是MyClass類里定義的n成員了。因此,Java的閉包并非不會捕獲字面上下文里的成員,只是在SAM類型的情況下,字面范圍內(lexical scope)成員的優先級會低于目標抽象類型的成員。

總體來說,對于SAM類型的支持上,我認為Java是有可取之處的,只是我始終認為這個做法會產生歧義,因為我印象中其他語言里的Lambda表達式似乎都是捕獲字面上下文的(當然它們可能也沒有SAM支持)。但是,如何在“歧義”和“優雅”之間做出平衡,我一時也找不到令人滿意的答案。

硬傷:Checked Exception

Java相當于其他常見語言有一個特別之處,那就是Checked Exception。Checked Exception意味著每個方法要標明自己會拋出哪些異常類型(RuntimeException及其子類除外),這也是方法契約的一部分,編譯器會強制程序員寫出滿足異常契約的代碼。例如某個類庫中定義了這樣一個方法:

  1. public void myMethod() throws AException, BException  
  2.  
  3.    

其中throws后面標注的便是myMethod可能會拋出的異常。于是如果我們要寫一個方法去調用myMethod,則可能是:

  1. public void myMethodCaller() throws AException {  
  2.     try {  
  3.         myMethod();  
  4.     } catch (BException ex) {  
  5.         throw new AException(ex);  
  6.     }  
  7. }  
  8.  
  9.    

當我們寫一個方法A去調用方法B時,我們要么在方法A中使用try...catch捕獲B拋出的方法,要么在方法A的簽名中標記“會拋出同樣的異常”。如上面的myMethodCaller方法,便在內部處理了BException異常,而只會對外拋出AException。Java便使用這種方法嚴格限制了類庫的異常信息。

Checked Exception是一個有爭議的特性。它對于編寫出高質量的代碼非常重要,因為在哪些情況拋出異常其實都是方法契約的一部分(不僅僅是簽名或返回值的問題),應該嚴格遵守,在類庫升級時也不能破壞,否則便會產生兼容性的問題。例如,您關注MSDN里的文檔時,就會看到異常的描述信息,只不過這是靠“文檔”記錄的,而Java則是強制在代碼中的;但是,從另一個角度說,Checked Exception讓代碼編寫變得非常麻煩,這導致的一個情況便是許多人在寫代碼時,自定義的異常全都是RuntimeException(因為不需要標記),每個方法也都是throws Exception的(這樣代碼中就不需要try...catch了),此時Checked Exception特性也基本形同虛設,除了造成麻煩以外幾乎沒有帶來任何好處。

我之前常說:一個特性如果要被人廣泛接受,那它一定要足夠好用。現在如Scala和Grovvy等為Java設計的語言中都放棄了Checked Exception,這也算是從側面印證了Checked Exception的尷尬境地吧。

#p#

而Checked Exception對于如今Lambda或閉包來說,在我看來更像是一種硬傷。為什么這么說?舉個例子吧,假如有這么一個map方法,可以把一個數組映射成另一個類型數組:

  1. public R[] map(T[] array, Func<T, R> mapper) { ... }  
  2.  
  3.    

好,那么比如這樣一個需求:給定一個字符串數組,保存著文件名,要求獲得它的標準路徑。從表面上看來,我們可以這樣寫:

  1. map(files, #(String f)(new File(f).getCanonicalPath())  
  2.  
  3.    

但事實上,這么做無法編譯通過。為什么?因為getCanonicalPath方法會拋出IOException,我們在調用時必須顯式地使用try...catch進行處理。那么這段代碼該怎么寫?還真沒法寫。如果沒有Checked Exception的話(如C#),我們還可以這么做(處理第一個拋出的IOException):

  1. public interface FuncThrowsIOException<T, R> {  
  2.     R invoke(T arg) throws IOException;  
  3. }  
  4.  

 

 但是,如果我們要寫出之前那種“漂亮”的寫法,就不能使用Func<T, R>而必須是這樣的接口類型:

  1. public interface FuncThrowsIOException<T, R> {  
  2.     R invoke(T arg) throws IOException;  
  3. }  
  4.  

或者是這樣的“匿名函數類型”:

#String(String)(throws IOException) // toCanonicalPath = #(String f)(new File(f).getCanonicalPath())
但是,作為Lambda和閉包的常用場景,如map,filter,fold等“函數式”元素,是不可能為某種特定的“異常類型”而設計的——異常類型千變萬化,難道這也要用throws Exception來進行“統一處理”嗎?Java雖然已經支持對異常類型的“推斷”,但Checked Exception還是對Lambda和閉包的適用性造成了很大影響。

因此,我認為Checked Exception是一個“硬傷”。

其他

Java的Lambda和閉包還有一些特性,例如參數的“泛化”:

  1. #boolean(Integer) f = #(Number n)(n.intValue() > 0);  
  2.  

由于Number是Integer的基類,因此我們可以使用Number來構造一個接受Integer參數的匿名函數類型。由于示例較少,我還不清楚這個特性的具體使用場景和意義所在——不過我猜想,在Java中可能允許這樣做吧:

  1. #boolean(Number) f = #(Number n)(n.intValue() > 0);  
  2. #boolean(Integer) ff1 = f; // cast implicitly or explicitly  
  3.  

此外還有一些特性,例如與MethodHandle類型的轉化,我就沒有特別的看法了。

趙劼,網名老趙,洋名Jeffrey Zhao,目前就職于盛大創新院產品開發部,研究員。InfoQ中文站編輯,多次受邀于微軟TechED,MSDN WebCast及各微軟官方或社區會議中擔任技術議題講師。

原文地址:http://blog.zhaojie.me/2010/06/first-version-of-lambda-and-closures-in-java-7.html

【編輯推薦】

  1. Oracle推出首個Java 7閉包版本
  2. Lambda表達式動態函數編程:更加靈活強大
  3. 詳解一個有歧義的Lambda表達式
  4. 詳解如何利用Lambda表達式編寫遞歸函數
責任編輯:佚名 來源: 趙劼blog
相關推薦

2009-09-09 13:01:33

LINQ Lambda

2009-08-27 09:57:50

C# Lambda表達

2012-06-26 10:03:58

JavaJava 8lambda

2024-03-25 13:46:12

C#Lambda編程

2009-04-29 09:05:59

Lambda抽象代表.NET

2024-01-22 09:51:32

Swift閉包表達式尾隨閉包

2024-03-12 08:23:54

JavaLambda函數式編程

2013-01-05 02:19:50

JavaLambda表達式JVM

2009-09-15 15:18:00

Linq Lambda

2022-12-05 09:31:51

接口lambda表達式

2009-09-11 09:48:27

Linq Lambda

2021-08-31 07:19:41

Lambda表達式C#

2013-04-07 15:44:26

Java8Lambda

2009-09-17 09:44:54

Linq Lambda

2009-09-17 10:40:22

Linq Lambda

2009-08-27 09:44:59

C# Lambda表達

2009-09-15 17:30:00

Linq Lambda

2012-07-18 09:45:32

Java 8ScalaLambda

2023-07-31 07:43:07

Java語言表達式變量

2013-04-07 10:04:03

Java8Lambda
點贊
收藏

51CTO技術棧公眾號

一色道久久88加勒比一| 欧美视频第一区| 亚洲黄色在线播放| 午夜影院日韩| 色偷偷av亚洲男人的天堂| 天天爽夜夜爽视频| 精精国产xxxx视频在线播放| 国产午夜精品一区二区| 91亚洲人电影| 日韩中文字幕在线观看视频| 青青草国产免费一区二区下载| 91麻豆精品国产91久久久久| 国产视频九色蝌蚪| 免费在线观看黄| 99久久精品免费看国产| 国产日韩欧美一二三区| 久久国产精品免费看| 97精品国产一区二区三区| 亚洲二区中文字幕| 欧美激情国内自拍| 少妇精品视频一区二区免费看| 亚洲曰韩产成在线| 亚洲一区高清| 青草久久伊人| 成人福利视频在线看| 91精品久久久久久| 久久久黄色大片| 极品av少妇一区二区| 精品国产一区av| 阿v天堂2014| 日韩精品欧美大片| 精品日本一线二线三线不卡| 五月天激情播播| 亚洲成人av观看| 疯狂做受xxxx欧美肥白少妇| 亚洲精品国产suv一区88| av电影在线观看网址| 久久免费偷拍视频| 免费看成人午夜电影| 丰满熟妇乱又伦| 国产成人精品免费在线| 91免费版网站入口| 91久久精品无码一区二区| 丝袜a∨在线一区二区三区不卡| 性欧美长视频免费观看不卡| 动漫精品一区一码二码三码四码| 亚洲一级淫片| 久久久久99精品久久久久| 老司机福利在线观看| 国产一区不卡| 国产亚洲视频在线观看| 成人午夜福利一区二区| 五月天亚洲色图| 亚洲精选一区二区| 在线免费观看黄色小视频| 久久97久久97精品免视看秋霞| 日韩欧美在线一区二区三区| 四川一级毛毛片| 日韩欧美另类中文字幕| 欧美一区二区三区四区视频| 91香蕉视频免费看| 日本成人手机在线| 亚洲精品一区二区三区在线观看| 91精品人妻一区二区三区四区| 欧美午夜在线播放| 精品少妇一区二区三区日产乱码| 性一交一黄一片| 国产劲爆久久| 国产丝袜一区二区| av网在线播放| 久久精品影视| 久久久久成人网| 啦啦啦免费高清视频在线观看| 另类国产ts人妖高潮视频| 国产成人精品网站| 136福利视频导航| 国产91精品在线观看| 激情五月综合色婷婷一区二区| 日本一区高清| 国产精品国产三级国产| 黄色录像特级片| 国产网站在线| 欧美另类z0zxhd电影| 日本中文字幕精品| 亚洲婷婷伊人| 久久视频在线看| 国偷自拍第113页| 免费av成人在线| av一区二区三区四区电影| 五月婷在线视频| 中文字幕av资源一区| 男女裸体影院高潮| 亚洲精品一区| 91精品国产综合久久久久久久久久| 亚洲黄色小说在线观看| 九九久久成人| 欧美激情一区二区三区久久久 | 日韩有码中文字幕在线| 中文字幕免费精品一区高清| 久久免费少妇高潮99精品| 免费视频久久| 91亚洲精品丁香在线观看| 亚洲 国产 欧美 日韩| 国产精品免费视频网站| 日日摸日日碰夜夜爽无码| 国产亚洲人成a在线v网站| 亚洲成人av片| 色婷婷在线视频观看| 久久精品人人| 国产精品.com| 国内精品久久久久久野外| 欧美日韩亚洲高清| 亚洲综合中文网| 精品视频免费| 欧美性受xxx| 国内精品久久久久久久久久| 欧美经典一区二区三区| 欧美牲交a欧美牲交| 欧美片网站免费| 日韩中文字幕av| 波多野结衣国产| 粉嫩绯色av一区二区在线观看| 先锋在线资源一区二区三区| 国产色播av在线| 精品日韩一区二区三区| 18岁成人毛片| 国产自产视频一区二区三区| 日韩视频专区| 国模套图日韩精品一区二区| 亚洲精品一区二区三区福利| 国产又粗又硬又长又爽| 麻豆91在线看| 婷婷四月色综合| 欧美大片高清| 亚洲欧美日韩在线高清直播| 国产亚洲精品成人| 国产成a人无v码亚洲福利| 国产a级片免费看| 人人精品久久| 久久精品一本久久99精品| 糖心vlog精品一区二区| 国产喂奶挤奶一区二区三区| 久久无码高潮喷水| 国产成人精品免费视| 欧美一区二区三区免费观看 | 99精品视频一区二区| 国产www免费| 国产乱人伦精品一区| 欧美精品video| 黄色www视频| 精品福利免费观看| 右手影院亚洲欧美| 久久久久中文| 亚洲国产精品久久久久久女王| 8av国产精品爽爽ⅴa在线观看| 亚洲人成在线电影| 五月婷婷丁香在线| 国产精品免费人成网站| 欧美一级小视频| 欧美一区二区| 波多野结衣久草一区| heyzo高清国产精品| 亚洲国产成人在线播放| 全部毛片永久免费看| 久久品道一品道久久精品| 成人精品小视频| 91青青国产在线观看精品| 亚洲va欧美va在线观看| 美女航空一级毛片在线播放| 91麻豆国产在线| 亚洲综合色丁香婷婷六月图片| 国产性猛交96| 久久久噜噜噜| 伊人av成人| 99re热精品视频| 国产91精品久久久| 五月婷婷在线视频| 精品久久国产字幕高潮| 久久午夜免费视频| 国产精品免费久久久久| 欧美色图校园春色| 性色av一区二区怡红| 午夜精品电影在线观看| 日韩在线网址| 欧美一级视频在线观看| 免费在线观看av片| 亚洲精品在线观看网站| 糖心vlog精品一区二区| 亚洲一区欧美一区| 四季av中文字幕| 成人网页在线观看| 亚洲成人天堂网| 欧美色123| 亚洲成人在线视频网站| 一区二区亚洲视频| 国产精品久久久久久av福利软件| 免费影视亚洲| 中文字幕一区日韩电影| 天天操天天干天天爱| 91精品久久久久久久99蜜桃| 五月婷婷激情视频| 亚洲一本大道在线| 992在线观看| 97久久精品人人做人人爽| 午夜免费福利网站| 久久一区精品| 成年人午夜视频在线观看| 99久久夜色精品国产亚洲96| 美日韩精品免费| 亚洲开心激情| 国产一区在线播放| 在线看欧美视频| 91国产在线精品| 色屁屁www国产馆在线观看| 亚洲天堂av综合网| 亚洲三区在线观看无套内射| 欧美一级精品在线| 91tv国产成人福利| 在线中文字幕不卡| 99热只有这里有精品| 亚洲最大色网站| 免费在线观看黄色小视频| 国产日韩v精品一区二区| 黄色录像a级片| 国产91在线观看丝袜| 一区二区三区人妻| 激情图片小说一区| 国内外成人免费在线视频| 日产欧产美韩系列久久99| 欧美在线观看www| 99热精品在线| 亚洲美免无码中文字幕在线| 国产精品v日韩精品v欧美精品网站| 亚洲欧洲精品一区| 成人嘿咻视频免费看| 日韩高清在线播放| 欧美日韩精品在线一区| 日韩精品一区二区三区四区五区 | 久久精品99久久久香蕉| 成人不用播放器| 伊人男人综合视频网| 国产有码在线| 伊人青青综合网站| av色图一区| xxx欧美精品| 巨大荫蒂视频欧美大片| 久久精品国产成人精品| 国产激情视频在线| 欧美精品一区二区免费| 午夜av在线免费观看| 欧美激情2020午夜免费观看| 国产桃色电影在线播放| 性金发美女69hd大尺寸| 超级碰碰久久| 国产精品福利片| 欧美爱爱视频| 91观看网站| eeuss鲁片一区二区三区| 国产伦精品一区二区三区四区视频 | 日本激情视频一区二区三区| 国产精品电影一区二区| 天堂网avav| 亚洲一区二区三区四区中文字幕| 国产无码精品视频| 色8久久人人97超碰香蕉987| 中文字幕欧美在线观看| 欧美另类久久久品| 丰满少妇一级片| 亚洲视频欧美视频| 天堂资源在线中文| 欧美成人精品xxx| а√天堂中文资源在线bt| 国产成人综合精品| 中文成人激情娱乐网| 国产精品久久久久久久久久直播| 九九热播视频在线精品6| 亚洲 日韩 国产第一区| 欧美1区免费| 男人天堂网视频| 精品在线一区二区三区| 亚洲麻豆一区二区三区| 久久久777精品电影网影网| 久久精品一区二区三区四区五区| 亚洲高清视频在线| 中国老头性行为xxxx| 日韩欧美三级在线| 黄色大片在线看| 久久99久久99精品中文字幕| 亚洲女色av| 91精品中文在线| 亚洲日产av中文字幕| 一级特黄妇女高潮| 性色一区二区| 日本人妻一区二区三区| 久久久国产精品麻豆| 青青操视频在线播放| 色婷婷综合久色| 韩国av免费在线| 最近中文字幕mv在线一区二区三区四区| 日本在线视频www鲁啊鲁| 国产精品视频久久久久| 精品自拍偷拍| 亚洲乱码日产精品bd在线观看| 视频一区视频二区在线观看| 日韩精品国产一区| 国产精品人妖ts系列视频| 国产一级片播放| 欧美丰满美乳xxx高潮www| 欧美日韩国产中文字幕在线| 欧美精品在线免费| 久久天天久久| 欧美日韩中文国产一区发布| 亚洲一级影院| 日日夜夜精品视频免费观看| 国产欧美日本一区二区三区| 99久在线精品99re8热| 欧美大片在线观看一区| 午夜激情视频在线观看| 日本精品久久久| 老牛国内精品亚洲成av人片| 国产 国语对白 露脸| 久久er精品视频| 99久久久无码国产精品性| 亚洲444eee在线观看| 亚洲精品一区二区三区四区| www国产91| 色综合视频一区二区三区日韩 | 在线一区二区观看| 色视频在线观看免费| 97碰在线观看| 久久精品福利| 日本丰满少妇xxxx| 99久久婷婷国产综合精品电影| 欧美精品99久久久| 日韩女同互慰一区二区| 超碰在线免费播放| 亚洲a一级视频| 国产精品成人一区二区不卡| 中文字幕av专区| 国产精品天天看| 亚洲综合精品在线| 久久精品国产综合| 国产成人久久精品一区二区三区| 久久av秘一区二区三区| 国产在线精品视频| 538精品在线视频| 欧美一级二级三级蜜桃| av网站在线免费看推荐| 91超碰在线免费观看| 欧美片第1页综合| 人妻体内射精一区二区三区| 午夜婷婷国产麻豆精品| 午夜av免费观看| 国产精品99一区| 国产精品国产一区| 欧美高清精品一区二区| 亚洲国产va精品久久久不卡综合| 蜜桃视频在线观看www| 午夜精品久久久久久久久久久久 | 亚洲性视频网站| 欧美成人毛片| 51xx午夜影福利| 99精品视频在线观看| 久久永久免费视频| xxx成人少妇69| 粉嫩av一区二区| 欧美三级午夜理伦三级| 国产精品激情偷乱一区二区∴| 国产精品久久婷婷| 久久久久久成人| 伊人精品一区| 奇米视频7777| 亚洲一区二区三区视频在线播放| 亚洲人视频在线观看| 国产精品综合不卡av| 欧美 日韩 国产一区二区在线视频| 亚洲天堂2024| 欧美日韩精品免费观看视频 | 成人亚洲一区| 黑人无套内谢中国美女| 一本一本大道香蕉久在线精品 | 美女网站视频在线观看| 色域天天综合网| 在线免费av导航| 欧美日韩在线观看一区| 国产一区二区视频在线| 国产成人无码精品久在线观看| 一区二区三区四区在线观看视频| 深夜福利一区| 婷婷丁香激情网| 亚洲成av人在线观看| 一区二区三区视频在线观看视频| 97伦理在线四区| 日韩成人一级大片| 国产午夜精品无码| 最近2019好看的中文字幕免费| 国产欧美啪啪| 久久久久久久久久一区| 好吊成人免视频| 亚洲欧美成人影院|