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

Unsafe 與 ByteBuffer 那些事

開發 開發工具
sun.misc.Unsafe 是 JDK 原生提供的一個工具類,包含了很多在 Java 語言看來很 cool 的操作,例如內存分配與回收、CAS 操作、類實例化、內存屏障等。正如其命名一樣,由于其可以直接操作內存,執行底層系統調用,其提供的操作也是比較危險的。

[[429887]]

本文轉載自微信公眾號「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 的價值。我簡單列舉兩個場景:

序列化框架在使用反射無法創建對象時,可以嘗試使用 Unsafe 創建,作為兜底邏輯。

獲取包級別保護的類,再借助于反射機制,可以魔改一些源碼實現或者調用一些 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.  

總結

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

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

 

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

2013-04-12 09:41:52

MySQL 5.6

2022-06-05 13:51:47

SentinelOpenFeign服務熔斷

2017-12-08 10:20:45

FedoraLinux

2019-07-15 15:37:31

頁面緩存內存

2011-05-19 16:47:50

軟件測試

2012-05-01 08:06:49

手機

2024-02-04 17:03:30

2017-05-15 21:50:54

Linux引號

2011-12-02 10:32:23

Java

2020-09-23 09:07:16

特權賬號管理PAM網絡安全

2014-06-06 16:08:17

初志科技

2011-08-22 16:42:43

SqliteiPad

2015-05-28 14:02:09

JavaJava日志性

2010-07-26 11:02:19

Perl模式匹配

2015-09-14 09:16:17

iOS統計打點

2012-01-02 19:30:22

iPad

2020-07-29 08:14:59

云計算云遷移IT

2009-07-29 10:36:04

北電收購

2011-07-04 15:30:24

Qt 布局 GridLayout

2011-06-30 14:34:17

QT Tablewidge QTableWidg
點贊
收藏

51CTO技術棧公眾號

