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

聊聊Unsafe的一些使用技巧

開發 后端
sun.misc.Unsafe 是 JDK 原生提供的一個工具類,包含了很多在 Java 語言看來很 cool 的操作,例如內存分配與回收、CAS 操作、類實例化、內存屏障等。

[[428449]]

本文轉載自微信公眾號「Kirito的技術分享」,作者kiritomoe 。轉載本文請聯系Kirito的技術分享公眾號。

前言

記得初學 Java 那會,剛學完語法基礎,就接觸到了反射這個 Java 提供的特性,盡管在現在看來,這是非常基礎的知識點,但那時候無疑是興奮的,瞬間覺得自己脫離了“Java 初學者”的隊伍。隨著工作經驗的積累,我也逐漸學習到了很多類似的讓我為之而興奮的知識點,Unsafe 的使用技巧無疑便是其中一個。

sun.misc.Unsafe 是 JDK 原生提供的一個工具類,包含了很多在 Java 語言看來很 cool 的操作,例如內存分配與回收、CAS 操作、類實例化、內存屏障等。正如其命名一樣,由于其可以直接操作內存,執行底層系統調用,其提供的操作也是比較危險的。Unsafe 在擴展 Java 語言表達能力、便于在更高層(Java層)代碼里實現原本要在更低層(C層)實現的核心庫功能上起到了很大的作用。

從 JDK9 開始,Java 模塊化設計的限制,使得非標準庫的模塊都無法訪問到 sun.misc.Unsafe。但在 JDK8 中,我們仍然可以直接操作 Unsafe,再不學習,后面可能就沒機會了。

使用 Unsafe

