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

Java代碼優化過程的實例介紹

開發 后端
通過筆者經歷的一個項目實例,本文介紹了 Java 代碼優化的過程,總結了優化 Java 程序的一些最佳實踐,分析了進行優化的方法,并解釋了性能提升的原因。從多個角度分析導致性能低的原因,并逐個進行優化,最終使得程序的性能得到極大提升,代碼的可讀性、可擴展性更強。

衡量程序的標準

衡量一個程序是否優質,可以從多個角度進行分析。其中,最常見的衡量標準是程序的時間復雜度、空間復雜度,以及代碼的可讀性、可擴展性。針對程序的時間復雜度和空間復雜度,想要優化程序代碼,需要對數據結構與算法有深入的理解,并且熟悉計算機系統的基本概念和原理;而針對代碼的可讀性和可擴展性,想要優化程序代碼,需要深入理解軟件架構設計,熟知并會應用合適的設計模式。

首先,如今計算機系統的存儲空間已經足夠大了,達到了 TB 級別,因此相比于空間復雜度,時間復雜度是程序員首要考慮的因素。為了追求高性能,在某些頻繁操作執行時,甚至可以考慮用空間換取時間。其次,由于受到處理器制造工藝的物理限制、成本限制,CPU 主頻的增長遇到了瓶頸,摩爾定律已漸漸失效,每隔 18 個月 CPU 主頻即翻倍的時代已經過去了,程序員的編程方式發生了徹底的改變。在目前這個多核多處理器的時代,涌現了原生支持多線程的語言(如 Java)以及分布式并行計算框架(如 Hadoop)。為了使程序充分地利用多核 CPU,簡單地實現一個單線程的程序是遠遠不夠的,程序員需要能夠編寫出并發或者并行的多線程程序。***,大型軟件系統的代碼行數達到了***,如果沒有一個設計良好的軟件架構,想在已有代碼的基礎上進行開發,開發代價和維護成本是無法想象的。一個設計良好的軟件應該具有可讀性和可擴展性,遵循“開閉原則”、“依賴倒置原則”、“面向接口編程”等。

項目介紹

本文將介紹筆者經歷的一個項目中的一部分,通過這個實例剖析代碼優化的過程。下面簡要地介紹該系統的相關部分。

該系統的開發語言為 Java,部署在共擁有 4 核 CPU 的 Linux 服務器上,相關部分主要有以下操作:通過某外部系統 D 提供的 REST API 獲取信息,從中提取出有效的信息,并通過 JDBC 存儲到某數據庫系統 S 中,供系統其他部分使用,上述操作的執行頻率為每天一次,一般在午夜當系統空閑時定時執行。為了實現高可用性(High Availability),外部系統 D 部署在兩臺服務器上,因此需要分別從這兩臺服務器上獲取信息并將信息插入數據庫中,有效信息的條數達到了上千條,數據庫插入操作次數則為有效信息條數的兩倍。

圖 1. 系統體系結構圖

圖 1. 系統體系結構圖

為了快速地實現預期效果,在最初的實現中優先考慮了功能的實現,而未考慮系統性能和代碼可讀性等。系統大致有以下的實現:(1)REST API 獲取信息、數據庫操作可能拋出的異常信息都被記錄到日志文件中,作為調試用;(2)共有 5 次數據庫連接操作,包括***次清空數據庫表,針對兩個外部系統 D 各有兩次數據庫插入操作,這 5 個連接都是獨立的,用完之后即釋放;(3)所有的數據庫插入語句都是使用 java.sql.Statement 類生成的;(4)所有的數據庫插入語句,都是單條執行的,即生成一條執行一條;(5)整個過程都是在單個線程中執行的,包括數據庫表清空操作,數據庫插入操作,釋放數據庫連接;(6)數據庫插入操作的 JDBC 代碼散布在代碼中。雖然這個版本的系統可以正常運行,達到了預期的效果,但是效率很低,從通過 REST API 獲取信息,到解析并提取有效信息,再到數據庫插入操作,總共耗時 100 秒左右。而預期的時間應該在一分鐘以內,這顯然是不符合要求的。

代碼優化過程