欧美一区二三区| 欧美亚洲综合久久| 久久青青草原| 波多野结衣mp4| 亚洲成人精品| 日韩精品丝袜在线| 亚洲免费av一区| 免费v片在线观看| 国产精品伦一区| 成人午夜电影在线播放| 99re国产在线| 欧美午夜不卡| 最近2019好看的中文字幕免费| 欧美老女人bb| 成人在线视频免费看| 亚洲午夜视频在线观看| 天堂资源在线亚洲资源| 天天摸夜夜添狠狠添婷婷| 久久99精品国产麻豆不卡| 97超级碰在线看视频免费在线看| 亚洲 欧美 变态 另类 综合| www.日日操| 欧美77777| 美女看a上一区| 777国产偷窥盗摄精品视频| 娇小11一12╳yⅹ╳毛片| 久久365资源| 欧美性大战xxxxx久久久| av免费观看大全| 在线三级中文| 中文字幕精品综合| 欧美精品一区二区视频 | 视频福利在线| 国产盗摄一区二区三区| 国产主播欧美精品| 波多野结衣激情视频| 亚洲激情影院| 欧美国产中文字幕| 免费视频一二三区| 永久亚洲成a人片777777| 色天天综合狠狠色| 免费看一级黄色| 精品国产91| 亚洲欧美一区二区三区在线| 国产性生活毛片| 超碰在线成人| 亚洲精品在线免费播放| 又黄又色的网站| 亚洲2区在线| 日韩免费视频线观看| 亚洲日本黄色片| 91麻豆精品| 3d动漫精品啪啪1区2区免费 | 午夜精品亚洲一区二区三区嫩草| 日韩大片b站免费观看直播| 成人sese在线| 国产日韩在线一区二区三区| 国产小视频一区| 暖暖视频在线免费观看| 99久久精品费精品国产风间由美| 亚洲天堂网在线观看| 蜜桃传媒一区二区亚洲av| 日本一道高清一区二区三区| 亚洲韩国欧洲国产日产av | 黄色av网站免费| 久久只有精品| 国产精品久久中文| 中文字幕第31页| 国产综合一区二区| 亚洲综合自拍一区| 日本免费一区视频| 久久亚洲精品小早川怜子| 日韩av电影在线观看| 在线免费观看黄| 一区二区三区色| av在线播放亚洲| 色8久久影院午夜场| 欧美麻豆精品久久久久久| 日本wwwxx| 日韩精品导航| 日韩中文av在线| 国产性一乱一性一伧一色| 一区二区国产在线观看| 国产精品精品一区二区三区午夜版 | 悠悠色在线精品| 妞干网视频在线观看| 亚洲女同志freevdieo| 欧美色老头old∨ideo| 性鲍视频在线观看| 欧美freesex8一10精品| 尤物九九久久国产精品的特点| 免费看特级毛片| 亚洲高清网站| 国产男人精品视频| 国内爆初菊对白视频| 国产午夜一区二区三区| 亚洲区成人777777精品| 精品久久一区二区三区蜜桃| av片免费播放| 91视频免费播放| 一区二区三区四区五区视频 | 国产成人精品亚洲线观看| 亚洲欧美日韩图片| 欧美黑吊大战白妞| 日韩综合小视频| 成人免费在线看片| 亚洲成人三级| 欧美三级xxx| 在线免费观看av网| 蜜桃国内精品久久久久软件9| 久久精品视频在线| 日韩电影在线观看一区二区| 国产成人三级在线观看| 日韩hmxxxx| 男人久久天堂| 欧美大片顶级少妇| 波多野结衣喷潮| 日韩激情中文字幕| 国产亚洲一区二区三区在线播放| 欧美激情二区| 欧洲视频一区二区| 日本黄色录像片| 女生裸体视频一区二区三区| 国产美女扒开尿口久久久| 日韩二区三区| 激情久久av一区av二区av三区| 亚洲免费黄色录像| 日本黄色精品| 国产精品高潮呻吟久久av无限| 亚洲欧洲视频在线观看| 一区二区不卡在线视频 午夜欧美不卡在 | 99电影网电视剧在线观看| 一级毛片视频在线观看| 日本精品一级二级| 亚洲第一成人网站| 国产精品夜夜夜| 精品福利影视| 久久一级免费视频| 天堂网av成人| 午夜精品视频在线| 亚洲高清视频在线播放| 一区二区三区中文字幕精品精品| 在线免费视频一区| 青青草成人影院| 国产99视频在线观看| 免费理论片在线观看播放老| 欧美日韩人人澡狠狠躁视频| av无码一区二区三区| 一本一本久久| 久久伊人一区| 中老年在线免费视频| 亚洲男人天堂网站| 无码人妻丰满熟妇区五十路| 99久久精品免费看| av动漫免费看| 欧美色女视频| 国产精品露脸自拍| 欧美性videos| 日韩一区二区在线观看视频播放| 欧美成人精品欧美一级| 成人av在线资源网| 又粗又黑又大的吊av| 国产精品一国产精品| 国产精品xxx视频| av在线播放av| 日韩一级视频免费观看在线| 久草资源在线视频| 99精品视频一区| 欧美黄色一级片视频| 不卡在线一区二区| 亚洲一区二区三| 国产精品69xx| 国产视频久久久久| 中文字幕人妻丝袜乱一区三区| 中文字幕在线不卡一区| 韩国三级丰满少妇高潮| 亚洲免费高清| 亚洲aⅴ天堂av在线电影软件| 日韩欧美激情| 久久久久久久av| 国产免费a∨片在线观看不卡| 欧美日韩日日摸| 精品少妇久久久| 久久久精品综合| www.桃色.com| 国产亚洲高清视频| 亚洲电影第三页| 久久草.com| 亚洲电影有码| 欧美猛交ⅹxxx乱大交视频| 无码精品人妻一区二区三区影院| 色婷婷激情久久| 午夜爱爱毛片xxxx视频免费看| 成人黄色在线视频| 色啦啦av综合| 亚洲欧美日韩视频二区| 国产91av视频在线观看| 精品视频在线你懂得| 国产精品一区=区| jizzjizz中国精品麻豆| 在线播放日韩精品| 丰满人妻妇伦又伦精品国产| 欧美日韩中文字幕一区二区| 久久免费视频99| 国产精品久久久久久亚洲伦| 日韩Av无码精品| 黑人精品欧美一区二区蜜桃| 女人喷潮完整视频| 欧美+日本+国产+在线a∨观看| 久久综合一区二区三区| 秋霞午夜一区二区三区视频| 国产999在线观看| jizz一区二区三区| 久久激情视频久久| 国产一二三区在线| 亚洲第一视频网站| 国产免费不卡视频| 欧美午夜精品免费| 91美女免费看| 亚洲一区二区在线免费观看视频| 538精品视频| 久久蜜臀精品av| 国产51自产区| 国产在线精品视频| 五月婷婷丁香色| 天堂午夜影视日韩欧美一区二区| 成人免费毛片在线观看| 亚洲成人精品| 中文字幕精品一区日韩| 精品美女久久久| 久久精品国产精品青草色艺| 黄色欧美网站| 国产精品一区二区你懂得| 精品国产第一国产综合精品| 国产精品香蕉av| 国产a亚洲精品| 国产精品扒开腿爽爽爽视频| 天堂中文av在线资源库| 91超碰caoporn97人人| 丰乳肥臀在线| 久久男人av资源网站| 污污视频在线看| 欧美另类高清videos| 菠萝菠萝蜜在线观看| 久久大大胆人体| 精品国产99久久久久久| 日韩精品一级二级 | 国产日韩在线观看一区| 欧美日韩一区二区三区四区 | 欧美6一10sex性hd| 久久91亚洲精品中文字幕奶水 | 欧美日韩国产在线观看网站 | 一个色综合网| 日本a级片在线观看| 一区二区三区网站 | 亚洲在线播放| 黑人糟蹋人妻hd中文字幕| 午夜综合激情| 天美星空大象mv在线观看视频| 日本视频一区二区三区| 少妇一级淫免费播放| 麻豆精品视频在线观看| 激情图片中文字幕| 风间由美一区二区三区在线观看| www.555国产精品免费| 91片黄在线观看| 国产亚洲精品熟女国产成人| 国产精品美女www爽爽爽| 992在线观看| 一区二区三区日韩精品视频| 国产无遮挡又黄又爽在线观看 | 精品中文字幕av| 日本不卡中文字幕| www.久久com| 99国产精品国产精品久久| 无码人妻精品一区二区中文| 国产精品日韩成人| 麻豆一区产品精品蜜桃的特点| 欧美日韩国产一区中文午夜| 亚洲av人无码激艳猛片服务器| 正在播放亚洲一区| 天天摸夜夜添狠狠添婷婷| 中文字幕亚洲一区二区三区| 91精品国产91久久久久久青草| 91极品视频在线| 国产成人亚洲一区二区三区| av资源站久久亚洲| 免费视频亚洲| 热久久最新地址| 国产美女精品| www.桃色.com| 久久中文字幕电影| 亚洲国产精品久| 国产精品一区一区| 国产精品99久久久久久久久久久久 | 日韩一区二区三区高清在线观看| 乱一区二区三区在线播放| 91视频久久| 成人免费aaa| 国产乱码字幕精品高清av| asian性开放少妇pics| 亚洲免费观看高清完整版在线观看 | 午夜精品福利一区二区三区蜜桃| 黄色一区二区视频| 亚洲国产精品久久久久| 欧美激情黑人| 国产97在线播放| 一区二区在线免费播放| 亚洲欧美99| 久久久久免费| 精人妻一区二区三区| 综合久久给合久久狠狠狠97色| 91视频免费网址| 精品成人一区二区三区| 免费a级在线播放| 国产91久久婷婷一区二区| 91蜜桃臀久久一区二区| 中文字幕中文字幕在线中心一区| 久久久国产亚洲精品| 中文字幕第3页| 亚洲免费视频中文字幕| 一本到在线视频| 中文日韩在线观看| 成人直播视频| 欧美极品一区二区| 中日韩视频在线观看| 中文字幕99页| 亚洲伊人色欲综合网| 99久久久久久久| 久久精品一本久久99精品| 99久久婷婷国产综合精品首页| 久久综合九色综合久99| 亚洲国产精品一区制服丝袜| 91人人澡人人爽| 亚洲精品日韩综合观看成人91| 国产露脸91国语对白| 日韩中文字幕免费视频| 视频一区在线免费看| 日本不卡一区二区三区在线观看| 亚洲欧美日韩视频二区| 国产麻豆xxxvideo实拍| 精品日韩中文字幕| 日韩av免费观影| 日韩美女免费视频| 精品国产一区二区三区噜噜噜| 国产无套内射久久久国产| 久久―日本道色综合久久| 亚洲天堂视频网站| 亚洲视频在线播放| 精品视频在线一区二区在线| 日韩欧美亚洲在线| 男女男精品网站| 永久免费看片视频教学| 6080yy午夜一二三区久久| www.久久ai| 波多野结衣一区二区三区在线观看| 欧美日韩国产亚洲一区| 久久久久久婷婷| 欧美日韩中文字幕| 黄视频在线观看免费| 国产精品亚洲网站| 欧美99在线视频观看| 粉嫩av四季av绯色av第一区| 男人的天堂在线免费视频| 5566成人精品视频免费| re久久精品视频| 日本人69视频| 一区二区日韩av| 婷婷视频在线观看| 日韩av123| 91综合在线| 成年人小视频在线观看| 欧美性生交大片免费| 3d成人动漫在线| 99中文字幕| 久久综合网络一区二区| 99自拍偷拍视频| 日韩欧美国产三级| 涩涩视频在线播放| 亚洲一区三区在线观看| 国产一区二区三区日韩| 自拍偷拍欧美亚洲| 日韩在线视频免费观看| 一区二区在线视频观看| 成人中文字幕av| 亚洲精品免费看| 免费福利在线观看| 国产日韩欧美视频| 精品1区2区3区4区| 国产馆在线观看| 亚洲高清在线观看| 黄色成人在线观看网站| 成人在线免费观看视频网站| 91蝌蚪porny| 国产精品一级视频| 欧洲成人免费aa| 国产精品久久久乱弄| 亚洲一区二区三区综合| 欧美日韩在线播放三区| 中文字幕12页|