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

Java高進進階之FastThreadLocal源碼詳解(修復ThreadLocal的缺陷)

開發(fā) 前端
在Netty中,要使用 FastThreadLocal 實現(xiàn)線程本地變量需要將線程包裝成 FastThreadLocalThread ,如果不是 FastThreadLocalThread ,會使用 slowThreadLocalMap的 ThreadLocal 來存儲變量副本。

[[423590]]

前言

ThreadLocal被ThreadLocalMap中的entry的key弱引用,如果出現(xiàn)GC的情況時,

沒有被其他對象引用,會被回收,但是ThreadLocal對應的value卻不會回收,容易造成內存泄漏,這也間接導致了內存溢出以及數(shù)據(jù)假丟失;

那么問題來了,有沒有更高效的ThreadLocal有;

今天我們就來分析一波FastThreadLocalThread

一、FastThreadLocalThread源碼分析

Netty為了在某些場景下提高性能,改進了jdk ThreadLocal,Netty實現(xiàn)的FastThreadLocal 優(yōu)化了Java 原生 ThreadLocal 的訪問速度,存儲速度。避免了檢測弱引用帶來的 value 回收難問題,和數(shù)組位置沖突帶來的線性查找問題,解決這些問題并不是沒有代價;

Netty實現(xiàn)的 FastThreadLocal 底層也是通過數(shù)組存儲 value 對象,與Java原生ThreadLocal使用自身作為Entry的key不同,F(xiàn)astThreadLocal通過保存數(shù)組的全局唯一下標,實現(xiàn)了對value的快速訪問。同時FastThreadLocal 也實現(xiàn)了清理對象的方法;

1、FastThreadLocalThread