筆者開始分析整個過程有哪些耗時操作,以及如何提升效率,縮短程序執行的時間。通過 REST API 獲取信息,因為是使用外部系統提供的 API,所以無法在此處提升效率;取得信息之后解析出有效部分,因為是對特定格式的信息進行解析,所以也無效率提升的空間。所以,效率可以大幅度提升的空間在數據庫操作部分以及程序控制部分。下面,分條敘述對耗時操作的改進方法。

針對日志記錄的優化

關閉日志記錄,或者更改日志輸出級別。因為從兩臺服務器的外部系統 D 上獲取到的信息是相同的,所以數據庫插入操作會拋出異常,異常信息類似于“Attempt to insert duplicate record”,這樣的異常信息跟有效信息的條數相等,有上千條。這種情況是能預料到的,所以可以考慮關閉日志記錄,或者不關閉日志記錄而是更改日志輸出級別,只記錄嚴重級別(severe level)的錯誤信息,并將此類操作的日志級別調整為警告級別(warning level),這樣就不會記錄以上異常信息了。本項目使用的是 Java 自帶的日志記錄類,以下配置文件將日志輸出級別設置為嚴重級別。

清單 1. log.properties 設置日志輸出級別的片段

 
  1. # default file output is in user ’ s home directory.  
  2. # levels can be: SEVERE, WARNING, INFO, FINE, FINER, FINEST  
  3. java.util.logging.ConsoleHandler.level=SEVERE  
  4. javajava.util.logging.FileHandler.formatter=java.util.logging.SimpleFormatter  
  5. java.util.logging.FileHandler.append=true  

通過上述的優化之后,性能有了大幅度的提升,從原來的 100 秒左右降到了 50 秒左右。為什么僅僅不記錄日志就能有如此大幅度的性能提升呢?查閱資料,發現已經有人做了相關的研究與實驗。經常聽到 Java 程序比 C/C++ 程序慢的言論,但是運行速度慢的真正原因是什么,估計很多人并不清楚。對于 CPU 密集型的程序(即程序中包含大量計算),Java 程序可以達到 C/C++ 程序同等級別的速度,但是對于 I/O 密集型的程序(即程序中包含大量 I/O 操作),Java 程序的速度就遠遠慢于 C/C++ 程序了,很大程度上是因為 C/C++ 程序能直接訪問底層的存儲設備。因此,不記錄日志而得到大幅度性能提升的原因是,Java 程序的 I/O 操作較慢,是一個很耗時的操作。

針對數據庫連接的優化

共享數據庫連接。共有 5 次數據庫連接操作,每次都需重新建立數據庫連接,數據庫插入操作完成之后又立即釋放了,數據庫連接沒有被復用。為了做到共享數據庫連接,可以通過單例模式(Singleton Pattern)獲得一個相同的數據庫連接,每次數據庫連接操作都共享這個數據庫連接。這里沒有使用數據庫連接池(Database Connection Pool)是因為在程序只有少量的數據庫連接操作,只有在大量并發數據庫連接的時候才需要連接池。#p#

清單 2. 共享數據庫連接的代碼片段

  1. public class JdbcUtil {  
  2.    private static Connection con;  
  3.    // 從配置文件讀取連接數據庫的信息 
  4.    private static String driverClassName;  
  5.    private static String url;  
  6.    private static String username;  
  7.    private static String password;  
  8.    private static String currentSchema;  
  9.    private static Properties properties = new Properties();  
  10.  
  11.  static {  
  12. // driverClassName, url, username, password, currentSchema 等從配置文件讀取,代碼略去 
  13.      try {  
  14.         Class.forName(driverClassName);  
  15.        } catch (ClassNotFoundException e) {  
  16.            e.printStackTrace();  
  17.        }  
  18.        properties.setProperty("user", username);  
  19.        properties.setProperty("password", password);  
  20.        properties.setProperty("currentSchema", currentSchema);  
  21.        try {  
  22.            con = DriverManager.getConnection(url, properties);  
  23.        } catch (SQLException e) {  
  24.            e.printStackTrace();  
  25.        }  
  26.    }  
  27.    private JdbcUtil() {}  
  28. // 獲得一個單例的、共享的數據庫連接 
  29. public static Connection getConnection() {  
  30.        return con;  
  31.    }  
  32.    public static void close() throws SQLException {  
  33.        if (con != null)  
  34.            con.close();  
  35. }  
  36. }  

