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

壓縮20M文件從30秒到1秒的優化過程

開發 后端
隨著前端所傳圖片的大小越來越大的時候,耗費的時間也在急劇增加,最后測了一下壓縮20M的文件竟然需要30秒的時間。

 [[274403]]

有一個需求需要將前端傳過來的10張照片,然后后端進行處理以后壓縮成一個壓縮包通過網絡流傳輸出去。之前沒有接觸過用Java壓縮文件的,所以就直接上網找了一個例子改了一下用了,改完以后也能使用,但是隨著前端所傳圖片的大小越來越大的時候,耗費的時間也在急劇增加,最后測了一下壓縮20M的文件竟然需要30秒的時間。壓縮文件的代碼如下。 

  1. public static void zipFileNoBuffer() {  
  2.     File zipFile = new File(ZIP_FILE);  
  3.     try (ZipOutputStream zipOut = new ZipOutputStream(new FileOutputStream(zipFile))) {  
  4.         //開始時間  
  5.         long beginTime = System.currentTimeMillis();  
  6.         for (int i = 0; i < 10; i++) {  
  7.             try (InputStream input = new FileInputStream(JPG_FILE)) {  
  8.                 zipOut.putNextEntry(new ZipEntry(FILE_NAME + i));  
  9.                 int temp = 0 
  10.                 while ((temp = input.read()) != -1) {  
  11.                     zipOut.write(temp);  
  12.                 }  
  13.             }  
  14.         }  
  15.         printInfo(beginTime);  
  16.     } catch (Exception e) {  
  17.         e.printStackTrace();  
  18.     }  

這里找了一張2M大小的圖片,并且循環十次進行測試。打印的結果如下,時間大概是30秒。 

  1. fileSize:20M  
  2. consum time:29599 

第一次優化過程-從30秒到2秒

進行優化首先想到的是利用緩沖區BufferInputStream。在FileInputStream中read()方法每次只讀取一個字節。源碼中也有說明。 

  1. /**  
  2.  * Reads a byte of data from this input stream. This method blocks  
  3.  * if no input is yet available.  
  4.  *  
  5.  * @return     the next byte of data, or <code>-1</code> if the end of the  
  6.  *             file is reached.  
  7.  * @exception  IOException  if an I/O error occurs.  
  8.  */  
  9. public native int read() throws IOException; 

這是一個調用本地方法與原生操作系統進行交互,從磁盤中讀取數據。每讀取一個字節的數據就調用一次本地方法與操作系統交互,是非常耗時的。例如我們現在有30000個字節的數據,如果使用FileInputStream那么就需要調用30000次的本地方法來獲取這些數據,而如果使用緩沖區的話(這里假設初始的緩沖區大小足夠放下30000字節的數據)那么只需要調用一次就行。因為緩沖區在第一次調用read()方法的時候會直接從磁盤中將數據直接讀取到內存中。隨后再一個字節一個字節的慢慢返回。

> BufferedInputStream內部封裝了一個byte數組用于存放數據,默認大小是8192。

優化過后的代碼如下: 

  1. public static void zipFileBuffer() {  
  2.     File zipFile = new File(ZIP_FILE);  
  3.     try (ZipOutputStream zipOut = new ZipOutputStream(new FileOutputStream(zipFile));  
  4.             BufferedOutputStream bufferedOutputStream = new BufferedOutputStream(zipOut)) {  
  5.         //開始時間  
  6.         long beginTime = System.currentTimeMillis();  
  7.         for (int i = 0; i &lt; 10; i++) {  
  8.             try (BufferedInputStream bufferedInputStream = new BufferedInputStream(new FileInputStream(JPG_FILE))) {  
  9.                 zipOut.putNextEntry(new ZipEntry(FILE_NAME + i));  
  10.                 int temp = 0 
  11.                 while ((temp = bufferedInputStream.read()) != -1) {  
  12.                     bufferedOutputStream.write(temp);  
  13.                 }  
  14.             }  
  15.         }  
  16.         printInfo(beginTime);  
  17.     } catch (Exception e) {  
  18.         e.printStackTrace();  
  19.     }  

輸出 

  1. ------Buffer  
  2. fileSize:20M  
  3. consum time:1808 

可以看到相比較于第一次使用FileInputStream效率已經提升了許多了。

第二次優化過程-從2秒到1秒

使用緩沖區buffer的話已經是滿足了我的需求了,但是秉著學以致用的想法,就想著用NIO中知識進行優化一下。

使用Channel

為什么要用Channel呢?因為在NIO中新出了Channel和ByteBuffer。正是因為它們的結構更加符合操作系統執行I/O的方式,所以其速度相比較于傳統IO而言速度有了顯著的提高。Channel就像一個包含著煤礦的礦藏,而ByteBuffer則是派送到礦藏的卡車。也就是說我們與數據的交互都是與ByteBuffer的交互。

在NIO中能夠產生FileChannel的有三個類。分別是FileInputStream、FileOutputStream、以及既能讀又能寫的RandomAccessFile。

源碼如下: 

  1. public static void zipFileChannel() {  
  2.     //開始時間  
  3.     long beginTime = System.currentTimeMillis();  
  4.     File zipFile = new File(ZIP_FILE);  
  5.     try (ZipOutputStream zipOut = new ZipOutputStream(new FileOutputStream(zipFile));  
  6.             WritableByteChannel writableByteChannel = Channels.newChannel(zipOut)) {  
  7.         for (int i = 0; i &lt; 10; i++) {  
  8.             try (FileChannel fileChannel = new FileInputStream(JPG_FILE).getChannel()) {  
  9.                 zipOut.putNextEntry(new ZipEntry(i + SUFFIX_FILE));  
  10.                 fileChannel.transferTo(0, FILE_SIZE, writableByteChannel);  
  11.             }  
  12.         }  
  13.         printInfo(beginTime);  
  14.     } catch (Exception e) {  
  15.         e.printStackTrace();  
  16.     }  

我們可以看到這里并沒有使用ByteBuffer進行數據傳輸,而是使用了transferTo的方法。這個方法是將兩個通道進行直連。 

  1. This method is potentially much more efficient than a simple loop  
  2. * that reads from this channel and writes to the target channel.  Many  
  3. * operating systems can transfer bytes directly from the filesystem cache  
  4. * to the target channel without actually copying them.  

這是源碼上的描述文字,大概意思就是使用transferTo的效率比循環一個Channel讀取出來然后再循環寫入另一個Channel好。操作系統能夠直接傳輸字節從文件系統緩存到目標的Channel中,而不需要實際的copy階段。

> copy階段就是從內核空間轉到用戶空間的一個過程

可以看到速度相比較使用緩沖區已經有了一些的提高。 

  1. ------Channel  
  2. fileSize:20M  
  3. consum time:1416 

內核空間和用戶空間

那么為什么從內核空間轉向用戶空間這段過程會慢呢?首先我們需了解的是什么是內核空間和用戶空間。在常用的操作系統中為了保護系統中的核心資源,于是將系統設計為四個區域,越往里權限越大,所以Ring0被稱之為內核空間,用來訪問一些關鍵性的資源。Ring3被稱之為用戶空間。

> 用戶態、內核態:線程處于內核空間稱之為內核態,線程處于用戶空間屬于用戶態

那么我們如果此時應用程序(應用程序是都屬于用戶態的)需要訪問核心資源怎么辦呢?那就需要調用內核中所暴露出的接口用以調用,稱之為系統調用。例如此時我們應用程序需要訪問磁盤上的文件。此時應用程序就會調用系統調用的接口open方法,然后內核去訪問磁盤中的文件,將文件內容返回給應用程序。大致的流程如下

直接緩沖區和非直接緩沖區

既然我們要讀取一個磁盤的文件,要廢這么大的周折。有沒有什么簡單的方法能夠使我們的應用直接操作磁盤文件,不需要內核進行中轉呢?有,那就是建立直接緩沖區了。

  •  非直接緩沖區:非直接緩沖區就是我們上面所講內核態作為中間人,每次都需要內核在中間作為中轉。
  •  直接緩沖區:直接緩沖區不需要內核空間作為中轉copy數據,而是直接在物理內存申請一塊空間,這塊空間映射到內核地址空間和用戶地址空間,應用程序與磁盤之間數據的存取通過這塊直接申請的物理內存進行交互。

既然直接緩沖區那么快,我們為什么不都用直接緩沖區呢?其實直接緩沖區有以下的缺點。直接緩沖區的缺點:

  1.  不安全
  2.  消耗更多,因為它不是在JVM中直接開辟空間。這部分內存的回收只能依賴于垃圾回收機制,垃圾什么時候回收不受我們控制。
  3.  數據寫入物理內存緩沖區中,程序就喪失了對這些數據的管理,即什么時候這些數據被最終寫入從磁盤只能由操作系統來決定,應用程序無法再干涉。

> 綜上所述,所以我們使用transferTo方法就是直接開辟了一段直接緩沖區。所以性能相比而言提高了許多

使用內存映射文件

NIO中新出的另一個特性就是內存映射文件,內存映射文件為什么速度快呢?其實原因和上面所講的一樣,也是在內存中開辟了一段直接緩沖區。與數據直接作交互。源碼如下: 

  1. //Version 4 使用Map映射文件  
  2. public static void zipFileMap() {  
  3.     //開始時間  
  4.     long beginTime = System.currentTimeMillis();  
  5.     File zipFile = new File(ZIP_FILE);  
  6.     try (ZipOutputStream zipOut = new ZipOutputStream(new FileOutputStream(zipFile));  
  7.             WritableByteChannel writableByteChannel = Channels.newChannel(zipOut)) {  
  8.         for (int i = 0; i &lt; 10; i++) {  
  9.             zipOut.putNextEntry(new ZipEntry(i + SUFFIX_FILE));  
  10.             //內存中的映射文件  
  11.             MappedByteBuffer mappedByteBuffer = new RandomAccessFile(JPG_FILE_PATH, "r").getChannel()  
  12.                     .map(FileChannel.MapMode.READ_ONLY, 0, FILE_SIZE);  
  13.             writableByteChannel.write(mappedByteBuffer);  
  14.         }  
  15.         printInfo(beginTime);  
  16.     } catch (Exception e) {  
  17.         e.printStackTrace();  
  18.     }  

打印如下: 

  1. ---------Map  
  2. fileSize:20M  
  3. consum time:1305 

可以看到速度和使用Channel的速度差不多的。

使用Pipe

Java NIO 管道是2個線程之間的單向數據連接。Pipe有一個source通道和一個sink通道。其中source通道用于讀取數據,sink通道用于寫入數據。可以看到源碼中的介紹,大概意思就是寫入線程會阻塞至有讀線程從通道中讀取數據。如果沒有數據可讀,讀線程也會阻塞至寫線程寫入數據。直至通道關閉。 

  1. Whether or not a thread writing bytes to a pipe will block until another  
  2.  thread reads those bytes 

我想要的效果是這樣的。源碼如下: 

  1. //Version 5 使用Pip  
  2. public static void zipFilePip() {  
  3.     long beginTime = System.currentTimeMillis();  
  4.     try(WritableByteChannel out = Channels.newChannel(new FileOutputStream(ZIP_FILE))) {  
  5.         Pipe pipe = Pipe.open();  
  6.         //異步任務  
  7.         CompletableFuture.runAsync(()-&gt;runTask(pipe));  
  8.         //獲取讀通道  
  9.         ReadableByteChannel readableByteChannel = pipe.source();  
  10.         ByteBuffer buffer = ByteBuffer.allocate(((int) FILE_SIZE)*10);  
  11.         while (readableByteChannel.read(buffer)&gt;= 0) {  
  12.             buffer.flip();  
  13.             out.write(buffer);  
  14.             buffer.clear();  
  15.         }  
  16.     }catch (Exception e){  
  17.         e.printStackTrace();  
  18.     }  
  19.     printInfo(beginTime);  
  20.  
  21. //異步任務  
  22. public static void runTask(Pipe pipe) {  
  23.     try(ZipOutputStream zos = new ZipOutputStream(Channels.newOutputStream(pipe.sink()));  
  24.             WritableByteChannel out = Channels.newChannel(zos)) {  
  25.         System.out.println("Begin");  
  26.         for (int i = 0; i &lt; 10; i++) {  
  27.             zos.putNextEntry(new ZipEntry(i+SUFFIX_FILE));  
  28.             FileChannel jpgChannel = new FileInputStream(new File(JPG_FILE_PATH)).getChannel();  
  29.             jpgChannel.transferTo(0, FILE_SIZE, out);  
  30.             jpgChannel.close();  
  31.         }  
  32.     }catch (Exception e){  
  33.         e.printStackTrace();  
  34.     }  

總結

  •  生活處處都需要學習,有時候只是一個簡單的優化,可以讓你深入學習到各種不同的知識。所以在學習中要不求甚解,不僅要知道這個知識也要了解為什么要這么做。
  •  知行合一:學習完一個知識要盡量應用一遍。這樣才能記得牢靠。 

 

責任編輯:龐桂玉 來源: 中國開源
相關推薦

2020-11-12 18:51:43

Java編程語言

2025-06-27 09:05:47

2017-12-25 11:15:06

JavaArray數組

2025-06-25 09:30:14

2022-09-26 09:41:25

MySQL數據庫

2021-08-26 22:26:55

性能優化技術

2025-08-18 03:00:22

Spring樹形結構分類樹

2025-03-27 00:14:10

2019-01-30 09:34:56

ElasticSearLogstashKibana

2013-11-11 11:17:45

AngularJS性能優化

2025-06-04 02:20:00

SQL優化儀表盤

2011-09-29 09:57:27

Ubuntu 11.1

2012-07-24 09:37:19

寬帶光纖

2010-08-19 09:36:28

飛輪儲能UPS飛輪UPS

2024-11-08 09:34:54

2024-05-06 10:11:51

2015-11-23 17:34:33

秒借

2024-11-01 12:10:57

2019-09-27 17:24:26

數據庫優化sql

2024-11-08 15:08:17

點贊
收藏

51CTO技術棧公眾號

亚洲免费毛片网站| 九九**精品视频免费播放| 亚洲国产精品久久| 久久久久狠狠高潮亚洲精品| 在线免费av电影| 成人免费看黄yyy456| 日本精品久久中文字幕佐佐木| 国产精品扒开腿做爽爽| 国产高清精品二区| 懂色av影视一区二区三区| 一区二区三区久久网| 国产 欧美 自拍| 美腿丝袜亚洲一区| 97视频色精品| 午夜三级在线观看| 日韩精选在线| 日韩一区二区电影在线| 日韩免费高清在线| 国内在线视频| 日韩一区中文字幕| 久久综合久久久| 午夜精品久久久久久久99| 老色鬼久久亚洲一区二区| 美女av一区二区| 韩国三级hd中文字幕| 大香伊人久久精品一区二区| 欧美日韩五月天| 国产成人精品视频免费看| 黄色在线免费网站| 国产日韩欧美高清| 精品在线视频一区二区三区| 国产免费不卡av| 免费欧美在线视频| 国产成人avxxxxx在线看| 国产大片aaa| 欧美91视频| 久久视频免费观看| 日本伦理一区二区三区| 自拍亚洲一区| 亚洲电影免费观看高清| 中文字幕avav| 亚洲一区二区av| 欧美日韩一区二区在线视频| 国产成人综合一区| 欧美一级大片| 日本国产一区二区| 日日摸日日碰夜夜爽av| 欧亚av在线| 婷婷亚洲久悠悠色悠在线播放| 国产亚洲精品久久久久久久| 精品黄色免费中文电影在线播放| 国产精品国产三级国产普通话99 | 亚洲中文字幕无码中文字| 色帝国亚洲欧美在线| 亚洲欧美激情小说另类| 2021狠狠干| 一区二区三区伦理| 亚洲国产一区视频| 99在线观看视频免费| 操喷在线视频| 午夜精品123| 国产肥臀一区二区福利视频| 一区二区电影免费观看| 色婷婷av一区二区三区大白胸| 免费黄色日本网站| 韩国精品主播一区二区在线观看| 色婷婷综合中文久久一本| 热久久精品免费视频| 婷婷激情一区| 欧美日本视频在线| 日本少妇激三级做爰在线| 欧美第一在线视频| 精品成人一区二区三区| 免费无码一区二区三区| 蜜桃tv一区二区三区| 在线不卡国产精品| 2025国产精品自拍| 亚洲精品123区| 日本精品中文字幕| 一本色道久久综合无码人妻| 国产一区在线看| 国产精华一区二区三区| 神马久久高清| 国产精品久久精品日日| 国产精品www在线观看| 热色播在线视频| 欧美三级电影网站| 国产精品19p| 亚洲丝袜啪啪| 久久福利网址导航| 国产精品美女久久久久av爽| 日本欧美在线观看| 超碰97网站| 麻豆av电影在线观看| 国产精品久久久久桃色tv| 国产精品久久久久久久乖乖| 欧美电影网址| 日韩欧美中文字幕一区| 国产ts丝袜人妖系列视频| 97久久视频| 69av在线视频| 99国产精品欲| 久久精品人人做人人爽97| 艳母动漫在线观看| 成人午夜视屏| 精品国精品国产| 农村老熟妇乱子伦视频| 在线 亚洲欧美在线综合一区| 国产高清在线不卡| 亚洲欧美激情国产综合久久久| xnxx国产精品| www.18av.com| 精品久久久网| 亚洲全黄一级网站| 国产在线拍揄自揄拍| 美国三级日本三级久久99| 国产精品免费在线| 国内精品不卡| 欧美午夜电影网| 182在线视频| 欧美日韩一区二区高清| 国产精品小说在线| 撸视在线观看免费视频| 亚洲va欧美va国产va天堂影院| 国产欧美激情视频| 国产一区二区三区探花| 午夜精品在线视频| www.看毛片| 亚洲欧美日韩在线播放| 嫩草影院国产精品| 国产午夜一区| 欧美影院久久久| 手机av在线免费观看| 亚洲男人的天堂网| 久久久久久久高清| 天天射综合网视频| 国产欧美日韩视频| 91xxx在线观看| 欧美色图12p| 亚洲最大成人综合网| 亚洲一区二区毛片| 精品国产一区二区三| 99在线视频影院| 欧美xfplay| 动漫精品一区一码二码三码四码| 国产精品夜夜嗨| 国产精品一二三在线观看| 国产美女精品视频免费播放软件| 日韩中文字幕免费看| 中文字幕在线观看欧美| 亚洲欧洲日产国产综合网| 特级丰满少妇一级| 天天精品视频| 91免费在线观看网站| 深夜国产在线播放| 精品欧美一区二区三区精品久久| 丰满少妇高潮久久三区| 高清日韩电视剧大全免费| a级免费在线观看| 久久精品国产亚洲blacked| 久久久久久12| 桃花色综合影院| 在线观看日韩电影| 91动漫免费网站| 国产一区二区三区不卡在线观看| 日韩久久久久久久久久久久| 99国产精品免费网站| 久久久爽爽爽美女图片| 日本免费一区二区三区最新| 一本久久精品一区二区| 日韩不卡av在线| 久久99久久99| 久久精品xxx| 久久99久久人婷婷精品综合| 国产精品免费视频xxxx| a级网站在线播放| 亚洲成人中文字幕| 无码人妻丰满熟妇区bbbbxxxx| 久久午夜羞羞影院免费观看| 三上悠亚av一区二区三区| 外国成人免费视频| 精品国产乱码久久久久| 性高爱久久久久久久久| 久久精品国产清自在天天线| 亚洲精品国产一区二| 色综合视频在线观看| 久久国产高清视频| zzijzzij亚洲日本少妇熟睡| 欧美日韩第二页| 欧美一区影院| 欧美极品一区二区| 精品999日本久久久影院| 91禁外国网站| 免费a在线看| 亚洲精品一区二区三区婷婷月 | 超免费在线视频| 国产一区二区三区直播精品电影| 国产美女自慰在线观看| 欧美色播在线播放| 91高清免费观看| 91免费观看视频| 亚洲精品国产久| 久久一综合视频| 美女黄色免费看| 日韩国产一区二区| 九色一区二区| 午夜视频一区二区在线观看| 国产成人综合亚洲| segui88久久综合| 久久精品视频99| 内衣办公室在线| 亚洲精品国产成人| 国产精品人妻一区二区三区| 一本大道av伊人久久综合| 久久久久久激情| 国产精品毛片a∨一区二区三区| 大尺度在线观看| 精彩视频一区二区| 狠狠热免费视频| 日韩视频久久| 男人的天堂avav| 一区二区三区午夜探花| 无遮挡亚洲一区| 亚洲+变态+欧美+另类+精品| 999国产视频| 国产一区二区三区| 国产精品黄色av| 一区二区三区电影大全| 午夜精品一区二区三区av| 国产探花在线观看| 精品国产欧美一区二区五十路 | 欧美人成在线视频| 欧美r级在线| 在线a欧美视频| 国产福利小视频在线观看| 日韩av在线精品| 好吊色一区二区| 欧美xxx久久| av手机免费看| 日韩欧美精品在线| 国产情侣激情自拍| 欧美一级片在线| 国产视频第一页| 欧美一级欧美一级在线播放| 国内老熟妇对白hdxxxx| 欧美一区二区在线看| 国产乱码精品一区二区三区精东| 欧美少妇一区二区| 中文字幕在线网址| 欧美日韩你懂得| 亚洲视频久久久| 欧美一区二视频| www久久久com| 亚洲高清一二三区| 无码国产精品一区二区免费16| 亚洲成色777777在线观看影院 | 亚洲视频视频在线| 成人午夜在线观看视频| 中文亚洲视频在线| 麻豆视频在线免费观看| 久久夜精品va视频免费观看| 成人日韩欧美| 国产69精品久久久久9| 51漫画成人app入口| 欧美亚洲激情在线| 亚洲一区二区三区四区| 成人淫片在线看| 色播一区二区| 久久av一区二区三区漫画| 九九免费精品视频在线观看| 日本最新一区二区三区视频观看| 成人中文视频| 99热这里只有精品免费| 99在线精品免费视频九九视| av观看免费在线| 精品一区二区在线免费观看| 亚洲最大视频网| 久久久影视传媒| 成人三级视频在线观看| 亚洲综合在线免费观看| 中文字幕超碰在线| 精品污污网站免费看| 精品国产亚洲av麻豆| 亚洲精品美女在线| 9色在线视频| 欧美激情中文字幕在线| 中文字幕av一区二区三区佐山爱| 成人中文字幕在线观看| 欧美电影在线观看完整版| 日本最新一区二区三区视频观看| 亚洲区综合中文字幕日日| 自拍日韩亚洲一区在线| 免费不卡在线观看| 制服丝袜在线第一页| 欧美经典一区二区| 日韩精品视频免费看| 欧美日韩三级一区二区| 欧美综合视频在线| www.xxxx欧美| 成人免费直播| 高清国语自产拍免费一区二区三区| 欧美禁忌电影| 日本五级黄色片| 麻豆精品在线播放| 国产黄色网址在线观看| 亚洲欧美成人一区二区三区| 不卡av电影在线| 亚洲第一精品自拍| 日本中文字幕在线观看| 欧美一区视频在线| 加勒比久久高清| 国产精品亚洲天堂| 日本欧洲一区二区| 欧美成人午夜精品免费| 一区二区高清视频在线观看| 中文字幕人妻精品一区| 日韩电影第一页| 丰满的护士2在线观看高清| 国产欧美日韩中文| 欧美伦理在线视频| 久久久久久久久久福利| 懂色中文一区二区在线播放| 熟女少妇a性色生活片毛片| 欧美午夜丰满在线18影院| 欧美一级特黄aaaaaa| 久久成人这里只有精品| 亚洲福利影视| 亚洲一区二区三区精品视频| 久久看片网站| 欧美老熟妇乱大交xxxxx | 免费观看美女裸体网站| 国产成人亚洲精品狼色在线| 国产美女久久久久久| 欧美男男青年gay1069videost| 成人精品一区二区三区免费| 2020久久国产精品| 天天躁日日躁狠狠躁欧美巨大小说| 超碰成人免费在线| 粉嫩av亚洲一区二区图片| 欧美极品aaaaabbbbb| 欧美一区二区三区性视频| 麻豆传媒在线免费看| 成人国产精品av| 国产精品久久观看| 亚欧精品在线视频| 亚洲精品一二三| 亚洲精品一区二区三区新线路| 欧美高清视频在线观看| 91欧美日韩在线| 国产一线二线三线女| 不卡的av电影| 国产农村妇女aaaaa视频| 亚洲开心激情网| 欧美不卡高清一区二区三区| 五月天综合网| 韩国精品在线观看| 在线免费观看亚洲视频| 日韩欧美亚洲一区二区| 乱插在线www| 久久精品国产美女| 久久久久网站| 一级免费黄色录像| 欧美成人精品3d动漫h| zzzwww在线看片免费| 欧美日韩精品久久久免费观看| 日本欧洲一区二区| 小泽玛利亚一区二区免费| 精品欧美黑人一区二区三区| 激情国产在线| 视频在线观看成人| 激情综合网av| 99免费在线观看| 国产一区二区三区久久精品| 91麻豆精品| 国产女主播自拍| 国产丝袜美腿一区二区三区| 91国偷自产中文字幕久久| 欧美大片免费观看| 亚洲免费成人av在线| 亚洲美女爱爱视频| 亚洲高清免费观看高清完整版在线观看 | 久久综合久久久| 久久精品国产色蜜蜜麻豆| 久久久91视频| 亚洲人a成www在线影院| 日韩精品亚洲专区在线观看| 久久网站免费视频| 亚洲免费电影在线| 欧美18xxxxx| 5566中文字幕一区二区| 久久久成人网| 久久精品99国产精| 在线视频免费一区二区| 91精品国产自产精品男人的天堂| aaaaaa亚洲| 亚洲国产日韩一级| 欧美三级黄网| 免费成人深夜夜行视频| 国产福利一区二区三区视频在线| 日日噜噜噜噜人人爽亚洲精品|