Unsafe 被設計的初衷,并不是希望被一般開發者調用,所以我們不能通過 new 或者工廠方法去實例化 Unsafe 對象,通常可以采用反射的方法獲取到 Unsafe 實例:

  1. public static final Unsafe unsafe = getUnsafe(); 
  2.  
  3. static sun.misc.Unsafe getUnsafe() { 
  4.     try { 
  5.         Field field = Unsafe.class.getDeclaredField("theUnsafe"); 
  6.         field.setAccessible(true); 
  7.         return  (Unsafe) field.get(null); 
  8.     } catch (Exception e) { 
  9.         throw new RuntimeException(e); 
  10.     } 

拿到之后,便可以用這個全局的單例對象去為所欲為了。

功能概覽

圖片來源于網絡,我直接借用過來了。上圖包含了 Unsafe 的眾多功能,還算全面。如果全部介紹,文章篇幅會過長,形式難免會流水賬,我打算結合我的一些項目經驗以及一些比賽經驗,從實踐角度聊聊 Unsafe 的一些使用技巧。

內存分配&存取

Java 其實也可以像 C++ 那樣直接操作內存,借助 Unsafe 就可以。讓我們先來看一個 ByteBuffer 的示例,我們將會開辟一個 16 字節的內存空間,先后寫入并讀取 4 個 int 類型的數據。

  1. public static void testByteBuffer() { 
  2.     ByteBuffer directBuffer = ByteBuffer.allocateDirect(16); 
  3.     directBuffer.putInt(1); 
  4.     directBuffer.putInt(2); 
  5.     directBuffer.putInt(3); 
  6.     directBuffer.putInt(4); 
  7.     directBuffer.flip(); 
  8.     System.out.println(directBuffer.getInt()); 
  9.     System.out.println(directBuffer.getInt()); 
  10.     System.out.println(directBuffer.getInt()); 
  11.     System.out.println(directBuffer.getInt()); 

熟悉 nio 操作的同學對上面的示例應該不會感到陌生,這是很基礎也是很標準的內存使用方式。那換做是 Unsafe 怎么實現同樣的效果的?

  1. public static void testUnsafe0() { 
  2.     Unsafe unsafe = Util.unsafe; 
  3.     long address = unsafe.allocateMemory(16); 
  4.     unsafe.putInt(address, 1); 
  5.     unsafe.putInt(address + 4, 2); 
  6.     unsafe.putInt(address + 8, 3); 
  7.     unsafe.putInt(address + 12, 4); 
  8.  
  9.     System.out.println(unsafe.getInt(address)); 
  10.     System.out.println(unsafe.getInt(address + 4)); 
  11.     System.out.println(unsafe.getInt(address + 8)); 
  12.     System.out.println(unsafe.getInt(address + 12)); 

兩段代碼輸出結果一致:

下面針對使用到的 Unsafe 的 API,逐個介紹:

  1. public native long allocateMemory(long var1); 

這個 native 方法分配的是堆外內存,返回的 long 類型數值,便是內存的首地址,可以作為 Unsafe 其他 API 的入參。你如果見過 DirectByteBuffer 的源碼,會發現其實它內部就是使用 Unsafe 封裝的。說到 DirectByteBuffer,這里額外提一句,ByteBuffer.allocateDirect 分配的堆外內存會受到 -XX:MaxDirectMemorySize 的限制,而 Unsafe 分配的堆外內存則不會受到限制,當然啦,也不會受到 -Xmx 的限制。如果你正在參加什么比賽并且受到了什么啟發,可以把“爺懂了”打在公屏上。

看到另外兩個 API putInt 和 getInt ,你應當會意識到,肯定會有其他字節操作的 API,例如 putByte/putShort/putLong ,當然 put 和 get 也是成對出現的。這一系列 API 里面也有注意點,建議需要成對的使用,否則可能會因為字節序問題,導致解析失敗。可以看下面的例子:

  1. public static void testUnsafe1() { 
  2.     ByteBuffer directBuffer = ByteBuffer.allocateDirect(4); 
  3.     long directBufferAddress = ((DirectBuffer)directBuffer).address(); 
  4.     System.out.println("Unsafe.putInt(1)"); 
  5.     Util.unsafe.putInt(directBufferAddress, 1); 
  6.     System.out.println("Unsafe.getInt() == " + Util.unsafe.getInt(directBufferAddress)); 
  7.     directBuffer.position(0); 
  8.     directBuffer.limit(4); 
  9.     System.out.println("ByteBuffer.getInt() == " + directBuffer.getInt()); 
  10.     directBuffer.position(0); 
  11.     directBuffer.limit(4); 
  12.     System.out.println("ByteBuffer.getInt() reverseBytes == " + Integer.reverseBytes(directBuffer.getInt())); 

輸出如下:

  1. Unsafe.putInt(1) 
  2. Unsafe.getInt() == 1 
  3. ByteBuffer.getInt() == 16777216 
  4. ByteBuffer.getInt() reverseBytes == 1 

可以發現當我們使用 Unsafe 進行 putInt,再使用 ByteBuffer 進行 getInt,結果會不符合預期,需要對結果進行字節序變化之后,才恢復正確。這其實是因為,ByteBuffer 內部判斷了當前操作系統的字節序,對于 int 這種多字節的數據類型,我的測試機器使用大端序存儲,而 Unsafe 默認以小短序存儲導致。如果你拿捏不準,建議配套使用寫入和讀取 API,以避免字節序問題。對字節序不了解的同學可以參考我的另外一篇文章:《“字節序”是個什么鬼》。

內存復制

內存復制在實際應用場景中還是很常見的需求,例如上一篇文章我剛介紹過的,堆內內存寫入磁盤時,需要先復制到堆外內存,再例如我們做內存聚合時,需要緩沖一部分數據,也會涉及到內存復制。你當然也可以通過 ByteBuffer 或者 set/get 去進行操作,但肯定不如 native 方法來的高效。Unsafe 提供了內存拷貝的 native 方法,可以實現堆內到堆內、堆外到堆外、堆外和堆內互相拷貝,總之就是哪兒到哪兒都可以拷貝。

  1. public native void copyMemory(Object src, long offset, Object dst ,long dstOffset, long size); 

對于堆內內存來說,我們可以直接給 src 傳入對象數組的首地址,并且指定 offset 為對應數組類型的偏移量,可以通過 arrayBaseOffset 方法獲取堆內內存存儲對象的偏移量

  1. public native int arrayBaseOffset(Class<?> var1); 

例如獲取 byte[] 的固定偏移量可以這樣操作:unsafe.arrayBaseOffset(byte[].class)

對于堆外內存來說,會更加直觀一點,dst 設為 null,dstOffset 設置為 Unsafe 獲取的內存地址即可。

堆內內存復制到堆外內存的示例代碼:

  1. public static void unsafeCopyMemory()  { 
  2.     ByteBuffer heapBuffer = ByteBuffer.allocate(4); 
  3.     ByteBuffer directBuffer = ByteBuffer.allocateDirect(4); 
  4.     heapBuffer.putInt(1234); 
  5.     long address = ((DirectBuffer)directBuffer).address(); 
  6.  
  7.     Util.unsafe.copyMemory(heapBuffer.array(), 16, null, address, 4); 
  8.  
  9.     directBuffer.position(0); 
  10.     directBuffer.limit(4); 
  11.  
  12.     System.out.println(directBuffer.getInt()); 

在實際應用中,大多數 ByteBuffer 相關的源碼在涉及到內存復制時,都使用了 copyMemory 方法。

非常規實例化對象

在 JDK9 模塊化之前,如果不希望將一些類開放給其他用戶使用,或者避免被隨意實例化(單例模式),通常有兩個常見做法

案例一:私有化構造器

  1. public class PrivateConstructorFoo { 
  2.  
  3.     private PrivateConstructorFoo() { 
  4.         System.out.println("constructor method is invoked"); 
  5.     } 
  6.  
  7.     public void hello() { 
  8.         System.out.println("hello world"); 
  9.     } 
  10.  

如果希望實例化該對象,第一時間想到的可能是反射創建

  1. public static void reflectConstruction() { 
  2.   PrivateConstructorFoo privateConstructorFoo = PrivateConstructorFoo.class.newInstance(); 
  3.   privateConstructorFoo.hello(); 

不出所料,我們獲得了一個異常

  1. java.lang.IllegalAccessException: Class io.openmessaging.Main can not access a member of class moe.cnkirito.PrivateConstructorFoo with modifiers "private" 

稍作調整,調用構造器創建實例

  1. public static void reflectConstruction2() { 
  2.    Constructor<PrivateConstructorFoo> constructor = PrivateConstructorFoo.class.getDeclaredConstructor(); 
  3.    constructor.setAccessible(true); 
  4.    PrivateConstructorFoo privateConstructorFoo = constructor.newInstance(); 
  5.    privateConstructorFoo.hello(); 

it works!輸出如下:

  1. constructor method is invoked 
  2. hello world 

當然,Unsafe 也提供了 allocateInstance 方法

  1. public native Object allocateInstance(Class<?> var1) throws InstantiationException; 

也可以實現實例化,而且更為直觀

  1. public static void allocateInstance() throws InstantiationException { 
  2.     PrivateConstructorFoo privateConstructorFoo = (PrivateConstructorFoo) Util.unsafe.allocateInstance(PrivateConstructorFoo.class); 
  3.     privateConstructorFoo.hello(); 

同樣 works!輸出如下:

  1. hello world 

注意這里有一個細節,allocateInstance 沒有觸發構造方法。

案例二:package level 實例

  1. package moe.cnkirito; 
  2.  
  3. class PackageFoo { 
  4.  
  5.     public void hello() { 
  6.         System.out.println("hello world"); 
  7.     } 
  8.  

注意,這里我定義了一個 package 級別可訪問的對象 PackageFoo,只有 moe.cnkirito 包下的類可以訪問。

我們同樣先嘗試使用反射

  1. package com.bellamm; 
  2.  
  3. public static void reflectConstruction() { 
  4.   Class<?> aClass = Class.forName("moe.cnkirito.PackageFoo"); 
  5.   aClass.newInstance(); 

得到了意料之中的報錯:

  1. java.lang.IllegalAccessException: Class io.openmessaging.Main can not access a member of class moe.cnkirito.PackageFoo with modifiers "" 

再試試 Unsafe 呢?

  1. package com.bellamm; 
  2.  
  3. public static void allocateInstance() throws Exception{ 
  4.     Class<?> fooClass = Class.forName("moe.cnkirito.PackageFoo"); 
  5.     Object foo = Util.unsafe.allocateInstance(fooClass); 
  6.     Method helloMethod = fooClass.getDeclaredMethod("hello"); 
  7.     helloMethod.setAccessible(true); 
  8.     helloMethod.invoke(foo); 

由于在 com.bellamm 包下,我們甚至無法在編譯期定義 PackageFoo 類,只能通過反射機制在運行時,獲取 moe.cnkirito.PackageFoo 的方法,配合 Unsafe 實例化,最終實現調用,成功輸出 hello world。

我們花了這么大的篇幅進行實驗來說明了兩種限制案例,以及 Unsafe 的解決方案,還需要有實際的應用場景佐證 Unsafe#allocateInstance 的價值。我簡單列舉兩個場景:

  1. 序列化框架在使用反射無法創建對象時,可以嘗試使用 Unsafe 創建,作為兜底邏輯。
  2. 獲取包級別保護的類,再借助于反射機制,可以魔改一些源碼實現或者調用一些 native 方法,此法慎用,不建議在生產使用。

示例代碼:動態修改堆外內存限制,覆蓋 JVM 啟動參數:-XX:MaxDirectMemorySize

  1. private void hackMaxDirectMemorySize() { 
  2.      try { 
  3.          Field directMemoryField = VM.class.getDeclaredField("directMemory"); 
  4.          directMemoryField.setAccessible(true); 
  5.          directMemoryField.set(new VM(), 8L * 1024 * 1024 * 1024); 
  6.  
  7.          Object bits = Util.unsafe.allocateInstance(Class.forName("java.nio.Bits")); 
  8.          Field maxMemory = bits.getClass().getDeclaredField("maxMemory"); 
  9.          maxMemory.setAccessible(true); 
  10.          maxMemory.set(bits, 8L * 1024 * 1024 * 1024); 
  11.  
  12.      } catch (Exception e) { 
  13.          throw new RuntimeException(e); 
  14.      } 
  15.  
  16.      System.out.println(VM.maxDirectMemory()); 
  17.  
  18.  } 

總結

先大概介紹這三個 Unsafe 用法吧,已經是我個人認為比較常用的幾個 Unsafe 案例了。

Unsafe 這個東西,會用的人基本都知道不能瞎用;不會用的話,看個熱鬧,知道 Java 有這個機制總比不知道強對吧。當然,本文也介紹了一些實際場景可能必須得用 Unsafe,但更多還是出現在各個底層源碼之中。

 

如果還有讀者想看到更多騷操作的話,歡迎轉發本文,閱讀過 1500,繼續加更一期,一鍵三連,這次一定。

 

責任編輯:武曉燕 來源: Kirito的技術分享
相關推薦

2021-06-08 06:13:16

React開發開發技術

2020-11-25 07:43:07

Java

2011-06-01 16:50:21

JAVA

2013-03-29 13:17:53

XCode調試技巧iOS開發

2012-05-21 10:13:05

XCode調試技巧

2015-08-17 15:53:58

Linux桌面

2011-07-19 18:11:09

iPhone 開發

2009-11-30 13:51:28

VS2003 Acti

2015-11-26 11:33:54

掃描器

2011-07-12 09:47:53

WebService

2011-10-26 20:55:43

ssh 安全

2011-05-23 18:06:24

站內優化SEO

2021-10-26 13:55:53

搞定系統設計

2022-12-02 14:58:27

JavaScript技巧編程

2009-11-26 10:32:57

PHP代碼優化

2020-04-14 09:22:47

bash腳本技巧

2020-04-08 10:21:58

bash腳本語言

2018-05-07 08:22:19

LinuxImageMagick查看圖片

2017-05-10 15:30:30

skynet崩潰程序

2017-09-20 15:07:32

數據庫SQL注入技巧分享
點贊
收藏

51CTO技術棧公眾號

亚洲精品中文字幕乱码三区| 蜜臀av一级做a爰片久久| 亚洲国内高清视频| 国产偷人视频免费| 韩国中文字幕在线| 92国产精品观看| 国产精品欧美日韩| 男女免费视频网站| 精品国产精品久久一区免费式 | 手机看片久久久| 久久精品国产亚洲夜色av网站| 欧美不卡视频一区| 91精品无人成人www| 97超碰免费在线| 最好看的中文字幕久久| 欧美一区亚洲二区| 欧美特级特黄aaaaaa在线看| 蜜臂av日日欢夜夜爽一区| 欧美高清在线观看| 久久免费手机视频| 亚洲精品蜜桃乱晃| 日韩欧美激情在线| 中国黄色片一级| 成人福利av| 亚洲大片在线观看| 欧洲金发美女大战黑人| 在线观看黄色av| 久久久久亚洲综合| 国产一区二区三区色淫影院| 国产视频第二页| 免费在线观看成人| 日韩美女视频免费在线观看| 国产亚洲欧美精品久久久久久| 日韩在线视频精品| 亚洲日本中文字幕| 欧美成人三级伦在线观看| 一区二区三区视频免费视频观看网站| 欧美体内she精视频| 少妇性饥渴无码a区免费| 电影k8一区二区三区久久| 亚洲天堂精品视频| 亚洲一卡二卡三卡| 北岛玲一区二区三区| 久久久久久综合| 精品国产乱码久久久久久88av| 国产成人久久精品77777综合| 麻豆精品在线看| 国产精品第一第二| 日韩欧美国产另类| 秋霞影院一区二区| 国产成人在线精品| 久久久久久亚洲av无码专区| 亚洲一区中文| 8x拔播拔播x8国产精品| 色网站在线播放| 亚洲精品123区| 午夜精品一区二区三区视频免费看| 欧美人与禽zozzo禽性配| 欧美91视频| 色综合久久悠悠| 精品99久久久久成人网站免费 | 免费看国产曰批40分钟| sm捆绑调教国产免费网站在线观看| 亚洲一卡二卡三卡四卡五卡| 日韩中文字幕亚洲精品欧美| 中文字幕在线观看网站| 亚洲精品日韩一| 97超碰在线人人| 碰碰在线视频| 在线观看视频91| 久久久久久久久久久久久久久国产| 日本在线一区二区| 日韩欧美国产午夜精品| 手机精品视频在线| 精品淫伦v久久水蜜桃| 亚洲二区在线播放视频| 精品无码在线视频| 日韩激情在线| 久久99国产精品自在自在app| 国产无码精品在线播放| 老司机精品福利视频| 国产精品一区二区性色av | 久久www免费人成看片高清| 92福利视频午夜1000合集在线观看| 精品久久无码中文字幕| 91首页免费视频| 五月天丁香综合久久国产| 在线中文字幕第一页| 精品久久久国产| 色噜噜狠狠一区二区| 97久久综合精品久久久综合| 日韩精品福利在线| 黄色片网站在线播放| 一本色道88久久加勒比精品| 国产精品视频一区二区三区四| av在线亚洲天堂| 久久精品夜色噜噜亚洲aⅴ| 亚洲一区二区免费视频软件合集 | 一区二区三区四区激情| www.四虎成人| 美女精品久久| 国产一区二区三区毛片| 免费人成年激情视频在线观看| 久久最新视频| 国产精品乱子乱xxxx| 99视频在线观看地址| 精品国产精品自拍| 永久看看免费大片| 欧美精品尤物在线观看| 97久久精品视频| 91福利在线观看视频| 久久久蜜桃精品| 人人妻人人做人人爽| 只有精品亚洲| 亚洲桃花岛网站| 日韩人妻无码一区二区三区99| 久久国产日韩欧美精品| 欧美高清性xxxxhd| av中文在线资源库| 欧美成人猛片aaaaaaa| 99久久久免费精品| 免费精品视频在线| 欧美性xxxx69| 在线观看网站免费入口在线观看国内| 日韩视频免费直播| www.黄色com| 日韩av在线播放中文字幕| 精品视频一区二区| av电影在线免费| 欧美mv日韩mv国产网站| 少妇人妻丰满做爰xxx| 奇米影视一区二区三区| 日韩欧美一区二区三区四区五区| 久久久男人天堂| 亚洲成人久久久久| 强行糟蹋人妻hd中文| 久久 天天综合| 午夜一区二区三视频在线观看| 欧美成人免费电影| 亚洲欧美国产精品va在线观看| 久久中文字幕在线观看| 风流少妇一区二区| 99er在线视频| 国产精品xxxav免费视频| 欧美激情一区二区久久久| 99久久久久久久| 亚洲美女在线一区| 性xxxxxxxxx| 激情久久综合| 国产精品一区在线播放| 色网在线免费观看| 国产丝袜精品第一页| 亚洲av中文无码乱人伦在线视色| 91毛片在线观看| 日本a√在线观看| 久久中文字幕av| 亚洲a级在线观看| 亚洲淫性视频| 亚洲第一精品福利| 黑人一级大毛片| 久久精品一区二区三区四区 | 极品尤物av久久免费看| 无码人妻aⅴ一区二区三区日本| 久久丁香四色| 69av在线视频| 成人在线免费电影| 91精品国产高清一区二区三区蜜臀 | 免费av一区二区| 亚洲成人一级片| 福利视频导航一区| 日韩影视一区二区三区| 国产精品99久久久久久似苏梦涵| 欧洲xxxxx| 伦理一区二区| 国产精品一区av| bl视频在线免费观看| 日韩精品在线视频观看| 中文字幕人妻一区二区在线视频| 亚洲色图欧美偷拍| 一边摸一边做爽的视频17国产| 可以看av的网站久久看| 一本色道久久99精品综合| 亚洲精品在线a| 日韩美女在线观看| av片在线观看永久免费| 精品视频中文字幕| 亚洲一区二区影视| 亚洲成人免费看| 国产精品成人在线视频| 成人性色生活片| 一区二区三区免费播放| 国产字幕视频一区二区| 久久99精品久久久久久三级 | 亚洲欧美清纯在线制服| 免费成人深夜夜行网站视频| 要久久电视剧全集免费 | 欧美电影免费网站| 国产精品亚洲自拍| 男人的天堂免费在线视频| 久久久精品视频在线观看| 午夜视频福利在线| 欧美一级生活片| 国产又粗又猛又黄视频| 亚洲国产成人av网| 色老板免费视频| 久久九九久精品国产免费直播| 国产成人精品综合久久久久99| 日日摸夜夜添夜夜添亚洲女人| 日本大片免费看| 久久一区二区三区电影| 欧美日韩一区在线视频| 亚洲精品在线a| 成人免费福利在线| 日韩欧美精品电影| 欧美亚洲国产另类| h片精品在线观看| 久久这里只有精品99| 成人在线观看黄色| 精品一区电影国产| 隣の若妻さん波多野结衣| 制服丝袜一区二区三区| 99精品人妻国产毛片| 婷婷国产v国产偷v亚洲高清| 国产探花在线播放| 最新日韩av在线| 粉嫩精品久久99综合一区| 久久久天堂av| 美女脱光内衣内裤| 久久伊人中文字幕| 黄色片视频免费观看| caoporm超碰国产精品| 男人添女人荫蒂国产| 国产精品一二三| 一起草最新网址| 国产精品77777| 2025中文字幕| 国产成人免费网站| 无码人妻一区二区三区精品视频| 国产中文字幕一区| 男女视频在线观看网站| 国产麻豆精品久久一二三| 日本中文字幕在线不卡| 国产精品99久久久久久久vr| 日韩不卡的av| 国产福利一区在线| 少妇搡bbbb搡bbb搡打电话| 成人自拍视频在线| 日本免费福利视频| 91蝌蚪porny| 国产三级av在线播放| 国产蜜臀av在线一区二区三区| 免费网站在线高清观看| 国产欧美日韩不卡| 午夜激情福利电影| 一区二区三区资源| 国产一级免费观看| 狠狠躁夜夜躁人人爽天天天天97| av大全在线观看| 欧美视频一区二区三区| 国产精品福利电影| 精品国产人成亚洲区| 五月激情六月婷婷| 国产一区二区三区毛片| 免费看美女视频在线网站| 久久精品电影网| 天使と恶魔の榨精在线播放| 97av在线播放| 天堂久久午夜av| 91精品国产91久久久久青草| 99精品中文字幕在线不卡| 国产一区二区黄色| 欧美日韩色图| 天堂а√在线中文在线| 亚洲精品1234| 亚洲污视频在线观看| 国产在线麻豆精品观看| 中国黄色片视频| 国产亚洲欧美日韩日本| 日本一级二级视频| 欧美日韩国产专区| 国产精品伦一区二区三区| 精品国产乱码久久久久久闺蜜| 女人偷人在线视频| 欧美xxxx做受欧美.88| 日韩电影毛片| 91久久精品视频| 亚洲高清极品| 免费看污污视频| 天堂一区二区在线| 一二三区视频在线观看| 国产亚洲短视频| 国产精品.www| 欧美精选午夜久久久乱码6080| 国产成人手机在线| 日韩一区二区av| 中文字幕在线看片| 97se视频在线观看| 精品九九在线| 奇米影视亚洲色图| 国产一区二区三区免费观看| 亚洲国产欧美视频| 一区二区三区在线视频免费| 亚洲欧美一二三区| 精品国产乱码久久| 黄网页在线观看| 国产精品久久久久久久久久99 | 日韩成人影音| 国产无套精品一区二区| 天天综合一区| 韩国中文字幕av| 91亚洲精品久久久蜜桃| 中文字幕在线观看成人| 欧美三级视频在线观看| 天堂在线观看av| 欧美国产精品日韩| 疯狂欧洲av久久成人av电影| 欧美亚洲丝袜| 99热免费精品在线观看| 91蝌蚪视频在线| 中文字幕一区二区不卡| 日本熟妇一区二区三区| 亚洲高清福利视频| 欧美xxx黑人xxx水蜜桃| 成人在线播放av| 日韩一区二区在线| 性欧美videossex精品| 久久奇米777| 青青青国产在线| 亚洲电影av在线| av资源一区| 精品人伦一区二区三区| 亚洲国产三级| 人妻 日韩 欧美 综合 制服| 亚洲一卡二卡三卡四卡| www三级免费| 欧美激情三级免费| jazzjazz国产精品久久| 久久香蕉视频网站| 丰满岳乱妇一区二区三区| 精品无码一区二区三区电影桃花| 日韩三级.com| 好久没做在线观看| 久久99精品久久久久久久久久 | 五月天丁香花婷婷| 亚洲天堂网中文字| a级片免费观看| 欧美另类高清videos| 中文字幕一区二区三区日韩精品| 特大黑人娇小亚洲女mp4| 国产精品一区二区在线观看不卡| 色婷婷粉嫩av| 欧美一级高清片在线观看| 青青草原av在线| 久久av一区二区三区漫画| 国产农村妇女精品一区二区| 成人精品999| 欧美日韩三级在线| www视频在线看| 国产精品久久亚洲| 香蕉久久国产| 你懂得视频在线观看| 制服丝袜在线91| 国产精品一品| 日韩videos| 极品少妇一区二区三区精品视频 | 在线观看不卡| 久久av无码精品人妻系列试探| 欧美三级视频在线| 日本高清在线观看| 久久精品午夜一区二区福利| 久热精品在线| 日韩精品一区二区亚洲av性色| 欧美mv日韩mv| 日韩网站中文字幕| 7777在线视频| 91色|porny| 一卡二卡在线视频| 欧美极品欧美精品欧美视频| 国产一区二区三区四区| 久久久九九九热| 欧美日韩一区二区在线| 男人的天堂在线视频免费观看| 成人区精品一区二区| 亚洲欧美日本国产专区一区| 亚洲怡红院在线观看| 日韩黄色中文字幕| 成人h精品动漫一区二区三区| 97久久久久久久| 在线观看日韩av| 99国产精品久久一区二区三区| 韩国日本在线视频| 亚洲美女免费视频| 国产午夜在线观看| 国产精品久久国产精品| 免费视频最近日韩| 中文字幕日韩一级| 久久久精品中文字幕| 九色精品91| 久久性爱视频网站| 91精品国产欧美一区二区18|