通過上述的優化之后,性能有了小幅度的提升,從 50 秒左右降到了 40 秒左右。共享數據庫連接而得到的性能提升的原因是,數據庫連接是一個耗時耗資源的操作,需要同遠程計算機進行網絡通信,建立 TCP 連接,還需要維護連接狀態表,建立數據緩沖區。如果共享數據庫連接,則只需要進行一次數據庫連接操作,省去了多次重新建立數據庫連接的時間。

針對插入數據庫記錄的優化 1

使用預編譯 SQL。具體做法是使用 java.sql.PreparedStatement 代替 java.sql.Statement 生成 SQL 語句。PreparedStatement 使得數據庫預先編譯好 SQL 語句,可以傳入參數。而 Statement 生成的 SQL 語句在每次提交時,數據庫都需進行編譯。在執行大量類似的 SQL 語句時,可以使用 PreparedStatement 提高執行效率。使用 PreparedStatement 的另一個好處是不需要拼接 SQL 語句,代碼的可讀性更強。通過上述的優化之后,性能有了小幅度的提升,從 40 秒左右降到了 30~35 秒左右。

清單 3. 使用 Statement 的代碼片段

 
  1. // 需要拼接 SQL 語句,執行效率不高,代碼可讀性不強 
  2. StringBuilder sql = new StringBuilder();  
  3. sql.append("insert into table1(column1,column2) values('");  
  4. sql.append(column1Value);  
  5. sql.append("','");  
  6. sql.append(column2Value);  
  7. sql.append("');");  
  8.  
  9. Statement st;  
  10. try {  
  11.     st = con.createStatement();  
  12.     st.executeUpdate(sql.toString());  
  13. } catch (SQLException e) {  
  14.     e.printStackTrace();  
  15. }  

清單 4. 使用 PreparedStatement 的代碼片段

 
  1. // 預編譯 SQL 語句,執行效率高,可讀性強 
  2. String sql = “insert into table1(column1,column2) values(?,?)”;  
  3. PreparedStatement pst = con.prepareStatement(sql);  
  4. pst.setString(1,column1Value);  
  5. pst.setString(2,column2Value);  
  6. pst.execute();  

針對插入數據庫記錄的優化 2

使用 SQL 批處理。通過 java.sql.PreparedStatement 的 addBatch 方法將 SQL 語句加入到批處理,這樣在調用 execute 方法時,就會一次性地執行 SQL 批處理,而不是逐條執行。通過上述的優化之后,性能有了小幅度的提升,從 30~35 秒左右降到了 30 秒左右。

針對多線程的優化

使用多線程實現并發 / 并行。清空數據庫表的操作、把從 2 個外部系統 D 取得的數據插入數據庫記錄的操作,是相互獨立的任務,可以給每個任務分配一個線程執行。清空數據庫表的操作應該先于數據庫插入操作完成,可以通過 java.lang.Thread 類的 join 方法控制線程執行的先后次序。在單核 CPU 時代,操作系統中某一時刻只有一個線程在運行,通過進程 / 線程調度,給每個線程分配一小段執行的時間片,可以實現多個進程 / 線程的并發(concurrent)執行。而在目前的多核多處理器背景下,操作系統中同一時刻可以有多個線程并行(parallel)執行,大大地提高了計算速度。

清單 5. 使用多線程的代碼片段

  1. Thread t0 = new Thread(new ClearTableTask());  
  2. Thread t1 = new Thread(new StoreServersTask(ADDRESS1));  
  3. Thread t2 = new Thread(new StoreServersTask(ADDRESS2));  
  4.  
  5. try {  
  6.     t0.start();  
  7.     // 執行完清空操作后,再進行后續操作 
  8.     t0.join();  
  9.     t1.start();  
  10.     t2.start();  
  11.     t1.join();  
  12.     t2.join();  
  13. } catch (InterruptedException e) {  
  14.     e.printStackTrace();  
  15. }  
  16.  
  17. // 斷開數據庫連接 
  18. try {  
  19.     JdbcUtil.close();  
  20. } catch (SQLException e) {  
  21.     e.printStackTrace();  
  22. }  

