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

一文告訴你Java日期時(shí)間API到底有多爛

開發(fā) 后端
日期時(shí)間API因?yàn)檫^于常用,因此你可能都覺得它毫不起眼。坦白的說,如果你沒有復(fù)雜的日期時(shí)間需求要處理,如涉及到時(shí)區(qū)、偏移量、跨時(shí)區(qū)轉(zhuǎn)換、國(guó)際化顯示等等,那么可能覺得Date也能將就。

 前言

你好,我是A哥(YourBatman)。

好看的代碼,千篇一律!難看的代碼,其實(shí)沒有什么代碼是“史上最爛”的,要有也只有“史上更爛”。

日期是商業(yè)邏輯計(jì)算的一個(gè)關(guān)鍵部分,任何企業(yè)的程序都需要正確的處理日期時(shí)間問題,否則很可能帶來事故和損失。為此本系列僅著眼于這一個(gè)點(diǎn)就寫了好幾篇文章,目的是幫助你系統(tǒng)化的搞定所有問題/難題。

平時(shí)我們都熱衷于吐槽同事的代碼有多爛,今天我們就來玩點(diǎn)狠的:吐槽吐槽JDK,看看它的日期時(shí)間API設(shè)計(jì)得到底有多爛。

  • ❝說明:本文指的日期時(shí)間API是Date/Calendar系列,而非Java 8新的API。畢竟一般我們稱后者為JSR 310日期時(shí)間,請(qǐng)注意區(qū)分哈❞

本文提綱


版本約定

JDK:8

正文

誠(chéng)然,Java的API絕大多數(shù)設(shè)計(jì)得都是非常優(yōu)秀且成功的,否則Java也不可能成為編程語言界的常青藤,并且還常年霸榜。但是,JDK也有失手的地方,存在設(shè)計(jì)得非常爛的API,先來了解下。

最爛API投票

談到對(duì)Java API不滿意程度的調(diào)研,最出名的當(dāng)屬2010年國(guó)外一個(gè)大佬Tiago Fernandez發(fā)起的一個(gè)很有意思的投票,投票結(jié)果的數(shù)據(jù)統(tǒng)計(jì)圖表如下:


對(duì)橫向標(biāo)題欄的各個(gè)單詞解釋一下,從左到右依次為:


計(jì)算最終得分的公式為:

  1. Score = (I can live with) + (Painful * 2) + (Crappy * 3) + (Hellish * 4) 

按照此公式,計(jì)算出各API的得分,畫成直方圖直觀的展示出來:


好,排名出來了。從最爛 -> 最好的名次依次為:

  1. EJB 2.x,簡(jiǎn)直“遙遙領(lǐng)先”
  2. Date/Time/Calendar,今天的豬腳
  3. XML/DOM
  4. AWT/Swing
  5. ...

爛歸爛,想一想什么樣的爛API對(duì)你的產(chǎn)生影響會(huì)是最大的呢?答:很常用卻很爛的。倘若一個(gè)API設(shè)計(jì)得很爛但你很少用或者幾乎不用接觸,你也不會(huì)對(duì)它產(chǎn)生很大厭惡感。打個(gè)比方,一堆屎本身很臭,但若你并不需要走到它身旁也就聞不到,自然就不會(huì)覺得它有多礙眼了。

回到這個(gè)統(tǒng)計(jì)結(jié)果來,EJB 2.x的API設(shè)計(jì)得最爛這個(gè)結(jié)果無可厚非,但站在時(shí)間維度的現(xiàn)在(2021年)回頭來看,是可以完全忽略它了,畢竟現(xiàn)在的我們絕無可能再接觸到它,再爛又有何干呢?

EJB 2.x這個(gè)老古董,相信在看文章的絕大部分同學(xué)都沒見過甚至沒聽過它吧,A哥2015年入行,一上來Spring 4.x嘎嘎就是干,從未接觸過EJB。

  • ❝說明:這個(gè)統(tǒng)計(jì)是2010年做的,那會(huì)EJB2.x的使用量還比較大,因此上了“榜首”❞

XML/DOM設(shè)計(jì)得也不好,但已完全被第三庫(kù)(如dom4j)取代,后者成為了事實(shí)的標(biāo)準(zhǔn);AWT/Swing是市場(chǎng)的抉擇,你用Java開發(fā)界面才會(huì)用到,否則不會(huì)接觸,屬于正常。

