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

Java 中的五個代碼性能提升技巧,最高提升近10倍

開發 后端
這篇文章介紹幾個 Java 開發中可以進行性能優化的小技巧,希望大家喜歡。

[[442793]]

 這篇文章介紹幾個 Java 開發中可以進行性能優化的小技巧,雖然大多數情況下極致優化代碼是沒有必要的,但是作為一名技術開發者,我們還是想追求代碼的更小、更快,更強。如果哪天你發現程序的運行速度不盡人意,可能會想到這篇文章。

提示:我們不應該為了優化而優化,這有時會增加代碼的復雜度。

這篇文章中的代碼都在以下環境中進行性能測試。

  •  JMH version: 1.33(Java 基準測試框架)
  •  VM version: JDK 17, OpenJDK 64-Bit Server VM, 17+35-2724

通過這篇文章的測試,將發現以下幾個操作的性能差異。

  1.   預先分配 HashMap 的大小,提高 1/4 的性能。
  2.   優化 HashMap 的 key,性能相差 9.5 倍。
  3.   不使用  Enum.values() 遍歷,Spring 也曾如此優化。
  4.   使用 Enum 代替 String 常量,性能高出 1.5 倍。
  5.   使用高版本 JDK,基礎操作有 2-5 倍性能差異。

預先分配 HashMap 的大小

HashMap 是 Java 中最為常用的集合之一,大多數的操作速度都非常快,但是 HashMap 在調整自身的容量大小時是很慢且難以自動優化,因此我們在定義一個 HashMap 之前,應該盡可能的給出它的容量大小。給出 size 值時要考慮負載因子,HashMap 默認負載因子是 0.75,也就是要設置的 size 值要除于 0.75。

相關文章:HashMap 源碼分析解讀