通過上述的優化之后,性能有了大幅度的提升,從 30 秒左右降到了 15 秒以下,10~15 秒之間。使用多線程而得到的性能提升的原因是,系統部署所在的服務器是多核多處理器的,使用多線程,給每個任務分配一個線程執行,可以充分地利用 CPU 計算資源。

筆者試著給每個任務分配兩個線程執行,希望能使程序運行得更快,但是事與愿違,此時程序運行的時間反而比每個任務分配一個線程執行的慢,大約 20 秒。筆者推測,這是因為線程較多(相對于 CPU 的內核數),使得 CPU 忙于線程的上下文切換,過多的線程上下文切換使得程序的性能反而不如之前。因此,要根據實際的硬件環境,給任務分配適量的線程執行。

針對設計模式的優化

使用 DAO 模式抽象出數據訪問層。原來的代碼中混雜著 JDBC 操作數據庫的代碼,代碼結構顯得十分凌亂。使用 DAO 模式(Data Access Object Pattern)可以抽象出數據訪問層,這樣使得程序可以獨立于不同的數據庫,即便訪問數據庫的代碼發生了改變,上層調用數據訪問的代碼無需改變。并且程序員可以擺脫單調繁瑣的數據庫代碼的編寫,專注于業務邏輯層面的代碼的開發。通過上述的優化之后,性能并未有提升,但是代碼的可讀性、可擴展性大大地提高了。

圖 2. DAO 模式的層次結構

圖 2. DAO 模式的層次結構

清單 6. 使用 DAO 模式的代碼片段

  1. // DeviceDAO.java,定義了 DAO 抽象,上層的業務邏輯代碼引用該接口,面向接口編程 
  2. public interface DeviceDAO {  
  3.    public void add(Device device);  
  4. }  
  5.  
  6. // DeviceDAOImpl.java,DAO 實現,具體的 SQL 語句和數據庫操作由該類實現 
  7. public class DeviceDAOImpl implements DeviceDAO {  
  8.    private Connection con;  
  9.    public DeviceDAOImpl() {  
  10.        // 獲得數據庫連接,代碼略去 
  11.    }  
  12. @Override  
  13. public void add(Device device) {  
  14.        // 使用 PreparedStatement 進行數據庫插入記錄操作,代碼略去 
  15.    }  
  16. }  

回顧以上代碼優化過程:關閉日志記錄、共享數據庫連接、使用預編譯 SQL、使用 SQL 批處理、使用多線程實現并發 / 并行、使用 DAO 模式抽象出數據訪問層,程序運行時間從最初的 100 秒左右降低到 15 秒以下,在性能上得到了很大的提升,同時也具有了更好的可讀性和可擴展性。

結束語

通過該項目實例,筆者深深地感到,想要寫出一個性能優化、可讀性可擴展性強的程序,需要對計算機系統的基本概念、原理,編程語言的特性,軟件系統架構設計都有較深入的理解。“紙上得來終覺淺,絕知此事要躬行”,想要將這些基本理論、編程技巧融會貫通,還需要不斷地實踐,并總結心得體會。

原文鏈接:http://www.ibm.com/developerworks/cn/java/j-lo-codeoptimize/

責任編輯:陳四芳 來源: developerWorks中國
相關推薦

2010-04-07 14:01:40

Oracle存儲過程

2010-04-16 13:16:11

OracleJavaP

2010-03-31 10:22:25

Oracle10g優化

2013-09-03 09:35:10

2010-04-23 11:15:43

Oracle創建

2011-08-22 12:01:36

SQL Server代碼優化

2011-08-25 11:36:50

PreparedStaJDBC存儲過程調用

2010-07-27 16:14:50

2009-12-28 11:08:34

ADO 實例

2011-07-21 14:15:08

java

2011-07-21 13:51:38

java

2010-11-19 09:48:48

ORACLE創建實例

2009-07-07 09:51:49

Servlet實例

2011-07-22 13:47:23

存儲過程

2010-11-10 15:16:14

Sql Server分

2011-08-10 17:00:45

DB2數據庫存儲過程

2010-11-16 14:30:32

Oracle存儲過程

2010-03-18 14:27:53

Java Thread

2010-04-07 12:08:28

Oracle存儲過程

2011-12-15 10:10:33