最后再看“屈居”第二名的Date/Time/Calendar日期時(shí)間API,它就不得了了。畢竟此API有個(gè)很大的特點(diǎn):哪怕到了現(xiàn)在(2021年)依舊非常常用。所以,它設(shè)計(jì)得爛帶來的實(shí)際影響是蠻大的。

下面就來具體了解下它有哪些坑爹的設(shè)計(jì)和槽點(diǎn),一起不吐不快。

日期時(shí)間API的七宗罪

[[377695]]

罪狀一:Date同時(shí)表示日期和時(shí)間

java.util.Date被設(shè)計(jì)為日期 + 時(shí)間的結(jié)合體。也就是說如果只需要日期,或者只需要單純的時(shí)間,用Date是做不到的。

  1. @Test 
  2. public void test1() { 
  3.     System.out.println(new Date()); 
  4.  
  5. 輸出: 
  6. Fri Jan 22 00:25:06 CST 2021 

這就導(dǎo)致語義非常的不清晰,比如說:

  1. /** 
  2.  * 是否是假期 
  3.  */ 
  4. private static boolean isHoliday(Date date){ 
  5.     return  ...; 

判斷某一天是否是假期,只和日期有關(guān),和具體時(shí)間沒有關(guān)系。如果代碼這樣寫語義只能靠注釋解釋,方法本身無法達(dá)到自描述的效果,也無法通過強(qiáng)類型去約束,因此容易出錯(cuò)。

❝說明:本文所有例子不考慮時(shí)區(qū)問題,下同❞

罪狀二:坑爹的年月日

  1. @Test 
  2. public void test2() { 
  3.     Date date = new Date(); 
  4.     System.out.println("當(dāng)前日期時(shí)間:" + date); 
  5.     System.out.println("年份:" + date.getYear()); 
  6.     System.out.println("月份:" + date.getMonth()); 
  7.  
  8. 輸出: 
  9. 當(dāng)前日期時(shí)間:Fri Jan 22 00:25:16 CST 2021 
  10. 年份:121 
  11. 月份:0 

what?年份是121年,這什么鬼?月份返回0,這又是什么鬼?

無奈,看看這兩個(gè)方法的Javadoc:



尼瑪,原來 2021 - 1900 = 121是這么來的。那么問題來了,為何是1900這個(gè)數(shù)字呢?

月份,竟然從0開始,這是學(xué)的誰呢?簡(jiǎn)直打破了我認(rèn)為的只有index索引值才是從0開始的認(rèn)知啊,這種做法非常的不符合人類思維有木有。

  • ❝索引值從0開始就算了,畢竟那是給計(jì)算機(jī)看的無所謂,但是你這月份主要是給人看的呀❞

罪狀三:Date是可變的

oh my god,也就是說我把一個(gè)Date日期時(shí)間對(duì)象傳給你,你竟然還能給我改掉,真是太沒安全感可言了。

  1. @Test 
  2. public void test() { 
  3.     Date currDate = new Date(); 
  4.     System.out.println("當(dāng)前日期是①:" + currDate); 
  5.     boolean holiday = isHoliday(currDate); 
  6.     System.out.println("是否是假期:" + holiday); 
  7.  
  8.     System.out.println("當(dāng)前日期是②:" + currDate); 
  9.  
  10. /** 
  11.  * 是否是假期 
  12.  */ 
  13. private static boolean isHoliday(Date date) { 
  14.     // 架設(shè)等于這一天才是假期,否則不是 
  15.     Date holiday = new Date(2021 - 1900, 10 - 1, 1); 
  16.  
  17.     if (date.getTime() == holiday.getTime()) { 
  18.         return true
  19.     } else { 
  20.         // 模擬寫代碼時(shí)不注意,使壞 
  21.         date.setTime(holiday.getTime()); 
  22.         return true
  23.     } 
  24.  
  25. 輸出: 
  26. 當(dāng)前日期是①:Fri Jan 22 00:41:59 CST 2021 
  27. 是否是假期:true 
  28. 當(dāng)前日期是②:Fri Oct 01 00:00:00 CST 2021 

我就像讓你幫我判斷下遮天是否是假期,然后你竟然連我的日期都給我改了?過分了啊。這是多么可怕的事,存在重大安全隱患有木有。

針對(duì)這種case,一般來說我們函數(shù)內(nèi)部操作的參數(shù)只能是副本:要么調(diào)用者傳進(jìn)來的就是副本,要么內(nèi)部自己生成一個(gè)副本。

在本利中提高程序健壯性只需在isHoliday首行加入這句代碼即可:

  1. private static boolean isHoliday(Date date) { 
  2.     date = (Datedate.clone(); 
  3.     ... 

再次運(yùn)行程序,輸出:

  1. 當(dāng)前日期是①:Fri Jan 22 00:44:10 CST 2021 
  2. 是否是假期:true 
  3. 當(dāng)前日期是②:Fri Jan 22 00:44:10 CST 2021 

bingo。

但是呢,Date作為高頻使用的API,并不能要求每個(gè)程序員都有這種安全意識(shí),畢竟即使百密也會(huì)有一疏。所以說,把Date設(shè)計(jì)為一個(gè)可變的類是非常糟糕的設(shè)計(jì)。

罪狀四:無法理喻的java.sql.Date

來,看看java.util.Date類的繼承結(jié)構(gòu):


它的三個(gè)子類均處于java.sql包內(nèi)。且先不談這種垮包繼承的合理性問題,直接看下面這個(gè)使用例子:

  1. @Test 
  2. public void test3() { 
  3.     // 竟然還沒有空構(gòu)造器 
  4.     // java.util.Date date = new java.sql.Date(); 
  5.     java.util.Date date = new java.sql.Date(System.currentTimeMillis()); 
  6.  
  7.     // 按到當(dāng)前的時(shí)分秒 
  8.     System.out.println(date.getHours()); 
  9.     System.out.println(date.getMinutes()); 
  10.     System.out.println(date.getSeconds()); 

運(yùn)行程序,暴雷了:

  1. java.lang.IllegalArgumentException 
  2.  at java.sql.Date.getHours(Date.java:187) 
  3.  at com.yourbatman.formatter.DateTester.test3(DateTester.java:65) 
  4.  ... 

what?又是一打破認(rèn)知的結(jié)果啊,第一句getHours()就報(bào)錯(cuò)啦。走進(jìn)java.sql.Date的方法源碼進(jìn)去一看,握草重寫了父類方法:


還有這么重寫父類方法的?還有王法嗎?這也算是JDK能干出來的事?赤裸裸的違背里氏替換原則等眾多設(shè)計(jì)原則,子類能力竟然比父類小,使用起來簡(jiǎn)直讓人云里霧里。

java.util.Date的三個(gè)子類均位于java.sql包內(nèi),他們?nèi)峭ㄟ^Javadoc描述來進(jìn)行分工的:

  • java.sql.Date:只表示日期
  • java.sql.Time:只表示時(shí)間
  • java.sql.Timestamp:表示日期 + 時(shí)間

這么一來,似乎可以“理解”java.sql.Date為何重寫父類的getHours()方法改為拋出IllegalArgumentException異常了,畢竟它只能表示日期嘛。但是這種通過繼承再閹割的實(shí)現(xiàn)手法你們接受得了?反正我是不能的~

罪狀五:無法處理時(shí)區(qū)

因?yàn)槿掌跁r(shí)間的特殊性,不同的國(guó)家地區(qū)在同一時(shí)刻顯示的日期時(shí)間應(yīng)該是不一樣的,但Date做不到,因?yàn)樗讓哟a是這樣的:


也就是說它表示的是一個(gè)具體時(shí)刻(時(shí)間戳),這個(gè)數(shù)值放在全球任何地方都是一模一樣的,也就是說new Date()和System.currentTimeMillis()沒啥兩樣。

JDK提供了TimeZone表示時(shí)區(qū)的概念,但它在Date里并無任何體現(xiàn),只能使用在格式化器上,這種設(shè)計(jì)著實(shí)讓我再一次看不懂了。

罪狀六:線程不安全的格式化器

關(guān)于Date的格式化,站在架構(gòu)設(shè)計(jì)的角度來看,首先不得不吐槽的是Date明明屬于java.util包,那么它的格式化器DateFormat為毛卻跑到j(luò)ava.text里去了呢?這種依賴管理的什么鬼?是不是有點(diǎn)太過于隨意了呢?

另外,JDK提供了一個(gè)DateFormat的子類實(shí)現(xiàn)SimpleDateFormat專門用于格式化日期時(shí)間。但是它卻被設(shè)計(jì)為了線程不安全的,一個(gè)定位為模版組件的API竟然被設(shè)計(jì)為線程不安全的類,實(shí)屬瞎整。

就因?yàn)檫@個(gè)坑的存在,讓多少初中級(jí)工程師淚灑職場(chǎng),算了說多了都是淚。另外,因?yàn)榫€程不安全問題并非必現(xiàn)問題,因此在黑盒/白盒測(cè)試、功能測(cè)試階段都可能測(cè)不出來,留下潛在風(fēng)險(xiǎn)。

  • ❝這就是“靈異事件”:測(cè)試環(huán)境測(cè)試得好好的,為何到線上就出問題了呢?❞

罪狀七:Calendar難當(dāng)大任

從JDK 1.1 開始,Java日期時(shí)間API似乎進(jìn)步了些,引入了Calendar類,并且對(duì)職責(zé)進(jìn)行了劃分:

  • Calendar類:日期和時(shí)間字段之間轉(zhuǎn)換
  • DateFormat類:格式化和解析字符串
  • Date類:只用來承載日期和時(shí)間

有了Calendar后,原有Date中的大部分方法均標(biāo)記為廢棄,交由Calendar代替。


Date終于單純了些:只需要展示日期時(shí)間而無需再顧及年月日操作、格式化操作等等了。值得注意的是,這些方法只是被標(biāo)記為過期,并未刪除。即便如此,請(qǐng)?jiān)趯?shí)際開發(fā)中也一定不要使用它們。

引入了一個(gè)Calendar似乎分離了職責(zé),但Calendar難當(dāng)大任,設(shè)計(jì)上依舊存在很多問題。

  1. @Test 
  2. public void test4() { 
  3.     Calendar calendar = Calendar.getInstance(TimeZone.getDefault()); 
  4.     calendar.set(2021, 10, 1); // -> 依舊是可變的 
  5.  
  6.     System.out.println(calendar.get(Calendar.YEAR)); 
  7.     System.out.println(calendar.get(Calendar.MONTH)); 
  8.     System.out.println(calendar.get(Calendar.DAY_OF_MONTH)); 
  9.  
  10. 輸出: 
  11. 2021 
  12. 10 

年月日的處理上似乎可以接受沒有問題了。從結(jié)果中可以發(fā)現(xiàn),Calendar年份的傳值不用再減去1900了,這和Date是不一樣的,不知道這種行為不一致會(huì)不會(huì)讓有些人抓狂。

  • ❝說明:Calendar相關(guān)的API是由IBM捐過來的,所以和Date不一樣貌似也“情有可原”❞

另外,還有個(gè)重點(diǎn)是Calendar依舊是可變的,所以存在不安全因素,參與計(jì)算改變值時(shí)請(qǐng)使用其副本變量。

總的來說,Calendar在Date的基礎(chǔ)上做了改善,但僅限于修修補(bǔ)補(bǔ),并未從根本上解決問題。最重要的是Calendar的API使用起來真的很不方便,而且該類在語義上也完全不符合日期/時(shí)間的含義,使用起來更顯尷尬。

總之,無論是Date,還是Calendar,還是格式化DateFormat都用著太方便,且存在各式各樣的安全隱患、線程安全問題等等,這是API沒有設(shè)計(jì)好的地方。

并不孤單

日期時(shí)間API屬于基礎(chǔ)API,在各個(gè)語言中都是必備的。然而不僅僅是Java面臨著API設(shè)計(jì)很爛的處境,有些其它流行語言一樣如此,涌現(xiàn)出1個(gè)(1堆)三方庫(kù)比乙方庫(kù)設(shè)計(jì)更好的情況,比如:

  • Python:日期時(shí)間處理庫(kù)Arrow
  • JavaScript:日期時(shí)間處理庫(kù)Moment.js
  • .Net:日期時(shí)間處理庫(kù)Joda-Time

所以說,Java它并不孤單(自我安慰一把)

自我救贖:JSR 310

因?yàn)樵腄ate日期時(shí)間體系存在“七宗罪”,催生了第三方Java日期時(shí)間庫(kù)的誕生,如大名鼎鼎的Joda-Time的流行甚至一度成為標(biāo)配。

對(duì)于Java來說,如此重要的API模塊豈能被第三方庫(kù)給占據(jù),開發(fā)者本就想簡(jiǎn)單的處理個(gè)日期時(shí)間還得導(dǎo)入第三方庫(kù),使用也太不方便了吧。當(dāng)時(shí)的Java如日中天,因此就開啟了“收編”Joda-Time之旅。

2013年9月份,具有劃時(shí)代意義的Java 8大版本正式發(fā)布,該版本帶來了非常多的新特性,其中最引入矚目之一便是全新的日期時(shí)間API:JSR 310。


JSR 310規(guī)范的領(lǐng)導(dǎo)者是Stephen Colebourne,此人也是Joda-Time的締造者。不客氣的說JSR 310是在Joda-Time的基礎(chǔ)上建立的,參考了其絕大部分的API實(shí)現(xiàn),因此若你之前是Joda-Time的重度使用者,現(xiàn)在遷移到Java 8原生的JSR 310日期時(shí)間上來幾乎無縫。

即便這樣,也并不能說JSR 310就完全等于Joda-Time的官方版本,還是有些許詫異的,例舉如下:

  1. 首先當(dāng)然是包名的差別,org.joda.time -> java.time標(biāo)準(zhǔn)日期時(shí)間包
  2. JSR 310不接受null值,Joda-Time把Null值當(dāng)0處理
  3. JSR 310所有拋出的異常是DateTimeException,它是個(gè)RuntimeException,而Joda-Time都是checked exception

簡(jiǎn)單感受下JSR 310 API:

  1. @Test 
  2. public void test5() { 
  3.     System.out.println(LocalDate.now(ZoneId.systemDefault())); 
  4.     System.out.println(LocalTime.now(ZoneId.systemDefault())); 
  5.     System.out.println(LocalDateTime.now(ZoneId.systemDefault())); 
  6.  
  7.     System.out.println(OffsetTime.now(ZoneId.systemDefault())); 
  8.     System.out.println(OffsetDateTime.now(ZoneId.systemDefault())); 
  9.     System.out.println(ZonedDateTime.now(ZoneId.systemDefault())); 
  10.  
  11.     System.out.println(DateTimeFormatter.ISO_LOCAL_DATE.format(LocalDate.now())); 
  12.     System.out.println(DateTimeFormatter.ISO_LOCAL_TIME.format(LocalTime.now())); 
  13.     System.out.println(DateTimeFormatter.ISO_LOCAL_DATE_TIME.format(LocalDateTime.now())); 

JSR 310的所有對(duì)象都是不可變的,所以線程安全。和老的日期時(shí)間API相比,最主要的特征對(duì)比如下:

關(guān)于JSR 310日期時(shí)間更多介紹此處就不展開了,畢竟前面文章啰嗦過好多次了。總之它是Java的新一代日期時(shí)間API,設(shè)計(jì)得非常好,幾乎沒有缺點(diǎn)可言,可用于100%替代老的日期時(shí)間API。

如果你到現(xiàn)在2021年了還沒擁抱它,那么請(qǐng)問你還在等啥呢?

總結(jié)

日期時(shí)間API因?yàn)檫^于常用,因此你可能都覺得它毫不起眼。坦白的說,如果你沒有復(fù)雜的日期時(shí)間需求要處理,如涉及到時(shí)區(qū)、偏移量、跨時(shí)區(qū)轉(zhuǎn)換、國(guó)際化顯示等等,那么可能覺得Date也能將就。

如果你不想做個(gè)將就的人,如果你想擁有更好的日期時(shí)間編程體驗(yàn),棄用Date,擁抱JSR 310吧。

本文思考題

看完了不一定懂,看懂了不一定會(huì)。來,文末3個(gè)思考題幫你復(fù)盤:

  1. 偏移量Z代表什么含義?
  2. ZoneId和ZoneOffset是如何建立對(duì)應(yīng)關(guān)系的?
  3. 若某個(gè)城市不在ZoneId列表里面,想要獲取其UTC偏移量該怎么破?

 

責(zé)任編輯:姜華 來源: BAT的烏托邦
相關(guān)推薦

2022-08-26 12:46:04

NQA網(wǎng)絡(luò)質(zhì)量分析

2019-03-14 15:59:44

前端開發(fā)編程

2024-01-30 09:58:00

IP屬地在線服務(wù)

2024-03-25 08:18:31

2021-04-25 21:18:27

技術(shù)開發(fā)爬蟲

2021-04-09 13:23:27

比特幣貨幣數(shù)據(jù)

2019-03-19 15:28:30

Linux 系統(tǒng) 數(shù)據(jù)

2023-02-07 07:32:12

Istio微服務(wù)治理

2016-08-31 09:48:07

體驗(yàn)

2024-10-28 00:00:03

IP屬地地址

2021-07-26 11:02:29

鄭州暴雨河南

2022-04-25 15:23:18

分布式系統(tǒng)故障

2020-07-31 12:52:40

OLEDQLEDMicroLED

2018-04-26 04:20:42

數(shù)據(jù)科學(xué)簡(jiǎn)歷編程

2022-05-06 08:09:28

代碼提交開發(fā)

2022-01-18 08:04:37

數(shù)據(jù)分析 Python

2018-05-15 09:24:19

硬盤網(wǎng)絡(luò)CPU

2018-07-24 15:22:30

區(qū)塊鏈數(shù)字貨幣比特幣

2016-09-22 16:47:55

iOSAndroidWindows Pho

2023-11-02 08:44:58

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

欧美精品成人久久| 黄色一级大片在线观看| 99久久久国产精品无码网爆| 影音先锋日韩在线| 在线播放日韩导航| 亚洲精品偷拍视频| 亚洲奶汁xxxx哺乳期| 亚洲久久成人| 亚洲欧美在线第一页| 国产一级做a爰片久久| 天堂中文字幕av| 久久精品免费| 少妇高潮 亚洲精品| 天天干天天曰天天操| 成年人视频免费在线播放| 91视频免费观看| 国产精品香蕉在线观看| 一区二区三区影视| 加勒比视频一区| 在线一区二区三区四区| 欧美a级黄色大片| 特黄视频在线观看| 免费高清成人在线| 久久噜噜噜精品国产亚洲综合| 欧美bbbbb性bbbbb视频| 亚洲精品伦理| 亚洲成人你懂的| 三区精品视频| 亚洲精品.www| 日韩激情av在线| 欧美成人一二三| 一道本在线观看| 国产一区二区视频在线看 | 国产综合精品在线| 欧美电影在线观看一区| 日韩欧美在线免费观看| 中文字幕精品在线播放| 欧洲毛片在线| 成人自拍视频在线观看| 国产精品久久久久久久久免费| 亚洲色图第四色| 国产精品自在线拍| 欧美精品亚洲二区| 男人天堂网视频| 女同一区二区免费aⅴ| 中文字幕欧美激情一区| 国产一区二区视频在线免费观看| 国产又粗又猛又爽| 免费中文字幕日韩欧美| 欧美国产日韩一区二区三区| 国产传媒在线看| 尤物tv在线精品| 欧美成人a∨高清免费观看| 男人女人黄一级| 乡村艳史在线观看| 亚洲国产一区在线观看| 99精品一区二区三区的区别| 福利在线视频导航| 91丨porny丨在线| 国产伦精品一区二区三区四区视频| 国产一卡二卡三卡| 国产日韩精品视频一区二区三区| 超碰精品一区二区三区乱码| 一级二级黄色片| 国产欧美一区二区精品久久久| 亚洲国产女人aaa毛片在线| 26uuu国产| 精品一区二区三区在线观看视频| 欧美日韩一区在线| 乌克兰美女av| 国产成人毛片| 欧美日韩精品一区二区三区| 国产三级国产精品国产专区50| 成人影音在线| 午夜精品久久久久影视| 亚洲精品无码国产| 波多野结依一区| 香蕉av福利精品导航| 精品视频在线观看一区二区| 天堂av中文在线| 综合网在线视频| 国产一二三四区在线观看| 免费成人黄色| 亚洲欧美成aⅴ人在线观看| 亚洲一卡二卡三卡四卡无卡网站在线看| 亚州男人的天堂| 2021中文字幕一区亚洲| 日本不卡一区二区三区在线观看| 欧美视频免费一区二区三区| 久久久久久久久99精品| 婷婷久久五月天| 91caoporn在线| 日韩一区日韩二区| 国产日韩第一页| 超碰97免费在线| 疯狂做受xxxx高潮欧美日本| 成人免费毛片播放| 国产精品久久久久久吹潮| 欧美一区二区三区免费视频 | 毛片a片免费观看| 亚洲国产电影| 国产精品999| 国产精品久久免费| 成人三级在线视频| 久久青青草原| 波多野结衣在线网站| 自拍偷拍欧美精品| 欧美一区二区激情| 天天综合网站| 欧美一区二区三区性视频| 国产夫妻性爱视频| 日韩av久操| 免费91在线视频| 黄色片网站在线免费观看| 麻豆精品在线播放| 韩日午夜在线资源一区二区| av片在线免费观看| 亚洲国产你懂的| 五月天亚洲视频| 国产精品白浆| 一区二区国产精品视频| 久久久综合久久| 久久婷婷激情| 成人综合电影| 777电影在线观看| 亚洲国产精品久久人人爱| 国产视频一区二区视频| 91精品啪在线观看国产手机| 永久免费毛片在线播放不卡| 久久久久香蕉视频| 蜜桃视频第一区免费观看| av一区二区三区免费| 北岛玲日韩精品一区二区三区| 中文字幕一区二区三区在线不卡| 欧美人成在线观看| avtt久久| 伊人伊成久久人综合网小说| 中文在线观看免费网站| 轻轻草成人在线| 精品视频导航| 国产黄a三级三级三级av在线看| 欧美午夜激情在线| 亚洲美女高潮久久久| 91久久高清国语自产拍| 国产精品草莓在线免费观看| 日本xxxxxwwwww| 曰韩精品一区二区| 国产色视频在线播放| 亚洲国产精品嫩草影院久久av| 欧美人与性动交a欧美精品| 亚洲一区二区影视| 国产清纯白嫩初高生在线观看91| 久久久天堂国产精品| 91伊人久久| 亚洲欧美中文在线视频| 国产免费av一区| av一本久道久久综合久久鬼色| 91免费视频黄| 日本免费成人| 在线视频欧美日韩| 天天干天天操天天操| 99国产精品久久| 青青草视频国产| 国产高清亚洲| 裸体女人亚洲精品一区| 国产精品无码天天爽视频| 26uuu色噜噜精品一区二区| 国产精品成人久久电影| 久久动漫网址| 97香蕉超级碰碰久久免费软件| 亚洲h视频在线观看| 亚洲精品国产一区二区精华液| 九九热精品国产| 91精品亚洲| 91精品国产一区二区三区动漫| 黄a在线观看| 日韩一区二区三区电影在线观看| 久久久久久久久久97| 国内精品不卡在线| 国产精品av免费| 日韩在线观看中文字幕| 欧美国产日韩在线| 污视频在线免费观看| 日韩欧美国产成人| 亚洲自拍偷拍一区二区| 天堂久久一区二区三区| 亚洲精品中文字幕在线| www.久久99| 久久91精品国产| 男人天堂手机在线观看| 欧美日韩综合视频网址| 国产aⅴ激情无码久久久无码| 日韩国产欧美一区二区三区| 一区二区不卡在线观看| 亚洲不卡在线| 欧美在线性爱视频| 高清中文字幕一区二区三区| 欧美日韩三级视频| 欧美国产日韩在线观看成人| 不卡视频在线看| 91蝌蚪视频在线观看| 亚洲九九视频| 国精产品99永久一区一区| 香蕉视频亚洲一级| 久久久国产91| 天天av天天翘| 欧美网站一区二区| 九九九在线视频| 久久精品亚洲乱码伦伦中文| 中文字幕第22页| 亚洲理论在线| 亚洲永久激情精品| 国产伦精品一区二区三区在线播放| 日本不卡高字幕在线2019| av电影在线播放高清免费观看| 日韩欧美一区二区免费| 亚洲欧美精品一区二区三区| 亚洲精品日韩综合观看成人91| www.com污| 99成人在线| 久久久成人精品一区二区三区| 日韩动漫一区| 国产精品美女久久| heyzo一区| 色诱女教师一区二区三区| 欧美一区二区黄片| 欧美久久久久久久久| 国产区一区二区三| 一区二区在线电影| 粉嫩精品久久99综合一区| 国产91精品在线观看| 人人干人人视频| 亚洲伦理一区| 男女啪啪免费观看| 日韩黄色大片网站| 麻豆av福利av久久av| 日韩成人在线观看视频| 欧洲永久精品大片ww免费漫画| 天堂va在线| 久久视频在线直播| av二区在线| 亚洲网站在线看| 色久视频在线播放| 精品国产三级电影在线观看| 国产精品免费无遮挡| 欧美专区在线观看一区| 99热只有这里有精品| 亚洲一区欧美一区| 久草成人在线视频| 中文字幕第一区| 四虎国产精品成人免费入口| 91丨porny丨最新| 呦呦视频在线观看| 成人精品视频一区二区三区| 天天干天天色天天干| 日一区二区三区| 激情内射人妻1区2区3区| 午夜一区不卡| 91视频最新入口| 欧美在线亚洲| 亚洲巨乳在线观看| 色综合咪咪久久网| 懂色av一区二区三区四区五区| 成人6969www免费视频| 日韩亚洲不卡在线| 欧美一区二区三区高清视频| 欧美日韩在线一二三| 国产99久久精品一区二区300| 久久精品人成| 日韩激情毛片| 欧美大香线蕉线伊人久久国产精品| 牛牛影视久久网| 久久精品国产精品青草色艺| 一本色道久久综合亚洲精品酒店| 九色一区二区| 国产成人3p视频免费观看| 亚洲精品日韩在线观看| 欧美在线黄色| www.com毛片| 久久99国产乱子伦精品免费| 免费观看一区二区三区| 久久新电视剧免费观看| 人人艹在线视频| 亚洲午夜私人影院| 成人免费毛片视频| 日韩一区二区在线观看视频播放| 手机看片福利在线| 色偷偷888欧美精品久久久| 天堂亚洲精品| 国产精品久久久久久久久久久新郎 | 伊人久久大香线蕉av超碰演员| 成人一级片网站| 精品亚洲国产成人av制服丝袜| 免费黄色三级网站| 中文字幕 久热精品 视频在线| 久草免费在线视频观看| 91国内精品野花午夜精品| 亚洲成熟女性毛茸茸| 亚洲一区av在线播放| 欧美日韩色网| 国产精品美乳在线观看| 鲁大师精品99久久久| 一本二本三本亚洲码| 久久久久久夜| 污网站免费观看| 国产精品久久久久久妇女6080| 午夜精品久久久久久久久久久久久蜜桃| 欧美夫妻性生活| 男女污视频在线观看| 欧美精品成人在线| 久久亚洲资源中文字| 久久久婷婷一区二区三区不卡| 欧美一区国产在线| 97超碰成人在线| 久久久精品国产免大香伊| 国产一级免费av| 欧美一区二区三区四区视频| av在线之家电影网站| 热99在线视频| 欧美激情网址| a级黄色小视频| 国产在线视视频有精品| 亚洲天堂岛国片| 欧美午夜视频在线观看| 日韩一级中文字幕| 欧美黄网免费在线观看| 电影中文字幕一区二区| 亚洲欧美日韩精品在线| 日韩av中文在线观看| 国产高清自拍视频| 香蕉成人伊视频在线观看| 午夜精品小视频| 久久国产精品久久国产精品| 在线播放成人| 中文字幕欧美人与畜| 美女视频网站久久| 国产三级短视频| 欧美图区在线视频| chinese偷拍一区二区三区| 国产成人涩涩涩视频在线观看| 欧美日日夜夜| www.四虎成人| 欧美国产一区二区在线观看| 波多野结衣视频在线观看| 亚洲最新中文字幕| av一区在线播放| 亚洲乱码一区二区三区| 久久精品噜噜噜成人av农村| 一二三四在线观看视频| 欧美嫩在线观看| 成人在线观看亚洲| 亚洲xxxxx电影| 欧美不卡在线| 亚洲美女高潮久久久| 亚洲成a人片综合在线| 特黄aaaaaaaaa真人毛片| 琪琪亚洲精品午夜在线| 国产一区二区三区天码| 在线观看国产福利| 亚洲精品久久久久久国产精华液| www.狠狠干| 欧美亚洲在线观看| 精品视频国产| 99精品999| 亚洲福利一区二区| 色就是色亚洲色图| 国产美女被下药99| 欧美福利专区| 亚洲国产第一区| 欧美亚一区二区| 在线视频国产区| 久久综合伊人77777麻豆| 日本不卡在线视频| 可以直接看的黄色网址| 亚洲国产天堂网精品网站| 瑟瑟视频在线看| 亚洲一区精品视频| 成人激情校园春色| 国产精品成人久久久| 久久久成人av| 中文字幕中文字幕精品| 777一区二区| 午夜影院在线观看欧美| 第三区美女视频在线| 亚洲综合在线中文字幕| 国产精品日韩精品欧美精品| 蜜桃av免费观看| 欧美精品一区二区三区蜜臀| 澳门av一区二区三区| 免费网站在线观看视频| 国产日韩精品一区二区三区在线| 国产普通话bbwbbwbbw| 欧美性资源免费| www.av88| 国产麻豆精品视频| 麻豆91精品91久久久| 精品无人区太爽高潮在线播放| 青青伊人久久| 欧美色图色综合| 亚洲乱码精品一二三四区日韩在线|