下面使用 JMH 進行基準測試,測試分別向初始容量為 16 和 32 的 HashMap 中插入 14 個元素的效率。 

  1. /**  
  2.  * @author https://www.wdbyte.com  
  3.  */  
  4. @State(Scope.Benchmark)  
  5. @Warmup(iterations = 3,time = 3 
  6. @Measurement(iterations = 5,time = 3 
  7. public class HashMapSize {  
  8.     @Param({"14"})  
  9.     int keys;  
  10.     @Param({"16", "32"})  
  11.     int size;  
  12.     @Benchmark  
  13.     public HashMap<Integer, Integer> getHashMap() {  
  14.         HashMap<Integer, Integer> map = new HashMap<>(size); 
  15.          for (int i = 0; i < keys; i++) {  
  16.             map.put(i, i);  
  17.         }  
  18.         return map; 
  19.    }  

HashMap 的初始容量是 16,負責因子 0.75,即最多插入 12 個元素,再插入時就要進行擴容,所以插入 14 個元素過程中需要擴容一次,但是如果 HashMap 初始化時就給了 32 容量,那么最多可以承載 32 * 0.75 = 24 個元素,所以插入 14 個元素時是不需要擴容操作的。 

  1. # JMH version: 1.33  
  2. # VM version: JDK 17, OpenJDK 64-Bit Server VM, 17+35-2724  
  3. Benchmark               (keys)  (size)   Mode  Cnt        Score        Error  Units  
  4. HashMapSize.getHashMap      14      16  thrpt   25  4825825.152 ± 323910.557  ops/s  
  5. HashMapSize.getHashMap      14      32  thrpt   25  6556184.664 ± 711657.679  ops/s 

可以看到在這次測試中,初始容量為32 的 HashMap 比初始容量為 16 的 HashMap 每秒可以多操作 26% 次,已經有 1/4 的性能差異了。

 優化 HashMap 的 key

如果 HashMap 的 key 值需要用到多個 String 字符串時,把字符串作為某個類屬性,然后使用這個類的實例作為 key 會比使用字符串拼接效率更高。

下面測試使用兩個字符串拼接作為 key,和把兩個字符串作為 MutablePair 類的屬性引用,然后使用 MutablePair 對象作為 key 的運行效率差異。 

  1. /**  
  2.  * @author https://www.wdbyte.com  
  3.  */  
  4. @State(Scope.Benchmark)  
  5. @Warmup(iterations = 3time = 3 
  6. @Measurement(iterations = 5time = 3 
  7. public class HashMapKey {  
  8.     private int size = 1024 
  9.     private Map<String, Object> stringMap;  
  10.     private Map<Pair, Object> pairMap;  
  11.     private String[] prefixes;  
  12.     private String[] suffixes;  
  13.     @Setup(Level.Trial)  
  14.     public void setup() {  
  15.         prefixes = new String[size];  
  16.         suffixes = new String[size];  
  17.         stringMap = new HashMap<>();  
  18.         pairMap = new HashMap<>();  
  19.         for (int i = 0; i < size; ++i) {  
  20.             prefixes[i] = UUID.randomUUID().toString();  
  21.             suffixes[i] = UUID.randomUUID().toString();  
  22.             stringMap.put(prefixes[i] + ";" + suffixes[i], i);  
  23.             // use new String to avoid reference equality speeding up the equals calls  
  24.             pairMap.put(new MutablePair(prefixes[i], suffixes[i]), i);  
  25.         }  
  26.     }  
  27.     @Benchmark  
  28.     @OperationsPerInvocation(1024)  
  29.     public void stringKey(Blackhole bh) {  
  30.         for (int i = 0; i < prefixes.length; i++) {  
  31.             bh.consume(stringMap.get(prefixes[i] + ";" + suffixes[i]));  
  32.         }  
  33.     }  
  34.     @Benchmark  
  35.     @OperationsPerInvocation(1024)  
  36.     public void pairMap(Blackhole bh) {  
  37.         for (int i = 0; i < prefixes.length; i++) {  
  38.             bh.consume(pairMap.get(new MutablePair(prefixes[i], suffixes[i])));  
  39.         }  
  40.     }  

測試結果: 

  1. # JMH version: 1.33  
  2. # VM version: JDK 17, OpenJDK 64-Bit Server VM, 17+35-2724  
  3. Benchmark              Mode  Cnt         Score         Error  Units  
  4. HashMapKey.pairMap    thrpt   25  89295035.436 ± 6498403.173  ops/s  
  5. HashMapKey.stringKey  thrpt   25   9410641.728 ±  389850.653  ops/s 

可以發現使用對象引用作為 key 的性能,是使用 String 拼接作為 key 的性能的 9.5 倍。 

不使用  Enum.values() 遍歷

我們通常會使用  Enum.values() 進行枚舉類遍歷,但是這樣每次調用都會分配枚舉類值數量大小的數組用于操作,這里完全可以緩存起來,以減少每次內存分配的時間和空間消耗。 

  1. /**  
  2.  * 枚舉類遍歷測試  
  3.  *  
  4.  * @author https://www.wdbyte.com  
  5.  */  
  6. @State(Scope.Benchmark)  
  7. @Warmup(iterations = 3time = 3 
  8. @Measurement(iterations = 5time = 3 
  9. @BenchmarkMode(Mode.AverageTime)  
  10. @OutputTimeUnit(TimeUnit.MILLISECONDS)  
  11. public class EnumIteration {  
  12.     enum FourteenEnum {  
  13.         a,b,c,d,e,f,g,h,i,j,k,l,m,n;  
  14.         static final FourteenEnum[] VALUES;  
  15.         static {  
  16.             VALUES = values();  
  17.         }  
  18.     }  
  19.     @Benchmark  
  20.     public void valuesEnum(Blackhole bh) {  
  21.         for (FourteenEnum value : FourteenEnum.values()) {  
  22.             bh.consume(value.ordinal());  
  23.         }  
  24.     }  
  25.     @Benchmark  
  26.     public void enumSetEnum(Blackhole bh) { 
  27.         for (FourteenEnum value : EnumSet.allOf(FourteenEnum.class)) {  
  28.             bh.consume(value.ordinal());  
  29.         }  
  30.     }  
  31.     @Benchmark  
  32.     public void cacheEnums(Blackhole bh) {  
  33.         for (FourteenEnum value : FourteenEnum.VALUES) {  
  34.             bh.consume(value.ordinal());  
  35.         }  
  36.     }  

運行結果 

  1. # JMH version: 1.33  
  2. # VM version: JDK 17, OpenJDK 64-Bit Server VM, 17+35-2724  
  3. Benchmark                   Mode  Cnt         Score         Error  Units  
  4. EnumIteration.cacheEnums   thrpt   25  15623401.567 ± 2274962.772  ops/s  
  5. EnumIteration.enumSetEnum  thrpt   25   8597188.662 ±  610632.249  ops/s  
  6. EnumIteration.valuesEnum   thrpt   25  14713941.570 ±  728955.826  ops/s 

很明顯使用緩存后的遍歷速度是最快的,使用 EnumSet 遍歷效率是最低的,這很好理解,數組的遍歷效率是大于哈希表的。

可能你會覺得這里使用 values() 緩存和直接使用 Enum.values() 的效率差異很小,其實在某些調用頻率很高的場景下是有很大區別的,在 Spring 框架中,曾使用 Enum.values() 這種方式在每次響應時遍歷 HTTP 狀態碼枚舉類,這在請求量大時造成了不必要的性能開銷,后來進行了 values() 緩存優化。

下面是這次提交的截圖:

Spring Enum.values 改動 

使用 Enum 代替 String 常量

使用 Enum 枚舉類代替 String 常量有明顯的好處,枚舉類強制驗證,不會出錯,同時使用枚舉類的效率也更高。即使作為 Map 的 key 值來看,雖然 HashMap 的速度已經很快了,但是使用 EnumMap 的速度可以更快。

提示:不要為了優化而優化,這會增加代碼的復雜度。

下面測試使用使用 Enum 作為 key,和使用 String 作為 key,在 map.get 操作下的性能差異。 

  1. /**  
  2.  * @author https://www.wdbyte.com  
  3.  */  
  4. @State(Scope.Benchmark)  
  5. @Warmup(iterations = 3time = 3 
  6. @Measurement(iterations = 5time = 3 
  7. public class EnumMapBenchmark {  
  8.     enum AnEnum {  
  9.         a, b, c, d, e, f, g,  
  10.         h, i, j, k, l, m, n,  
  11.         o, p, q,    r, s, t,  
  12.         u, v, w,    x, y, z;  
  13.     }  
  14.     /** 要查找的 key 的數量 */  
  15.     private static int size = 10000 
  16.     /** 隨機數種子 */  
  17.     private static int seed = 99 
  18.     @State(Scope.Benchmark)  
  19.     public static class EnumMapState {  
  20.         private EnumMap<AnEnum, String> map;  
  21.         private AnEnum[] values;  
  22.         @Setup(Level.Trial)  
  23.         public void setup() {  
  24.             map = new EnumMap<>(AnEnum.class);  
  25.             values = new AnEnum[size];  
  26.             AnEnum[] enumValues = AnEnum.values();  
  27.             SplittableRandom random = new SplittableRandom(seed);  
  28.             for (int i = 0; i < size; i++) {  
  29.                 int nextInt = random.nextInt(0, Integer.MAX_VALUE);  
  30.                 values[i] = enumValues[nextInt % enumValues.length];  
  31.             }  
  32.             for (AnEnum value : enumValues) {  
  33.                 map.put(value, UUID.randomUUID().toString());  
  34.             }  
  35.         }  
  36.     }  
  37.     @State(Scope.Benchmark)  
  38.     public static class HashMapState{  
  39.         private HashMap<String, String> map;  
  40.         private String[] values;  
  41.         @Setup(Level.Trial)  
  42.         public void setup() {  
  43.             map = new HashMap<>();  
  44.             values = new String[size];  
  45.             AnEnum[] enumValues = AnEnum.values();  
  46.             int pos = 0 
  47.             SplittableRandom random = new SplittableRandom(seed);  
  48.             for (int i = 0; i < size; i++) {  
  49.                 int nextInt = random.nextInt(0, Integer.MAX_VALUE);  
  50.                 values[i] = enumValues[nextInt % enumValues.length].toString();  
  51.             }  
  52.             for (AnEnum value : enumValues) {  
  53.                 map.put(value.toString(), UUID.randomUUID().toString());  
  54.             }  
  55.         }  
  56.     }  
  57.     @Benchmark  
  58.     public void enumMap(EnumMapState state, Blackhole bh) {  
  59.         for (AnEnum value : state.values) {  
  60.             bh.consume(state.map.get(value));  
  61.         }  
  62.     }  
  63.     @Benchmark  
  64.     public void hashMap(HashMapState state, Blackhole bh) {  
  65.         for (String value : state.values) {  
  66.             bh.consume(state.map.get(value));  
  67.         }  
  68.     }  

運行結果: 

  1. # JMH version: 1.33  
  2. # VM version: JDK 17, OpenJDK 64-Bit Server VM, 17+35-2724  
  3. Benchmark                  Mode  Cnt      Score      Error  Units  
  4. EnumMapBenchmark.enumMap  thrpt   25  22159.232 ± 1268.800  ops/s  
  5. EnumMapBenchmark.hashMap  thrpt   25  14528.555 ± 1323.610  ops/s 

很明顯,使用 Enum 作為 key 的性能比使用 String 作為 key 的性能高出 1.5 倍。但是仍然要根據實際情況考慮是否使用 EnumMap 和 EnumSet。

 使用高版本 JDK

String 類應該是 Java 中使用頻率最高的類了,但是 Java 8 中的  String 實現相比高版本 JDK ,則占用空間更多,性能更低。

下面測試 String 轉 bytes 和 bytes 轉 String 在 Java 8 以及 Java 11 中的性能開銷。 

  1. /**  
  2.  * @author https://www.wdbyte.com  
  3.  * @date 2021/12/23  
  4.  */  
  5. @State(Scope.Benchmark)  
  6. @Warmup(iterations = 3time = 3 
  7. @Measurement(iterations = 5time = 3 
  8. public class StringInJdk {  
  9.     @Param({"10000"})  
  10.     private int size;  
  11.     private String[] stringArray;  
  12.     private List<byte[]> byteList;  
  13.     @Setup(Level.Trial)  
  14.     public void setup() {  
  15.         byteList = new ArrayList<>(size);  
  16.         stringArray = new String[size]; 
  17.         for (int i = 0; i < size; i++) {  
  18.             String uuid = UUID.randomUUID().toString();  
  19.             stringArray[i] = uuid;  
  20.             byteList.add(uuid.getBytes(StandardCharsets.UTF_8));  
  21.         }  
  22.     }  
  23.     @Benchmark  
  24.     public void byteToString(Blackhole bh) {  
  25.         for (byte[] bytes : byteList) {  
  26.             bh.consume(new String(bytes, StandardCharsets.UTF_8));  
  27.         }  
  28.     }  
  29.     @Benchmark 
  30.  
  31.     public void stringToByte(Blackhole bh) {  
  32.         for (String s : stringArray) {  
  33.             bh.consume(s.getBytes(StandardCharsets.UTF_8));  
  34.         }  
  35.     }  

測試結果: 

  1. # JMH version: 1.33  
  2. # VM version: JDK 1.8.0_151, Java HotSpot(TM) 64-Bit Server VM, 25.151-b12  
  3. Benchmark                 (size)   Mode  Cnt     Score     Error  Units  
  4. StringInJdk.byteToString   10000  thrpt   25  2396.713 ± 133.500  ops/s  
  5. StringInJdk.stringToByte   10000  thrpt   25  1745.060 ±  16.945  ops/s  
  6. # JMH version: 1.33  
  7. # VM version: JDK 17, OpenJDK 64-Bit Server VM, 17+35-2724  
  8. Benchmark                 (size)   Mode  Cnt     Score     Error  Units  
  9. StringInJdk.byteToString   10000  thrpt   25  5711.954 ±  41.865  ops/s  
  10. StringInJdk.stringToByte   10000  thrpt   25  8595.895 ± 704.004  ops/s 

可以看到在 bytes 轉 String 操作上,Java 17 的性能是 Java 8 的 2.5 倍左右,而 String 轉 bytes 操作,Java 17 的性能是 Java 8 的 5 倍。關于字符串的操作非常基礎,隨處可見,可見高版本的優勢十分明顯。 

 

責任編輯:龐桂玉 來源: Hollis
相關推薦

2019-09-26 08:33:51

Nginx技術Java

2020-07-25 20:01:45

CSS前端

2020-03-26 12:38:15

代碼節點數據

2024-11-18 19:00:29

2011-07-01 10:11:39

2021-12-28 14:10:41

開發技能代碼

2020-07-22 08:30:02

代碼開發工具

2014-03-26 10:00:06

RailsRails性能

2018-08-23 17:45:52

2017-10-30 15:22:29

代碼可讀性技巧

2017-11-06 14:33:54

Web開發服務器網絡

2024-08-06 12:35:42

C#代碼重構

2020-07-21 15:40:55

NginxJava服務器

2025-05-27 01:55:00

TypeScript開發者項目

2024-10-29 08:21:05

2021-05-11 12:30:21

PyTorch代碼Python

2024-11-01 07:30:00

2024-06-11 00:09:00

JavaScript模式變量

2024-11-14 11:29:38

點贊
收藏

51CTO技術棧公眾號

日本中文字幕久久| 国产福利一区二区三区视频在线| 99久久精品国产一区| 亚洲理论在线a中文字幕| 国产在线视频不卡| 小毛片在线观看| 超碰人人在线| 精品一区毛片| 亚洲一区二区三区小说| 国产免费观看久久黄| 久久亚洲AV成人无码国产野外| 黄色av免费在线| 免费成人美女在线观看| 亚洲精品日韩丝袜精品| 福利视频一区二区三区四区| 中文字幕+乱码+中文| 九色精品91| 91精品国产综合久久精品图片| 亚洲欧洲日韩精品| 国产又粗又猛又爽又| 最新精品国偷自产在线| 欧美顶级少妇做爰| 欧美亚洲另类久久综合| 久久精品免费在线| 天堂va欧美ⅴa亚洲va一国产| 亚洲欧洲精品一区二区三区| 国产日产亚洲精品| 精品国产免费久久久久久尖叫| 日本精品一区在线| 男人资源在线播放| 韩国成人福利片在线播放| 日韩中文字幕不卡视频| 在线观看国产中文字幕| 日本亚洲精品| 国产九色精品成人porny| 日韩视频第一页| 波多野结衣视频播放| 国产亚洲人成a在线v网站 | 麻豆专区一区二区三区四区五区| 亚洲精品久久久久久下一站 | 中文字幕成人网| 91av视频在线免费观看| 野战少妇38p| www久久日com| 国产日韩精品一区二区浪潮av| 欧美国产日韩xxxxx| 99热这里只有精品2| 思思99re6国产在线播放| 99久精品国产| 波多野结衣久草一区| 色哟哟一一国产精品| 偷拍自拍在线看| 国产一二三精品| 中文字幕亚洲欧美日韩2019| 亚洲一区二区图片| www在线观看播放免费视频日本| 91丝袜呻吟高潮美腿白嫩在线观看| 久久91超碰青草是什么| 成年网站免费在线观看| 黄色在线视频网站| 欧美激情在线一区二区| 成人网在线观看| 亚洲aaa视频| 中文字幕综合| 亚洲欧美综合色| 欧美人与物videos另类| 婷婷开心激情网| 日本亚洲视频在线| 国产盗摄xxxx视频xxx69| 天堂www中文在线资源| 日韩成人免费av| 亚洲一区影音先锋| 人人妻人人澡人人爽欧美一区| 午夜视频福利在线观看| 99久久精品国产一区二区三区| 99在线影院| 精品国产黄色片| 一区在线视频| 综合网日日天干夜夜久久| www.自拍偷拍| 欧美男gay| 一区二区三区视频免费| 亚洲综合激情视频| 色8久久久久| 欧美在线免费播放| 久久99精品久久久久久三级| caoporn国产| 亚洲主播在线| 久久久国产在线视频| 日日橹狠狠爱欧美超碰| 国产午夜精品一区理论片| 亚洲一区二区三区四区五区午夜 | 亚洲精品视频中文字幕| 一区二区黄色片| 91淫黄看大片| 国产系列在线观看| 国产婷婷一区二区| 在线视频一区观看| www.国产麻豆| 成人免费毛片app| 国产大片精品免费永久看nba| 天天干天天操天天操| 美女一区二区视频| 成人免费看吃奶视频网站| 黄色av网站免费在线观看| 丝袜a∨在线一区二区三区不卡| 久久国产精品久久国产精品| 国产精品12| 污版视频在线观看| 国产秀色在线www免费观看| 亚洲精品免费视频| 男人添女人下面高潮视频| 韩日一区二区| 亚洲午夜激情av| 国产 欧美 日韩 一区| 成人免费短视频| 亚洲综合成人网| 国产美女视频免费| 国产自产自拍视频在线观看| 亚洲精品成a人| 亚洲第一视频网站| 亚洲精品mv在线观看| 九色丨蝌蚪丨成人| 亚洲天堂网站在线观看视频| 欧美精品日韩在线| 精品国产一区二区三区久久久蜜臀 | 色在线中文字幕| 亚洲欧美偷拍另类a∨色屁股| 欧美激情专区| 宅男网站在线免费观看| 国产精品国产自产拍在线| 欧美一区国产一区| www.激情五月.com| 欧美激情一区二区在线| 霍思燕三级露全乳照| 久久久加勒比| 亚洲欧美一区二区激情| 精品肉丝脚一区二区三区| 女生裸体视频一区二区三区| 免费av在线一区| 日韩av免费播放| 丁香激情综合国产| 菠萝蜜视频在线观看入口| 黄色日韩网站| 亚洲国产精品成人一区二区| 国产天堂av在线| 亚洲a一区二区三区| 中文字幕久精品免费视频| 精品成人久久久| 在线成人h网| 91色精品视频在线| 懂色av成人一区二区三区| 国产精品麻豆一区二区| 亚洲v欧美v另类v综合v日韩v| 青青久草在线| 亚洲欧洲性图库| 国产h视频在线播放| 日韩精品三级| 九九精品视频在线观看| 国产欧美熟妇另类久久久 | 男人操女人动态图| 国产精品视频| 免费亚洲一区二区| 男人最爱成人网| 一本大道久久a久久综合婷婷 | 日韩和欧美一区二区三区| 精品欧美一区二区三区久久久| 国产蜜臀一区二区打屁股调教| 亚洲一级电影视频| 日本一区二区免费视频| 国产精品多人| 91产国在线观看动作片喷水| 三级网站免费观看| 精品久久久久久电影| 一本加勒比波多野结衣| av成人国产| 国产欧美日韩精品丝袜高跟鞋| av网站无病毒在线| 亚洲精品国产一区二区三区四区在线| 午夜剧场高清版免费观看| 91亚洲人成网污www| 91久久国产综合久久91精品网站| 国产素人视频在线观看| 欧美久久婷婷综合色| 中文字幕第69页| 国产精品99久久久久久有的能看 | 97精品97| 国产日韩av高清| 黄色免费网站在线观看| 91精品久久久久久久99蜜桃| 精品国产免费久久久久久婷婷| 一区二区三区日本久久久| 91产国在线观看动作片喷水| 触手亚洲一区二区三区| 91精品欧美久久久久久动漫| 国产一区二区视频在线观看免费| 一本色道久久综合亚洲精品不| 久久久精品国产一区二区三区| 都市激情综合| 久久艳片www.17c.com | 国产美女精品人人做人人爽| 久青草视频在线播放| 日韩国产激情| 丝袜一区二区三区| 国内爆初菊对白视频| 欧美日韩在线视频一区二区| 亚洲一二三精品| 国产成人av自拍| 日本最新一区二区三区视频观看| 天堂综合在线播放| 欧美成人剧情片在线观看| 色视频在线看| 日韩一区二区免费在线观看| 日本午夜视频在线观看| 国产精品久久久久久久蜜臀| 五月天丁香社区| 免费成人在线观看视频| 国产人妻777人伦精品hd| 日韩在线激情| 91国内免费在线视频| 自拍视频在线网| 亚洲精品99久久久久中文字幕| 中文字幕免费观看视频| 亚洲国产中文字幕在线视频综合 | 在线免费av网| 久久亚洲精精品中文字幕早川悠里| 香蕉视频网站入口| 成人免费看片39| 欧美亚洲免费电影| 婷婷在线免费观看| 欧美丰满高潮xxxx喷水动漫| 亚洲欧美一区二区三区在线观看| 一区二区三区蜜桃| 国产农村妇女精品一区| 日产欧产美韩系列久久99| 97干在线视频| 这里只有精品在线| 性欧美精品一区二区三区在线播放| 麻豆国产一区二区三区四区| 欧美精品做受xxx性少妇| 精品电影在线| 精品视频在线免费看| 国产区在线观看视频| 一区二区三区国产| 欧美波霸videosex极品| 国产欧美日韩中文久久| 国产亚洲无码精品| av中文字幕不卡| 人妻久久久一区二区三区| 亚洲视频电影在线| 亚洲一区3d动漫同人无遮挡 | 亚洲av无码一区二区乱子伦| 欧美精品日韩一本| 国产真人无遮挡作爱免费视频| 亚洲风情在线资源站| 女同性αv亚洲女同志| 国产一区二区精品久久| 日韩av一卡二卡三卡| 黑人一区二区| 一本久道久久综合| 日韩影院二区| 91久色国产| 麻豆视频久久| 7777精品伊久久久大香线蕉语言| 91精品在线免费视频| 成人黄在线观看| 欧美在线一级| 国产日本欧美一区二区三区| 图片一区二区| 91精品在线观| 国产一区二区| 99在线视频首页| 精品一区二区三区中文字幕视频 | 国产毛片精品| 国产乱子伦精品| 同性恋视频一区| 奇米影视首页 狠狠色丁香婷婷久久综合| 亚洲97av| 视频一区二区三| 国产精品99一区二区三| 一本色道久久88亚洲精品综合| 国产一区二区三区免费观看在线| 成人在线视频网站| 日本精品在线观看| 国产精品综合久久久久久| 136国产福利精品导航网址应用| 粉嫩精品一区二区三区在线观看 | 麻豆国产在线播放| 欧美一级欧美一级在线播放| 成人福利小视频| 日韩视频一区二区| 亚洲av成人精品毛片| 亚洲一级免费视频| 成人在线播放免费观看| 国内精品一区二区三区| 成人性生交大片免费观看网站| 国产精品爽爽爽| 69精品国产久热在线观看| 久久久久久国产精品免费免费| av一区二区高清| 国产精品igao激情视频| 国产综合网站| 日韩久久一级片| 免费人成黄页网站在线一区二区| 肉丝美足丝袜一区二区三区四| 2024国产精品视频| 男人av资源站| 欧美午夜精品久久久久久浪潮| 做爰视频毛片视频| 亚洲高清一区二区三区| 无码人妻久久一区二区三区| 9191久久久久久久久久久| 熟妇人妻系列aⅴ无码专区友真希 熟妇人妻av无码一区二区三区 | 亚洲永久激情精品| 亚洲第一毛片| 激情五月婷婷基地| www.亚洲人| 亚洲 欧美 变态 另类 综合| 欧美日韩在线视频首页| 国产免费的av| 亚洲热线99精品视频| 日本成人不卡| 久久影院中文字幕| 欧洲av不卡| 国产精品国产三级欧美二区| 久久99精品久久久久久园产越南| 色哺乳xxxxhd奶水米仓惠香| 日韩1区2区日韩1区2区| 黄色性生活一级片| 亚洲综合区在线| 久久久蜜桃一区二区| 精品视频在线免费| 国产香蕉在线| 欧美做受高潮1| 爱情岛亚洲播放路线| 国产精品丝袜高跟| 国产真实有声精品录音| 国产 日韩 亚洲 欧美| 国产成人鲁色资源国产91色综| 在线观看天堂av| 在线观看一区日韩| 婷婷在线免费视频| 久久久视频在线| avtt久久| 日本一道在线观看| 韩国欧美国产1区| 男女男精品视频网站| 91福利社在线观看| 你懂得网站在线| 欧美性做爰毛片| 老汉色老汉首页av亚洲| 热这里只有精品| 国产乱一区二区| 午夜精品一区二区三区视频| 欧美日韩中文精品| 欧美精品电影| 国产在线日韩在线| 国产精品成人a在线观看| 天天视频天天爽| 国产精品免费视频观看| 国产精品无码一区| 亚洲人成在线观看| 欧美xx视频| 日韩在线电影一区| 蜜臀国产一区二区三区在线播放| 亚洲色成人网站www永久四虎| 欧美韩国日本不卡| 狠狠躁夜夜躁人人爽视频| 亚洲最大在线视频| 国产69精品久久| 樱空桃在线播放| 国产精品白丝av| 亚洲成人生活片| 91精品国产欧美日韩| 在线看一级片| 国产九色91| 久久成人一区| 五月天婷婷丁香网| 9191成人精品久久| 日本片在线看| 久久一区二区三区av| 亚洲一区观看| 一级黄色录像毛片| 欧美日本免费一区二区三区| 国内精品不卡| 国产视频一区二区三区四区| 亚洲欧美视频| 国产探花视频在线播放| 欧美高清视频一二三区 | 日韩激情视频在线播放| 色天使综合视频| 欧美爱爱视频网站| 99视频有精品| 欧美 亚洲 另类 激情 另类| 麻豆乱码国产一区二区三区| 成人av动漫| 无码精品国产一区二区三区免费| 一色屋精品亚洲香蕉网站| 黑人精品一区二区三区| 日韩暖暖在线视频|