Javanio
點贊
收藏

51CTO技術棧公眾號

精品久久久噜噜噜噜久久图片| 99国产精品久久一区二区三区| 国产一区二区三区在线观看精品| 久久在线观看视频| 91丨porny丨九色| 国产黄色大片在线观看| 成人国产精品免费观看动漫| 成人永久免费视频| 欧美激情国产精品| 人妻丰满熟妇aⅴ无码| 日韩av黄色| 91亚洲天堂| 激情综合久久| 国产一区二区日韩| 久久精品91久久久久久再现| 污色网站在线观看| 超碰在线中文字幕| 国产日本欧洲亚洲| 俄罗斯精品一区二区三区| 国产又粗又爽视频| 综合一区二区三区| 亚洲精品天天看| 欧美视频国产视频| 日韩一区二区三区在线免费观看| 一区二区三区在线免费播放| 日韩欧美亚洲日产国| 国产国语亲子伦亲子| 奇米在线7777在线精品| 97久久精品在线| 久久久久久久久久综合| 日韩在线观看| 亚洲天堂日韩电影| 无码人妻精品一区二区三区温州| 精品视频一区二区三区| 欧美日韩免费在线视频| 成人综合视频在线| 国产蜜臀一区二区打屁股调教| 1区2区3区欧美| 日韩电影在线播放| 免费毛片在线| 不卡的av中国片| 成人影片在线播放| 国产欧美第一页| 久久99久久99精品免视看婷婷 | 欧美亚州韩日在线看免费版国语版| 免费在线看黄色片| 日本小视频在线免费观看| 九九热视频在线观看| 日韩精品一二区| 欧洲亚洲在线视频| 97人人澡人人爽人人模亚洲| 国内精品久久久久久久影视麻豆| 欧美wwwxxxx| 91插插插插插插| 国产精品伦理久久久久久| 亚洲免费一在线| 大黑人交xxx极品hd| 欧美美女黄色| 日韩精品亚洲元码| www.色多多| 影视先锋久久| 一区二区三区无码高清视频| 欧美激情 一区| 日韩三级在线| 久久综合国产精品台湾中文娱乐网| 亚洲国产精品一区二区久久hs| 99久久夜色精品国产亚洲96| 精品国产一区二区三区久久狼5月 精品国产一区二区三区久久久狼 精品国产一区二区三区久久久 | 国产精品99免费看| 欧美高清激情视频| 天海翼一区二区| 噜噜噜91成人网| 国产精品免费久久久久久| 中文字幕在线观看1| 久久99国产精品免费网站| 成人性生交大片免费看小说| 精品国精品国产自在久不卡| 成人免费黄色在线| 欧美高清视频一区| 在线激情网站| 亚洲一区二区三区国产| 日本免费黄视频| 男人亚洲天堂| 精品国产青草久久久久福利| 亚洲精品乱码久久久久久不卡| 精品福利久久久| 欧美美女15p| 久久久精品福利| 免费观看在线综合| 成人在线观看av| 你懂的在线播放| 亚洲视频资源在线| 中国丰满熟妇xxxx性| 向日葵视频成人app网址| 欧美一区二区三区精品| 国产在线观看无码免费视频| 成人免费在线播放| 欧美高清在线视频观看不卡| 无码人妻av免费一区二区三区 | 欧美日韩中文精品| 一区二区三区四区影院| 国产乱码精品一区二区三区四区 | 青青草国产精品| 国产一二三区在线观看| 色综合色狠狠综合色| 亚洲高清视频免费| 国内亚洲精品| 国内精品久久久久久中文字幕| 青娱乐在线免费视频| 粉嫩绯色av一区二区在线观看| 天堂va久久久噜噜噜久久va| av免费不卡| 91麻豆精品久久久久蜜臀| 亚洲专区区免费| 欧美精品综合| 国产伊人精品在线| 欧美欧美欧美| 午夜一区二区三区视频| 国产高清av片| 欧美精品一区二区三区精品| 国内精品久久久久影院优| 亚洲自拍偷拍另类| 久久久亚洲高清| 国产高清av在线播放| av成人在线网站| 中文字幕日韩专区| 五月天综合激情| 粉嫩一区二区三区在线看| 中文字幕一区二区三区四区五区| 欧美天堂视频| 亚洲精品福利在线观看| 久久网一区二区| 国产精品2024| 国产香蕉一区二区三区| 在线视频成人| 日韩一区二区三区xxxx| 性高潮视频在线观看| 91啦中文在线观看| 高清欧美精品xxxxx| 日韩精品一级| 美女999久久久精品视频 | 欧美一区二区三区在线观看 | 亚洲久本草在线中文字幕| 久久国产精品国产精品| 精品国产一区二区三区噜噜噜 | 欧美日韩成人在线播放| 国产裸体无遮挡| 最新中文字幕一区二区三区 | 欧美精品影院| 久久五月情影视| 99这里有精品视频| 亚洲麻豆国产自偷在线| 永久免费看片在线观看| 欧美粗暴jizz性欧美20| 亚洲综合日韩在线| 特级毛片在线| 欧美精品一区二区三区蜜臀| 天天爽天天爽天天爽| 免播放器亚洲一区| 一区二区三区av| 日韩毛片一区| 色哟哟亚洲精品一区二区| 一级做a爰片久久毛片16| 中文字幕一区日韩精品欧美| 亚洲妇熟xx妇色黄蜜桃| 午夜精品久久99蜜桃的功能介绍| 亚洲va久久久噜噜噜| 中文字幕有码在线视频| 精品国产污污免费网站入口 | 视频在线观看成人| 人人精品久久| 欧美激情videos| 香蕉视频成人在线| 欧洲精品一区二区| 四虎精品免费视频| www.视频一区| 91香蕉视频污版| 亚洲一区二区三区无吗| 国产视频在线观看一区| 日韩大尺度黄色| www.久久久久久.com| 成人爽a毛片一区二区| 精品久久中文字幕| 亚洲AV成人无码网站天堂久久| 国产一区二区在线电影| 国产老熟妇精品观看| 欧美在线观看视频一区| 99久久久久国产精品免费| 蜜臀久久精品| 日韩在线观看免费av| 亚洲精品国产精| 色久优优欧美色久优优| 欧美激情图片小说| 91视频免费看| 99999精品| 美日韩精品视频| 日韩人妻一区二区三区蜜桃视频| 日韩av不卡一区| 91免费国产网站| 欧美一区久久久| 欧美激情a在线| 在线免费看a| 亚洲精品久久在线| 国产精品嫩草影院桃色| 大桥未久av一区二区三区| 天天操夜夜操av| 91麻豆国产精品久久| 免费欧美一级片| 蜜臀久久久久久久| 免费黄色福利视频| 欧美福利电影在线观看| 亚洲精品成人a8198a| 欧美福利在线播放网址导航| 92看片淫黄大片欧美看国产片 | 国产日韩1区| 强开小嫩苞一区二区三区网站| 精品在线99| 国产九色精品| 日韩欧美一级| 成人欧美在线观看| 成人午夜sm精品久久久久久久| 午夜精品一区二区三区在线视频| 在线观看小视频| 色妞在线综合亚洲欧美| 国产中文字幕在线播放| 亚洲精美色品网站| 精品人妻无码一区二区 | 亚洲av无码一区二区乱子伦| 欧美性生活久久| 成人在线免费看视频| 亚洲午夜av在线| 久草福利资源在线观看| 亚洲欧美区自拍先锋| 亚洲人做受高潮| 国产精品视频在线看| 欧美黄色一级生活片| 久久网站热最新地址| v天堂中文在线| 成人精品一区二区三区中文字幕| 欧美熟妇另类久久久久久多毛| 国产麻豆成人精品| 91丝袜超薄交口足| 极品少妇xxxx精品少妇| 91亚洲免费视频| 精品一区二区免费看| 久久婷五月综合| 久久精品国产第一区二区三区| 中文字幕有码av| 捆绑紧缚一区二区三区视频| 天天影视色综合| 韩国视频一区二区| 手机在线观看日韩av| 国产精品18久久久久久久久久久久| 国产精品999.| 成人免费va视频| 免费中文字幕av| 久久综合狠狠综合| 国产精久久一区二区三区| 欧美国产乱子伦| 美国一级片在线观看| 中文字幕视频一区二区三区久| 四虎永久免费地址| 精品国模在线视频| 极品粉嫩国产18尤物| 综合视频在线| 青青草国产免费| 国产一区二区高清| 国产免费人做人爱午夜视频| 日韩国产高清在线| 日韩av.com| 国产91对白在线观看九色| 国产一级免费片| 久久婷婷成人综合色| 大胸美女被爆操| 亚洲免费在线观看| 国产午夜视频在线播放| 欧美三级免费观看| 伊人成人在线观看| 日韩精品最新网址| 亚洲色图另类小说| 自拍偷拍亚洲区| 手机av免费在线| 91高潮在线观看| 欧美黄色网络| 国产乱码精品一区二区三区日韩精品 | 中文字幕一区二区av| 人人妻人人做人人爽| 日韩精品视频网| 亚洲欧美日韩中文字幕在线观看| 91丨porny丨国产入口| 免费黄色国产视频| 亚洲高清久久久| 中文在线观看av| 亚洲福利在线观看| av网站无病毒在线| 97国产在线观看| 爱情电影网av一区二区| 精品综合久久| 中文精品电影| 天天爽天天爽夜夜爽| av中文字幕亚洲| 日韩精品123区| 91福利精品第一导航| 亚洲精品国产片| 日韩有码视频在线| 欧美电影免费观看| 国产精品日韩一区二区免费视频| 奇米影视亚洲| 九九九九免费视频| 国产成人综合自拍| 极品人妻videosss人妻| 亚洲成人激情av| 99精品在线看| 自拍偷拍亚洲一区| 夜鲁夜鲁夜鲁视频在线播放| av一区二区三区免费| 久久日文中文字幕乱码| 国产偷人视频免费| 91在线视频免费观看| 久久久久久天堂| 91精品国产91久久综合桃花| 成年人在线看| 日本在线观看天堂男亚洲| 9l亚洲国产成人精品一区二三| 伊人色综合影院| 日韩电影在线观看网站| 亚洲色图14p| 亚洲成人高清在线| 午夜精品久久久久久久96蜜桃 | 我要看一级黄色录像| 欧美综合色免费| 男女污视频在线观看| 77777少妇光屁股久久一区| 一区三区自拍| 真实国产乱子伦对白视频| 国产乱码精品一区二区三区忘忧草 | 欧美精品在线视频| 麻豆影院在线观看| 国产中文字幕91| 天天插综合网| 男女视频在线观看网站| 亚洲欧美日韩中文字幕一区二区三区 | 日韩欧美第一区| 人人超在线公开视频| 99中文字幕| 精品成人国产| 日韩成人av一区二区| 日韩欧美亚洲综合| 国产中文在线| 国产精品专区h在线观看| 欧美xxav| 久久久久久无码精品人妻一区二区| 一区二区三区四区不卡在线| 亚洲AV无码一区二区三区性 | 蜜臀在线免费观看| 国产成人av电影在线观看| 久久精品视频日本| 日韩电影中文字幕在线| 在线观看精品| 尤物一区二区三区| 国产一区二区不卡| 国产性猛交普通话对白| 日韩成人在线免费观看| 成人日韩在线观看| 日本女人高潮视频| 不卡视频一二三| 69视频免费看| 日韩在线观看精品| 日韩欧美一级| 9999在线观看| 99久久久无码国产精品| 亚洲国产精品无码久久久| 中文字幕欧美精品日韩中文字幕| 91精品亚洲一区在线观看| 97在线免费视频观看| 2021中文字幕一区亚洲| 波多野结衣高清视频| 亚洲人精选亚洲人成在线| 婷婷激情一区| 黄色一区三区| 美女在线视频一区| 99久久婷婷国产综合| 亚洲精品按摩视频| 日韩电影大全网站| 热久久最新网址| 99精品视频一区| 国产精品系列视频| 久久久午夜视频| 久久精品播放| 又黄又色的网站| 欧美性色黄大片| 手机电影在线观看| 亚洲国产欧洲综合997久久| 国产精一品亚洲二区在线视频| 日韩欧美一区二区一幕| 国产亚洲欧美另类中文| www.成人网| 日韩精品一区二区三区色欲av| 中文字幕中文在线不卡住| 亚洲精品久久久狠狠狠爱|