在Netty中,要使用 FastThreadLocal 實現(xiàn)線程本地變量需要將線程包裝成 FastThreadLocalThread ,如果不是 FastThreadLocalThread ,會使用 slowThreadLocalMap的 ThreadLocal 來存儲變量副本;

  1. io.netty.util.concurrent.DefaultThreadFactory 
  2. @Override 
  3. public Thread newThread(Runnable r) { 
  4.     Thread t = newThread(FastThreadLocalRunnable.wrap(r), prefix + nextId.incrementAndGet()); 
  5.     // 一般daemon為false,意思是不設置為守護線程 
  6.     if (t.isDaemon() != daemon) { 
  7.         t.setDaemon(daemon); 
  8.     } 
  9.     // 優(yōu)先級 默認為5 
  10.     if (t.getPriority() != priority) { 
  11.         t.setPriority(priority); 
  12.     } 
  13.     return t; 
  14. protected Thread newThread(Runnable r, String name) { 
  15.     return new FastThreadLocalThread(threadGroup, r, name); 

FastThreadLocalThread 繼承自Thread類,有如下成員變量:

  1. io.netty.util.concurrent.FastThreadLocalThread 
  2. // 任務執(zhí)行完,是否清除FastThreadLocal的標記 
  3. private final boolean cleanupFastThreadLocals; 
  4. // 類似于Thread類中ThreadLocalMap,為了實現(xiàn)FastThreadLocal 
  5. private InternalThreadLocalMap threadLocalMap; 

2、 InternalThreadLocalMap

FastThreadLocalThread.threadLocalMap 是 InternalThreadLocalMap 對象實例。在第一次獲取FTL數(shù)據(jù)時,會初始化FastThreadLocalThread.threadLocalMap,調用的構造函數(shù)如下:

  1. private InternalThreadLocalMap() { 
  2.             //為了簡便,InternalThreadLocalMap父類 
  3.             //UnpaddedInternalThreadLocalMap不展開介紹 
  4.             super(newIndexedVariableTable()); 
  5.         } 
  6.         //默認的數(shù)組大小為32,且使用UNSET對象填充數(shù)組 
  7.         //如果下標處數(shù)據(jù)為UNSET,則表示沒有數(shù)據(jù) 
  8.         private static Object[] newIndexedVariableTable() { 
  9.             Object[] array = new Object[32]; 
  10.             Arrays.fill(array, UNSET); 
  11.             return array; 
  12.         } 

為了避免寫時候影響同一cpu緩沖行的其他數(shù)據(jù)并發(fā)訪問,其使用了緩存行填充技術 (cpu 緩沖行填充),在類定義中聲明了如下long字段進行填充;

  1. //InternalThreadLocalMap 
  2. // Cache line padding (must be public)  
  3. // With CompressedOops enabled, an instance of this class should occupy at least 128 bytes.  
  4. public long rp1, rp2, rp3, rp4, rp5, rp6, rp7, rp8, rp9; 

FTL使用的數(shù)組下標是InternalThreadLocalMap中的靜態(tài)變量nextIndex統(tǒng)一遞增生成的:

  1. static final AtomicInteger nextIndex = new AtomicInteger(); 
  2. public static int nextVariableIndex() { 
  3.     //Netty中所有FTL數(shù)組下標都是通過遞增這個靜態(tài)變量實現(xiàn)的 
  4.     //采用靜態(tài)變量生成所有FTL元素在數(shù)組中的下標會造成一個問題, 
  5.     //會造成InternalThreadLocalMap中數(shù)組不必要的自動擴容 
  6.     int index = nextIndex.getAndIncrement(); 
  7.     if (index < 0) { 
  8.         nextIndex.decrementAndGet(); 
  9.         throw new IllegalStateException("too many thread-local indexed variables"); 
  10.     } 
  11.     return index

InternalThreadLocalMap.nextVariableIndex()方法獲取FTL在該FastThreadLocalThread.threadLocalMap數(shù)組下標,因為InternalThreadLocalMap.nextVariableIndex() 使用靜態(tài)域 nextIndex 遞增維護所有FTL的下標,會造成后面實例化的 FTL 下標過大,如果FTL下標大于其對應 FastThreadLocalThread.threadLocalMap 數(shù)組的長度,會進行數(shù)組的自動擴容,如下:

  1. private void expandIndexedVariableTableAndSet(int index, Object value) { 
  2.     Object[] oldArray = indexedVariables; 
  3.     final int oldCapacity = oldArray.length; 
  4.     //下面復雜的實現(xiàn)是為了將newCapacity規(guī)范為最接近的一個2的指數(shù),  
  5.     //這段代碼在早期的 jdk HashMap 中見過 
  6.     int newCapacity = index
  7.     newCapacity |= newCapacity >>>  1; 
  8.     newCapacity |= newCapacity >>>  2; 
  9.     newCapacity |= newCapacity >>>  4; 
  10.     newCapacity |= newCapacity >>>  8; 
  11.     newCapacity |= newCapacity >>> 16; 
  12.     newCapacity ++; 
  13.     Object[] newArray = Arrays.copyOf(oldArray, newCapacity); 
  14.     Arrays.fill(newArray, oldCapacity, newArray.length, UNSET); 
  15.     newArray[index] = value; 
  16.     indexedVariables = newArray; 

3、FastThreadLocal

構造函數(shù):

有兩個重要的下標域,F(xiàn)TL不僅在FastThreadLocalThread.threadLocalMap中保存了用戶實際使用的value(在數(shù)組中的下標為index),還在數(shù)組中保存為了實現(xiàn)清理記錄的相關數(shù)據(jù),也即下標variablesToRemoveIndex,一般情況 variablesToRemoveIndex = 0;因為variablesToRemoveIndex 是靜態(tài)變量,所以全局唯一;

  1. //如果在該FTL中放入了數(shù)據(jù),也就實際調用了其set或get函數(shù),會在 
  2.        //該FastThreadLocalThread.threadLocalMap數(shù)組的 
  3.        // variablesToRemoveIndex下標處放置一個IdentityHashMap, 
  4.        //并將該FTL放入IdentityHashMap中,在后續(xù)清理時會取出 
  5.        //variablesToRemoveIndex下標處的IdentityHashMap進行清理 
  6.         private static final int variablesToRemoveIndex = InternalThreadLocalMap.nextVariableIndex(); 
  7.        //在threadLocalMap數(shù)組中存放實際數(shù)據(jù)的下標 
  8.         private final int index
  9.         public FastThreadLocal() { 
  10.             index = InternalThreadLocalMap.nextVariableIndex(); 
  11.         } 

用戶可擴展的函數(shù):

  1. //初始化 value 函數(shù) 
  2. protected V initialValue() throws Exception { 
  3.     return null
  4. //讓使用者在該FTL被移除時可以有機會做些操作。 
  5. protected void onRemoval(@SuppressWarnings("UnusedParameters") V value) throws Exception { } 

FastThreadLocalThread

cleanupFastThreadLocals 字段在 4.1 的最新版本中已經沒有在用到了

  1. /** 
  2.  * true,表示FTL會在線程結束時被主動清理 見  FastThreadLocalRunnable 類 
  3.  * false,需要將FTL放入后臺清理線程的隊列中 
  4.  */ 
  5. // This will be set to true if we have a chance to wrap the Runnable. 
  6. //這個字段則用于標識該線程在結束時是否會主動清理FTL 
  7. private final boolean cleanupFastThreadLocals; 
  8. //次對象將在 第一次 FastThreadLocal.get 和 FastThreadLocal.set 時候創(chuàng)建 
  9. private InternalThreadLocalMap threadLocalMap; 
  10. public FastThreadLocalThread(Runnable target) { 
  11.     super(FastThreadLocalRunnable.wrap(target)); 
  12.     cleanupFastThreadLocals = true

4、 set 方法

  1. public final void set(V value) { 
  2.     //判斷設置的 value 值是否是缺省值 
  3.     if (value != InternalThreadLocalMap.UNSET) { 
  4.         //獲取當前線程的 InternalThreadLocalMap , 如果當前線程為FastThreadLocalThread,那么直接通過threadLocalMap引用獲取 
  5.         //否則通過 jdk 原生的 threadLocal 獲取 
  6.         InternalThreadLocalMap threadLocalMap = InternalThreadLocalMap.get(); 
  7.         //FastThreadLocal 對應的 index 下標的 value 替換成新的 value 
  8.         setKnownNotUnset(threadLocalMap, value); 
  9.     } else { 
  10.         //如果放置的對象為UNSET,則表示清理,會對該FTL進行清理,類似毒丸對象 
  11.         remove(); 
  12.     } 

這里擴容方會調用 InternalThreadLocalMap.expandIndexedVariableTableAndSet

  1. private void setKnownNotUnset(InternalThreadLocalMap threadLocalMap, V value) { 
  2.     //在數(shù)組下標index處放置實際對象,如果index大于數(shù)組length,會進行數(shù)組擴容. 
  3.     if (threadLocalMap.setIndexedVariable(index, value)) { 
  4.         //放置成功之后,將該FTL加入到 variablesToRemoveIndex 下標的 
  5.         //IdentityHashMap,等待后續(xù)清理 
  6.         addToVariablesToRemove(threadLocalMap, this); 
  7.     } 
  1. /** 
  2.  * 該FTL加入到variablesToRemoveIndex下標的IdentityHashMap 
  3.  * IdentityHashMap的特性可以保證同一個實例不會被多次加入到該位置 
  4.  */ 
  5. @SuppressWarnings("unchecked"
  6. private static void addToVariablesToRemove(InternalThreadLocalMap threadLocalMap, FastThreadLocal<?> variable) { 
  7.     //獲取 variablesToRemoveIndex下標處的 IdentityHashMap 
  8.     Object v = threadLocalMap.indexedVariable(variablesToRemoveIndex); 
  9.     Set<FastThreadLocal<?>> variablesToRemove; 
  10.     //如果是第一次獲取,則 variablesToRemoveIndex下標處的值為 UNSET 
  11.     if (v == InternalThreadLocalMap.UNSET || v == null) { 
  12.         //新建一個新的 IdentityHashMap 并 
  13.         variablesToRemove = Collections.newSetFromMap(new IdentityHashMap<FastThreadLocal<?>, Boolean>()); 
  14.         //放入到下標variablesToRemoveIndex處 
  15.         threadLocalMap.setIndexedVariable(variablesToRemoveIndex, variablesToRemove); 
  16.     } else { 
  17.         variablesToRemove = (Set<FastThreadLocal<?>>) v; 
  18.     } 
  19.     //將該FTL放入該IdentityHashMap中 
  20.     variablesToRemove.add(variable); 

下面看InternalThreadLocalMap.get()實現(xiàn):

  1. public static InternalThreadLocalMap get() { 
  2.     Thread thread = Thread.currentThread(); 
  3.     //首先看當前 thread 是否為FastThreadLocalThread實例 
  4.     //如果是的話,可以快速通過引用,獲取到其 threadLocalMap 
  5.     if (thread instanceof FastThreadLocalThread) { 
  6.         return fastGet((FastThreadLocalThread) thread); 
  7.     } else { 
  8.         //如果不是,則 jdk 原生慢速獲取到其 threadLocalMap 
  9.         return slowGet(); 
  10.     } 

5、 get 方法

get方法極為簡單,實現(xiàn)如下:

  1. ===========================FastThreadLocal========================== 
  2. public final V get() { 
  3.         InternalThreadLocalMap threadLocalMap = InternalThreadLocalMap.get(); 
  4.         Object v = threadLocalMap.indexedVariable(index); 
  5.         if (v != InternalThreadLocalMap.UNSET) { 
  6.             return (V) v; 
  7.         } 
  8.         return initialize(threadLocalMap); 
  9.     } 

首先獲取當前線程的map,然后根據(jù) FastThreadLocal的index 獲取value,然后返回,如果是空對象,則通過 initialize 返回,initialize 方法會將返回值設置到 map 的槽位中,并放進 Set 中;

  1. initialize 
  2. ============================FastThreadLocal========================== 
  3. private V initialize(InternalThreadLocalMap threadLocalMap) { 
  4.     V v = null
  5.     try { 
  6.         //1、獲取初始值 
  7.         v = initialValue(); 
  8.     } catch (Exception e) { 
  9.         throw new RuntimeException(e); 
  10.     } 
  11.     // 2、設置value到InternalThreadLocalMap中 
  12.     threadLocalMap.setIndexedVariables(index, v); 
  13.     // 3、添加當前的FastThreadLocal到InternalThreadLocalMap的Set<FastThreadLocal<?>>中 
  14.     addToVariablesToRemove(threadLocalMap, this); 
  15.     return v; 
  16. //初始化參數(shù):由子類復寫 
  17. protected V initialValue() throws Exception { 
  18.     return null
  • 獲取 ThreadLocalMap
  • 直接通過索引取出對象
  • 如果為空那么調用初始化方法初始化

6、ftl的資源回收機制

netty中ftl的兩種回收機制回收機制:

自動:使用ftlt執(zhí)行一個被FastThreadLocalRunnable wrap的Runnable任務,在任務執(zhí)行完畢后會自動進行ftl的清理;

手動:ftl和InternalThreadLocalMap都提供了remove方法,在合適的時候用戶可以(有的時候也是必須,例如普通線程的線程池使用ftl)手動進行調用,進行顯示刪除;

  1. FastThreadLocalRunnable 
  2. final class FastThreadLocalRunnable implements Runnable { 
  3.     private final Runnable runnable; 
  4.     @Override 
  5.     public void run() { 
  6.         try { 
  7.             runnable.run(); 
  8.         } finally { 
  9.             FastThreadLocal.removeAll(); 
  10.         } 
  11.     } 
  12.     static Runnable wrap(Runnable runnable) { 
  13.         return runnable instanceof FastThreadLocalRunnable  
  14.                 ? runnable : new FastThreadLocalRunnable(runnable); 
  15.     } 

如果將線程執(zhí)行的任務包裝成 FastThreadLocalRunnable,那么在任務執(zhí)行完后自動刪除ftl的資源。

  1. ===============================FastThreadLocal=========================== 
  2. public static void removeAll() { 
  3.     // 獲取到map 
  4.     InternalThreadLocalMap threadLocalMap = InternalThreadLocalMap.getIfSet(); 
  5.     if (threadLocalMap == null) { 
  6.         return
  7.     } 
  8.     try { 
  9.         // 獲取到Set<FastThreadLocal>集合 
  10.         Object v = threadLocalMap.indexedVariable(variablesToRemoveIndex); 
  11.         if (v != null && v != InternalThreadLocalMap.UNSET) { 
  12.             @SuppressWarnings("unchecked"
  13.             Set<FastThreadLocal<?>> variablesToRemove = (Set<FastThreadLocal<?>>) v; 
  14.             // 將Set轉換為數(shù)組 
  15.             FastThreadLocal<?>[] variablesToRemoveArray = 
  16.                     variablesToRemove.toArray(new FastThreadLocal[variablesToRemove.size()]); 
  17.             // 遍歷數(shù)組,刪除每一個FastThreadLocal對應的value 
  18.             for (FastThreadLocal<?> tlv: variablesToRemoveArray) { 
  19.                 tlv.remove(threadLocalMap); 
  20.             } 
  21.         } 
  22.     } finally { 
  23.         // 刪除當前線程的InternalThreadLocalMap 
  24.         InternalThreadLocalMap.remove(); 
  25.     } 
  26. public static void remove() { 
  27.     Thread thread = Thread.currentThread(); 
  28.     if (thread instanceof FastThreadLocalThread) { 
  29.          // 將FastThreadLocalThread 內部的map置位null 
  30.         ((FastThreadLocalThread) thread).setThreadLocalMap(null); 
  31.     } else { 
  32.         // 將 ThreadLocal內部ThreadLocalMap 中的value置位null 
  33.         slowThreadLocalMap.remove(); 
  34.     } 

remove方法:

  1. ===============================FastThreadLocal========================== 
  2. private void remove() { 
  3.     remove(InternalThreadLocalMap.getIfSet()); 
  4. private void remove(InternalThreadLocalMap threadLocalMap) { 
  5.     if (threadLocalMap == null) { 
  6.         return
  7.     } 
  8.     // 從 InternalThreadLocalMap 中刪除當前的FastThreadLocal對應的value并設UNSET 
  9.     Object v = threadLocalMap.removeIndexedVariable(index); 
  10.     // 從 InternalThreadLocalMap 中的Set<FastThreadLocal<?>>中刪除當前的FastThreadLocal對象 
  11.     removeFromVariablesToRemove(threadLocalMap, this); 
  12.     // 如果刪除的是有效值,則進行onRemove方法的回調 
  13.     if (v != InternalThreadLocalMap.UNSET) { 
  14.         try { 
  15.             // 回調子類復寫的onRemoved方法,默認為空實現(xiàn) 
  16.             onRemoved((V) v); 
  17.         } catch (Exception e) { 
  18.             throw new RuntimeException(e); 
  19.         } 
  20.     } 

總結

只有不斷的學習,不斷的找到自己的缺點才可以進步;

一起加油;

 

責任編輯:武曉燕 來源: Android開發(fā)編程
相關推薦

2020-11-04 13:01:38

FastThreadLocalJDK

2021-09-12 07:30:10

配置

2021-09-02 07:00:01

Glide流程Android

2021-09-07 06:40:25

AndroidLiveData原理

2021-09-01 06:48:16

AndroidGlide緩存

2021-08-10 20:41:33

AndroidApp流程

2015-09-09 08:45:49

JavaThreadLocal

2024-10-28 08:15:32

2021-08-17 13:41:11

AndroidView事件

2021-10-29 08:19:54

JMeterJava java sample

2021-09-03 07:27:38

AndroidGlide管理

2023-10-07 08:26:40

多線程數(shù)據(jù)傳遞數(shù)據(jù)共享

2021-08-05 20:39:34

AndroidKotlinStandard.kt

2021-09-05 07:35:58

lifecycleAndroid組件原理

2021-08-25 07:43:17

AndroidSurfaceViewTextureView

2012-01-13 16:11:44

2024-11-18 16:15:00

2021-09-09 06:55:43

AndroidViewDragHel原理

2021-09-11 07:32:15

Java線程線程池

2021-09-18 06:56:01

JavaCAS機制
點贊
收藏

51CTO技術棧公眾號

久久综合久久鬼色| 天天色天天综合网| 日韩欧美99| 精品国产乱码一区二区三区 | 欧美精品日韩三级| 精品久久免费观看| www.中文字幕在线观看| 亚洲影视资源| 久久精子c满五个校花| 欧美日韩精品一区二区三区 | 国产清纯在线一区二区www| 精品国产区一区二区三区在线观看 | 91成人在线播放| 亚洲欧美国产中文| 国产裸舞福利在线视频合集| 黄色录像特级片| 逼特逼视频在线| 国产黄频在线观看| 国产大片一区| 色综合久久综合| 精品视频一区在线| 日本最新中文字幕| 精品综合久久88少妇激情| 亚洲色图丝袜美腿| 国产精品一区二区三| www.久久国产| 欧美人体一区二区三区| 久久先锋影音av| 亚洲成av人片在线| 欧美夫妻性视频| 污污视频网站在线| 无遮挡爽大片在线观看视频| 日本美女视频一区二区| 999精品视频在线观看| 99久久久国产精品免费蜜臀| 久99九色视频在线观看| 中文字幕在线视频一区二区三区| 日本三级在线视频| 国产精品久久久久久久成人午夜 | jizz国产精品| 中文字幕亚洲不卡| 亚洲精品资源| 涩涩涩久久久成人精品| 成人a区在线观看| 久久久久久久久国产精品| 69**夜色精品国产69乱| 亚洲少妇一区二区三区| 美足av综合网| 成人午夜看片网址| 欧美在线一区二区视频| 青青草成人免费视频| 写真福利精品福利在线观看| 久久女同性恋中文字幕| 日本一区福利在线| 欧美一二三区在线| 韩剧1988免费观看全集| 日韩精品一区二区三区高清免费| av成人影院在线| 久久影院电视剧免费观看| 国产免费一区二区三区| 九九热最新视频| 欧美综合一区| 欧美一区二区精品久久911| 91午夜在线观看| 亚洲欧美色视频| 男女性色大片免费观看一区二区 | 亚洲国产精品人人做人人爽| 另类视频在线观看+1080p| 在线免费一区二区| 国产精品99免费看| 一区二区三区欧美亚洲| 黄色在线成人| 亚洲精品免费电影| 青少年xxxxx性开放hg| 乱人伦中文视频在线| 成人h动漫精品一区二区| 国产九色精品| 在线免费观看一区二区| 成人黄色在线观看视频| 成人福利免费在线观看| 亚洲第一精品福利| 成年人在线观看视频免费| 岛国成人毛片| 国产三级欧美三级日产三级99| 97中文在线观看| 中文字幕一区二区在线视频| 影音先锋久久精品| 久久久国产精彩视频美女艺术照福利| 国产在线观看无码免费视频| 影视先锋久久| 亚洲国产精品小视频| 加勒比av中文字幕| 成人av影音| 亚洲人成在线播放| 久久免费精品国产| 久久gogo国模啪啪裸体| 亚洲国产91色在线| 免费在线观看a视频| 亚洲精品白浆高清| 色噜噜久久综合伊人一本| 性久久久久久久久久| 日韩欧美精品一区| 夜夜嗨av一区二区三区四区| aaaaaav| 青青草综合网| 久久久久久高潮国产精品视| 日韩妆和欧美的一区二区| 亚洲AV成人无码精电影在线| 青草久久视频| 日韩一级黄色av| 日韩三级小视频| 精品1区2区3区4区| 国产精品男女猛烈高潮激情| 无码人妻av免费一区二区三区| 亚洲影院在线| 欧美中文字幕在线观看| av免费观看在线| 国产婷婷色一区二区三区| www成人免费| 国产网红在线观看| 亚洲午夜一区二区三区| 成人免费在线网| 久久人体av| 在线播放亚洲一区| 97免费公开视频| 91久久精品无嫩草影院| 亚洲国产精品va在线看黑人动漫| 亚洲不卡的av| 91精品高清| 欧美高清videos高潮hd| 在线播放精品视频| 久久久久国产精品免费免费搜索| 性欧美办公室18xxxxhd| 在线免费观看成人短视频| 午夜精品久久99蜜桃的功能介绍| 极品在线视频| 91黄色在线视频| 朝桐光av一区二区三区| www.玖玖玖| 路边理发店露脸熟妇泻火| 99精品视频网站| caoporn国产精品免费视频| 国产成人激情av| 国产精品久久7| www久久日com| 欧美一区二区视频在线观看2022 | 91精品福利观看| 极品中文字幕一区| 成人综合国产精品| 欧美一级黄视频| 2023国产精品自拍| 亚洲自偷自拍熟女另类| 美女视频亚洲色图| 97视频网站入口| 亚洲人成色777777精品音频| 亚洲国产综合色| 欧美xxxx×黑人性爽| 视频国产一区| 欧美freesextv| 一个色妞综合视频在线观看| 日韩成人手机在线| 一区二区三区自拍视频| 色综合五月天导航| 色婷婷一区二区三区av免费看| 超碰免费公开在线| 7777精品伊人久久久大香线蕉 | 久久久久久久香蕉网| 精品少妇在线视频| h色网站在线观看| 欧美女激情福利| 亚洲自拍偷拍第一页| 青青草免费在线| 亚洲女同ⅹxx女同tv| 91视频最新入口| 久久最新网址| 成人观看高清在线观看免费| 色综合888| 欧美在线观看一区二区| 黄色av网址在线观看| 亚洲欧美日韩视频二区| 亚洲福利av在线| 黄色污网站在线观看| 亚洲人成网7777777国产| 影音先锋黄色网址| 亚洲最大色网站| 中文字幕国产综合| 欧美日本一区| 欧美日韩国产区一| 亚洲午夜福利在线观看| 日本不卡视频在线观看| 久久精品国产精品亚洲精品色| jizz18欧美18| 日韩av大片在线| 九一国产精品视频| 亚洲精品大片| 久久久久久久久久久久av| 欧美孕妇性xxxⅹ精品hd| 欧美猛男男办公室激情| 久久视频精品在线观看| 国产综合久久久久久久久久久久| 日本一区免费| 欧美黑人巨大xxxxx| 久久精品久久久久| 天堂在线一二区| 午夜精品免费在线观看| 日本在线观看网址| eeuss影院一区二区三区| 亚洲娇小娇小娇小| 亚洲欧美激情诱惑| 91国在线高清视频| 深夜激情久久| 欧美黑人xxxx| 91涩漫在线观看| 欧美日韩国产在线播放网站| 国产第一页第二页| 国产成a人亚洲精品| 天天操天天爱天天爽| 亚洲伦伦在线| 在线观看污视频| 欧美综合另类| 欧美日韩精品中文字幕一区二区| xxxxxx欧美| 亚洲男人的天堂在线| 国产视频1区2区| 国产区在线观看成人精品| 四季av综合网站| 国产精品一区二区在线看| 国产手机免费视频| 亚洲最新色图| 国产精品日本一区二区| www 久久久| 国产色综合天天综合网| 色呦呦在线观看视频| 亚洲精品999| 国产高潮在线观看| 91麻豆精品91久久久久久清纯| 69av视频在线观看| 日韩欧美中文字幕在线播放| 99精品全国免费观看| 国产一区二区三区国产| 三上悠亚在线一区二区| 日本在线不卡视频一二三区| 国产精品免费成人| 亚洲自拍偷拍网| 香蕉视频在线网址| 亚洲女同中文字幕| 国产美女视频免费| 亚洲精品888| 久久免费一级片| 午夜久久影院| 精品国偷自产一区二区三区| 在线播放不卡| 男人用嘴添女人下身免费视频| 在线看片一区| 亚洲中文字幕无码中文字| 久久不射2019中文字幕| 日韩视频在线观看视频| 中文av一区| 激情五月六月婷婷| 亚洲国产专区校园欧美| 131美女爱做视频| 翔田千里一区二区| 蜜臀视频一区二区三区| 欧美日韩亚洲三区| 欧美精品久久久久久久自慰| 国产精品毛片一区二区三区| 日韩亚洲欧美综合| 久久综合色影院| 欧美与黑人午夜性猛交久久久| 激情久久av| 欧洲av一区二区三区| 中国精品一区二区| 成人精品国产亚洲| 中文字幕一区二区三区在线视频| 亚洲婷婷综合久久一本伊一区 | 日韩在线观看高清| 国产福利第一视频在线播放| 日韩中文字幕视频| 成人免费高清观看| 国产精品27p| 五月香视频在线观看| 欧美另类极品videosbestfree| 久草视频福利在线| av中文字幕在线观看第一页| 韩日欧美一区二区| 羞羞影院欧美| 亚洲最大的网站| 希岛爱理av免费一区二区| 国产精品国产自产拍高清av水多| 啦啦啦中文在线观看日本| 91高潮精品免费porn| 黄色精品视频| 国产69精品久久久久久| 成人国产一区| 国产精品初高中精品久久| 欧美精品三级在线| 久久日韩精品| 午夜欧洲一区| avove在线观看| 无码一区二区三区视频| 免费av观看网址| 一区二区三区福利| 欧美久久久久久久久久久久久| 日韩中文字幕91| 欧美日韩另类一区| 97精品在线观看| 国产在线黄色| 欧美一区二区免费| 亚洲av电影一区| 日日骚久久av| 久久婷婷国产91天堂综合精品| 亲子伦视频一区二区三区| 亚洲一区三区视频在线观看| 久久亚洲道色| 一区二区不卡在线视频 午夜欧美不卡' | 2021久久精品国产99国产精品| 成人在线视频免费看| 黑人巨大精品欧美一区二区小视频 | 成人女同在线观看| 国产精品久久色| 日本午夜精品| 国产精品久久久久9999爆乳| 韩国三级电影一区二区| 久久精品免费网站| 成人性生交大片免费看中文网站| 蜜桃av免费在线观看| 欧美香蕉大胸在线视频观看| 成人毛片在线精品国产| 日韩欧美不卡在线观看视频| 亚洲精品一区二区口爆| 日韩电影大片中文字幕| 精品亚洲综合| 亚洲**2019国产| 一区二区在线免费播放| 中国黄色录像片| 久久99久久99精品免视看婷婷| 国内精品国产三级国产aⅴ久| 风间由美一区二区三区在线观看| 成年人视频软件| 亚洲男人的天堂网| 国产精品乱码久久久| 日韩一区二区福利| 欧美大陆国产| 制服诱惑一区| 亚洲二区视频| 亚洲天堂av网站| 性做久久久久久免费观看 | 激情五月婷婷综合| 国精产品视频一二二区| 欧美日韩精品欧美日韩精品一| xxxxx日韩| 色呦呦国产精品| 日韩熟女一区二区| 亚洲日韩第一页| 欧美日韩国产网站| 视频在线99| 久久成人18免费观看| 国产性生活大片| 亚洲午夜国产一区99re久久| 成人激情四射网| 久久久久久综合网天天| 国产香蕉精品| 夜夜爽www精品| 精品一区二区三区在线播放| 99精品久久久久| 91成人免费网站| aⅴ在线视频男人的天堂| 国产在线999| 欧美激情综合色综合啪啪| 亚洲麻豆一区二区三区| 色综合一个色综合| 亚洲图片88| 国产精品免费一区二区三区在线观看| 日韩视频免费| 成人无码av片在线观看| 在线成人免费视频| 青草青在线视频| 免费在线观看一区二区| 久久精品国产网站| 91精彩刺激对白露脸偷拍| 91久久人澡人人添人人爽欧美| 成人免费一级视频| 2019中文字幕免费视频| 国产精品99久久免费| 久久综合九色综合97婷婷| 国产在线观看h| 欧美午夜不卡在线观看免费| av片在线观看网站| 国产精品高潮在线| 午夜国产一区二区| 特级特黄刘亦菲aaa级| 午夜影院日韩| 国语自产精品视频在线看| 五月天福利视频| 日韩女优人人人人射在线视频| 91九色精品| 一区二区不卡免费视频| 91 com成人网| 国偷自产一区二区免费视频| 强开小嫩苞一区二区三区网站|