国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

Java7和Java8中的ConcurrentHashMap原理解析

 更新時間:2021年04月23日 14:41:17   作者:JaJian  
這篇文章主要介紹了Java7和Java8中的ConcurrentHashMap原理解析,對ConcurrentHashMap感興趣的讀者,一定要好好看一下

Java7 中 ConcurrentHashMap

ConcurrentHashMap 和 HashMap 思路是差不多的,但是因為它支持并發(fā)操作,所以要復(fù)雜一些。

整個 ConcurrentHashMap 由一個個 Segment 組成,Segment 代表”部分“或”一段“的意思,所以很多地方都會將其描述為分段鎖。注意,行文中,我很多地方用了“槽”來代表一個 segment。

簡單理解就是,ConcurrentHashMap 是一個 Segment 數(shù)組,Segment 通過繼承 ReentrantLock 來進行加鎖,所以每次需要加鎖的操作鎖住的是一個 segment,這樣只要保證每個 Segment 是線程安全的,也就實現(xiàn)了全局的線程安全。

concurrencyLevel:并行級別、并發(fā)數(shù)、Segment 數(shù),怎么翻譯不重要,理解它。默認(rèn)是 16,也就是說 ConcurrentHashMap 有 16 個 Segments,所以理論上,這個時候,最多可以同時支持 16 個線程并發(fā)寫,只要它們的操作分別分布在不同的 Segment 上。這個值可以在初始化的時候設(shè)置為其他值,但是一旦初始化以后,它是不可以擴容的。

再具體到每個 Segment 內(nèi)部,其實每個 Segment 很像之前介紹的 HashMap,不過它要保證線程安全,所以處理起來要麻煩些。

初始化

initialCapacity:初始容量,這個值指的是整個 ConcurrentHashMap 的初始容量,實際操作的時候需要平均分給每個 Segment。

loadFactor:負(fù)載因子,之前我們說了,Segment 數(shù)組不可以擴容,所以這個負(fù)載因子是給每個 Segment 內(nèi)部使用的。

public ConcurrentHashMap(int initialCapacity,
                         float loadFactor, int concurrencyLevel) {
    if (!(loadFactor > 0) || initialCapacity < 0 || concurrencyLevel <= 0)
        throw new IllegalArgumentException();
    if (concurrencyLevel > MAX_SEGMENTS)
        concurrencyLevel = MAX_SEGMENTS;
    // Find power-of-two sizes best matching arguments
    int sshift = 0;
    int ssize = 1;
    // 計算并行級別 ssize,因為要保持并行級別是 2 的 n 次方
    while (ssize < concurrencyLevel) {
        ++sshift;
        ssize <<= 1;
    }
    // 我們這里先不要那么燒腦,用默認(rèn)值,concurrencyLevel 為 16,sshift 為 4
    // 那么計算出 segmentShift 為 28,segmentMask 為 15,后面會用到這兩個值
    this.segmentShift = 32 - sshift;
    this.segmentMask = ssize - 1;

    if (initialCapacity > MAXIMUM_CAPACITY)
        initialCapacity = MAXIMUM_CAPACITY;

    // initialCapacity 是設(shè)置整個 map 初始的大小,
    // 這里根據(jù) initialCapacity 計算 Segment 數(shù)組中每個位置可以分到的大小
    // 如 initialCapacity 為 64,那么每個 Segment 或稱之為"槽"可以分到 4 個
    int c = initialCapacity / ssize;
    if (c * ssize < initialCapacity)
        ++c;
    // 默認(rèn) MIN_SEGMENT_TABLE_CAPACITY 是 2,這個值也是有講究的,因為這樣的話,對于具體的槽上,
    // 插入一個元素不至于擴容,插入第二個的時候才會擴容
    int cap = MIN_SEGMENT_TABLE_CAPACITY; 
    while (cap < c)
        cap <<= 1;

    // 創(chuàng)建 Segment 數(shù)組,
    // 并創(chuàng)建數(shù)組的第一個元素 segment[0]
    Segment<K,V> s0 =
        new Segment<K,V>(loadFactor, (int)(cap * loadFactor),
                         (HashEntry<K,V>[])new HashEntry[cap]);
    Segment<K,V>[] ss = (Segment<K,V>[])new Segment[ssize];
    // 往數(shù)組寫入 segment[0]
    UNSAFE.putOrderedObject(ss, SBASE, s0); // ordered write of segments[0]
    this.segments = ss;
}

初始化完成,我們得到了一個 Segment 數(shù)組。

我們就當(dāng)是用 new ConcurrentHashMap() 無參構(gòu)造函數(shù)進行初始化的,那么初始化完成后:

  • Segment 數(shù)組長度為 16,不可以擴容
  • Segment[i] 的默認(rèn)大小為 2,負(fù)載因子是 0.75,得出初始閾值為 1.5,也就是以后插入第一個元素不會觸發(fā)擴容,插入第二個會進行第一次擴容
  • 這里初始化了 segment[0],其他位置還是 null,至于為什么要初始化 segment[0],后面的代碼會介紹
  • 當(dāng)前 segmentShift 的值為 32 - 4 = 28,segmentMask 為 16 - 1 = 15,姑且把它們簡單翻譯為移位數(shù)和掩碼,這兩個值馬上就會用到

put 過程分析

我們先看 put 的主流程,對于其中的一些關(guān)鍵細(xì)節(jié)操作,后面會進行詳細(xì)介紹。

public V put(K key, V value) {
    Segment<K,V> s;
    if (value == null)
        throw new NullPointerException();
    // 1. 計算 key 的 hash 值
    int hash = hash(key);
    // 2. 根據(jù) hash 值找到 Segment 數(shù)組中的位置 j
    //    hash 是 32 位,無符號右移 segmentShift(28) 位,剩下高 4 位,
    //    然后和 segmentMask(15) 做一次與操作,也就是說 j 是 hash 值的高 4 位,也就是槽的數(shù)組下標(biāo)
    int j = (hash >>> segmentShift) & segmentMask;
    // 剛剛說了,初始化的時候初始化了 segment[0],但是其他位置還是 null,
    // ensureSegment(j) 對 segment[j] 進行初始化
    if ((s = (Segment<K,V>)UNSAFE.getObject          // nonvolatile; recheck
         (segments, (j << SSHIFT) + SBASE)) == null) //  in ensureSegment
        s = ensureSegment(j);
    // 3. 插入新值到 槽 s 中
    return s.put(key, hash, value, false);
}

第一層皮很簡單,根據(jù) hash 值很快就能找到相應(yīng)的 Segment,之后就是 Segment 內(nèi)部的 put 操作了。

Segment 內(nèi)部是由 數(shù)組+鏈表 組成的。

final V put(K key, int hash, V value, boolean onlyIfAbsent) {
    // 在往該 segment 寫入前,需要先獲取該 segment 的獨占鎖
    //    先看主流程,后面還會具體介紹這部分內(nèi)容
    HashEntry<K,V> node = tryLock() ? null :
        scanAndLockForPut(key, hash, value);
    V oldValue;
    try {
        // 這個是 segment 內(nèi)部的數(shù)組
        HashEntry<K,V>[] tab = table;
        // 再利用 hash 值,求應(yīng)該放置的數(shù)組下標(biāo)
        int index = (tab.length - 1) & hash;
        // first 是數(shù)組該位置處的鏈表的表頭
        HashEntry<K,V> first = entryAt(tab, index);

        // 下面這串 for 循環(huán)雖然很長,不過也很好理解,想想該位置沒有任何元素和已經(jīng)存在一個鏈表這兩種情況
        for (HashEntry<K,V> e = first;;) {
            if (e != null) {
                K k;
                if ((k = e.key) == key ||
                    (e.hash == hash && key.equals(k))) {
                    oldValue = e.value;
                    if (!onlyIfAbsent) {
                        // 覆蓋舊值
                        e.value = value;
                        ++modCount;
                    }
                    break;
                }
                // 繼續(xù)順著鏈表走
                e = e.next;
            }
            else {
                // node 到底是不是 null,這個要看獲取鎖的過程,不過和這里都沒有關(guān)系。
                // 如果不為 null,那就直接將它設(shè)置為鏈表表頭;如果是null,初始化并設(shè)置為鏈表表頭。
                if (node != null)
                    node.setNext(first);
                else
                    node = new HashEntry<K,V>(hash, key, value, first);

                int c = count + 1;
                // 如果超過了該 segment 的閾值,這個 segment 需要擴容
                if (c > threshold && tab.length < MAXIMUM_CAPACITY)
                    rehash(node); // 擴容后面也會具體分析
                else
                    // 沒有達到閾值,將 node 放到數(shù)組 tab 的 index 位置,
                    // 其實就是將新的節(jié)點設(shè)置成原鏈表的表頭
                    setEntryAt(tab, index, node);
                ++modCount;
                count = c;
                oldValue = null;
                break;
            }
        }
    } finally {
        // 解鎖
        unlock();
    }
    return oldValue;
}

整體流程還是比較簡單的,由于有獨占鎖的保護,所以 segment 內(nèi)部的操作并不復(fù)雜。至于這里面的并發(fā)問題,我們稍后再進行介紹。

到這里 put 操作就結(jié)束了,接下來,我們說一說其中幾步關(guān)鍵的操作。

初始化槽: ensureSegment

ConcurrentHashMap 初始化的時候會初始化第一個槽 segment[0],對于其他槽來說,在插入第一個值的時候進行初始化。

這里需要考慮并發(fā),因為很可能會有多個線程同時進來初始化同一個槽 segment[k],不過只要有一個成功了就可以。

private Segment<K,V> ensureSegment(int k) {
    final Segment<K,V>[] ss = this.segments;
    long u = (k << SSHIFT) + SBASE; // raw offset
    Segment<K,V> seg;
    if ((seg = (Segment<K,V>)UNSAFE.getObjectVolatile(ss, u)) == null) {
        // 這里看到為什么之前要初始化 segment[0] 了,
        // 使用當(dāng)前 segment[0] 處的數(shù)組長度和負(fù)載因子來初始化 segment[k]
        // 為什么要用“當(dāng)前”,因為 segment[0] 可能早就擴容過了
        Segment<K,V> proto = ss[0];
        int cap = proto.table.length;
        float lf = proto.loadFactor;
        int threshold = (int)(cap * lf);

        // 初始化 segment[k] 內(nèi)部的數(shù)組
        HashEntry<K,V>[] tab = (HashEntry<K,V>[])new HashEntry[cap];
        if ((seg = (Segment<K,V>)UNSAFE.getObjectVolatile(ss, u))
            == null) { // 再次檢查一遍該槽是否被其他線程初始化了。

            Segment<K,V> s = new Segment<K,V>(lf, threshold, tab);
            // 使用 while 循環(huán),內(nèi)部用 CAS,當(dāng)前線程成功設(shè)值或其他線程成功設(shè)值后,退出
            while ((seg = (Segment<K,V>)UNSAFE.getObjectVolatile(ss, u))
                   == null) {
                if (UNSAFE.compareAndSwapObject(ss, u, null, seg = s))
                    break;
            }
        }
    }
    return seg;
}

總的來說,ensureSegment(int k) 比較簡單,對于并發(fā)操作使用 CAS 進行控制。

我沒搞懂這里為什么要搞一個 while 循環(huán),CAS 失敗不就代表有其他線程成功了嗎,為什么要再進行判斷?
感謝評論區(qū)的李子木,如果當(dāng)前線程 CAS 失敗,這里的 while 循環(huán)是為了將 seg 賦值返回。

獲取寫入鎖: scanAndLockForPut

前面我們看到,在往某個 segment 中 put 的時候,首先會調(diào)用 node = tryLock() ? null : scanAndLockForPut(key, hash, value),也就是說先進行一次 tryLock() 快速獲取該 segment 的獨占鎖,如果失敗,那么進入到 scanAndLockForPut 這個方法來獲取鎖。

下面我們來具體分析這個方法中是怎么控制加鎖的。

private HashEntry<K,V> scanAndLockForPut(K key, int hash, V value) {
    HashEntry<K,V> first = entryForHash(this, hash);
    HashEntry<K,V> e = first;
    HashEntry<K,V> node = null;
    int retries = -1; // negative while locating node

    // 循環(huán)獲取鎖
    while (!tryLock()) {
        HashEntry<K,V> f; // to recheck first below
        if (retries < 0) {
            if (e == null) {
                if (node == null) // speculatively create node
                    // 進到這里說明數(shù)組該位置的鏈表是空的,沒有任何元素
                    // 當(dāng)然,進到這里的另一個原因是 tryLock() 失敗,所以該槽存在并發(fā),不一定是該位置
                    node = new HashEntry<K,V>(hash, key, value, null);
                retries = 0;
            }
            else if (key.equals(e.key))
                retries = 0;
            else
                // 順著鏈表往下走
                e = e.next;
        }
        // 重試次數(shù)如果超過 MAX_SCAN_RETRIES(單核1多核64),那么不搶了,進入到阻塞隊列等待鎖
        //    lock() 是阻塞方法,直到獲取鎖后返回
        else if (++retries > MAX_SCAN_RETRIES) {
            lock();
            break;
        }
        else if ((retries & 1) == 0 &&
                 // 這個時候是有大問題了,那就是有新的元素進到了鏈表,成為了新的表頭
                 //     所以這邊的策略是,相當(dāng)于重新走一遍這個 scanAndLockForPut 方法
                 (f = entryForHash(this, hash)) != first) {
            e = first = f; // re-traverse if entry changed
            retries = -1;
        }
    }
    return node;
}

這個方法有兩個出口,一個是 tryLock() 成功了,循環(huán)終止,另一個就是重試次數(shù)超過了 MAX_SCAN_RETRIES,進到 lock() 方法,此方法會阻塞等待,直到成功拿到獨占鎖。

這個方法就是看似復(fù)雜,但是其實就是做了一件事,那就是獲取該 segment 的獨占鎖,如果需要的話順便實例化了一下 node。

擴容: rehash

重復(fù)一下,segment 數(shù)組不能擴容,擴容是 segment 數(shù)組某個位置內(nèi)部的數(shù)組 HashEntry[] 進行擴容,擴容后,容量為原來的 2 倍。

首先,我們要回顧一下觸發(fā)擴容的地方,put 的時候,如果判斷該值的插入會導(dǎo)致該 segment 的元素個數(shù)超過閾值,那么先進行擴容,再插值,讀者這個時候可以回去 put 方法看一眼。

該方法不需要考慮并發(fā),因為到這里的時候,是持有該 segment 的獨占鎖的。

// 方法參數(shù)上的 node 是這次擴容后,需要添加到新的數(shù)組中的數(shù)據(jù)。
private void rehash(HashEntry<K,V> node) {
    HashEntry<K,V>[] oldTable = table;
    int oldCapacity = oldTable.length;
    // 2 倍
    int newCapacity = oldCapacity << 1;
    threshold = (int)(newCapacity * loadFactor);
    // 創(chuàng)建新數(shù)組
    HashEntry<K,V>[] newTable =
        (HashEntry<K,V>[]) new HashEntry[newCapacity];
    // 新的掩碼,如從 16 擴容到 32,那么 sizeMask 為 31,對應(yīng)二進制 ‘000...00011111'
    int sizeMask = newCapacity - 1;

    // 遍歷原數(shù)組,老套路,將原數(shù)組位置 i 處的鏈表拆分到 新數(shù)組位置 i 和 i+oldCap 兩個位置
    for (int i = 0; i < oldCapacity ; i++) {
        // e 是鏈表的第一個元素
        HashEntry<K,V> e = oldTable[i];
        if (e != null) {
            HashEntry<K,V> next = e.next;
            // 計算應(yīng)該放置在新數(shù)組中的位置,
            // 假設(shè)原數(shù)組長度為 16,e 在 oldTable[3] 處,那么 idx 只可能是 3 或者是 3 + 16 = 19
            int idx = e.hash & sizeMask;
            if (next == null)   // 該位置處只有一個元素,那比較好辦
                newTable[idx] = e;
            else { // Reuse consecutive sequence at same slot
                // e 是鏈表表頭
                HashEntry<K,V> lastRun = e;
                // idx 是當(dāng)前鏈表的頭結(jié)點 e 的新位置
                int lastIdx = idx;

                // 下面這個 for 循環(huán)會找到一個 lastRun 節(jié)點,這個節(jié)點之后的所有元素是將要放到一起的
                for (HashEntry<K,V> last = next;
                     last != null;
                     last = last.next) {
                    int k = last.hash & sizeMask;
                    if (k != lastIdx) {
                        lastIdx = k;
                        lastRun = last;
                    }
                }
                // 將 lastRun 及其之后的所有節(jié)點組成的這個鏈表放到 lastIdx 這個位置
                newTable[lastIdx] = lastRun;
                // 下面的操作是處理 lastRun 之前的節(jié)點,
                //    這些節(jié)點可能分配在另一個鏈表中,也可能分配到上面的那個鏈表中
                for (HashEntry<K,V> p = e; p != lastRun; p = p.next) {
                    V v = p.value;
                    int h = p.hash;
                    int k = h & sizeMask;
                    HashEntry<K,V> n = newTable[k];
                    newTable[k] = new HashEntry<K,V>(h, p.key, v, n);
                }
            }
        }
    }
    // 將新來的 node 放到新數(shù)組中剛剛的 兩個鏈表之一 的 頭部
    int nodeIndex = node.hash & sizeMask; // add the new node
    node.setNext(newTable[nodeIndex]);
    newTable[nodeIndex] = node;
    table = newTable;
}

這里的擴容比之前的 HashMap 要復(fù)雜一些,代碼難懂一點。上面有兩個挨著的 for 循環(huán),第一個 for 有什么用呢?

仔細(xì)一看發(fā)現(xiàn),如果沒有第一個 for 循環(huán),也是可以工作的,但是,這個 for 循環(huán)下來,如果 lastRun 的后面還有比較多的節(jié)點,那么這次就是值得的。因為我們只需要克隆 lastRun 前面的節(jié)點,后面的一串節(jié)點跟著 lastRun 走就是了,不需要做任何操作。

我覺得 Doug Lea 的這個想法也是挺有意思的,不過比較壞的情況就是每次 lastRun 都是鏈表的最后一個元素或者很靠后的元素,那么這次遍歷就有點浪費了。不過 Doug Lea 也說了,根據(jù)統(tǒng)計,如果使用默認(rèn)的閾值,大約只有 1/6 的節(jié)點需要克隆。

get 過程分析

相對于 put 來說,get 真的不要太簡單。

  • 計算 hash 值,找到 segment 數(shù)組中的具體位置,或我們前面用的“槽”
  • 槽中也是一個數(shù)組,根據(jù) hash 找到數(shù)組中具體的位置
  • 到這里是鏈表了,順著鏈表進行查找即可
public V get(Object key) {
    Segment<K,V> s; // manually integrate access methods to reduce overhead
    HashEntry<K,V>[] tab;
    // 1. hash 值
    int h = hash(key);
    long u = (((h >>> segmentShift) & segmentMask) << SSHIFT) + SBASE;
    // 2. 根據(jù) hash 找到對應(yīng)的 segment
    if ((s = (Segment<K,V>)UNSAFE.getObjectVolatile(segments, u)) != null &&
        (tab = s.table) != null) {
        // 3. 找到segment 內(nèi)部數(shù)組相應(yīng)位置的鏈表,遍歷
        for (HashEntry<K,V> e = (HashEntry<K,V>) UNSAFE.getObjectVolatile
                 (tab, ((long)(((tab.length - 1) & h)) << TSHIFT) + TBASE);
             e != null; e = e.next) {
            K k;
            if ((k = e.key) == key || (e.hash == h && key.equals(k)))
                return e.value;
        }
    }
    return null;
}

并發(fā)問題分析

現(xiàn)在我們已經(jīng)說完了 put 過程和 get 過程,我們可以看到 get 過程中是沒有加鎖的,那自然我們就需要去考慮并發(fā)問題。

添加節(jié)點的操作 put 和刪除節(jié)點的操作 remove 都是要加 segment 上的獨占鎖的,所以它們之間自然不會有問題,我們需要考慮的問題就是 get 的時候在同一個 segment 中發(fā)生了 put 或 remove 操作。

put 操作的線程安全性

  • 初始化槽,這個我們之前就說過了,使用了 CAS 來初始化 Segment 中的數(shù)組。
  • 添加節(jié)點到鏈表的操作是插入到表頭的,所以,如果這個時候 get 操作在鏈表遍歷的過程已經(jīng)到了中間,是不會影響的。當(dāng)然,另一個并發(fā)問題就是 get 操作在 put 之后,需要保證剛剛插入表頭的節(jié)點被讀取,這個依賴于 setEntryAt 方法中使用的 UNSAFE.putOrderedObject。
  • 擴容。擴容是新創(chuàng)建了數(shù)組,然后進行遷移數(shù)據(jù),最后面將 newTable 設(shè)置給屬性 table。所以,如果 get 操作此時也在進行,那么也沒關(guān)系,如果 get 先行,那么就是在舊的 table 上做查詢操作;而 put 先行,那么 put 操作的可見性保證就是 table 使用了 volatile 關(guān)鍵字。

remove 操作的線程安全性

remove 操作我們沒有分析源碼,所以這里說的讀者感興趣的話還是需要到源碼中去求實一下的。

get 操作需要遍歷鏈表,但是 remove 操作會"破壞"鏈表。

如果 remove 破壞的節(jié)點 get 操作已經(jīng)過去了,那么這里不存在任何問題。

如果 remove 先破壞了一個節(jié)點,分兩種情況考慮。 1、如果此節(jié)點是頭結(jié)點,那么需要將頭結(jié)點的 next 設(shè)置為數(shù)組該位置的元素,table 雖然使用了 volatile 修飾,但是 volatile 并不能提供數(shù)組內(nèi)部操作的可見性保證,所以源碼中使用了 UNSAFE 來操作數(shù)組,請看方法 setEntryAt。2、如果要刪除的節(jié)點不是頭結(jié)點,它會將要刪除節(jié)點的后繼節(jié)點接到前驅(qū)節(jié)點中,這里的并發(fā)保證就是 next 屬性是 volatile 的。

Java8 ConcurrentHashMap

Java7 中實現(xiàn)的 ConcurrentHashMap 說實話還是比較復(fù)雜的,Java8 對 ConcurrentHashMap 進行了比較大的改動。建議讀者可以參考 Java8 中 HashMap 相對于 Java7 HashMap 的改動,對于 ConcurrentHashMap,Java8 也引入了紅黑樹。

說實話,Java8 ConcurrentHashMap 源碼真心不簡單,最難的在于擴容,數(shù)據(jù)遷移操作不容易看懂。

我們先用一個示意圖來描述下其結(jié)構(gòu):

結(jié)構(gòu)上和 Java8 的 HashMap 基本上一樣,不過它要保證線程安全性,所以在源碼上確實要復(fù)雜一些。

初始化

// 這構(gòu)造函數(shù)里,什么都不干
public ConcurrentHashMap() {
}
public ConcurrentHashMap(int initialCapacity) {
    if (initialCapacity < 0)
        throw new IllegalArgumentException();
    int cap = ((initialCapacity >= (MAXIMUM_CAPACITY >>> 1)) ?
               MAXIMUM_CAPACITY :
               tableSizeFor(initialCapacity + (initialCapacity >>> 1) + 1));
    this.sizeCtl = cap;
}

這個初始化方法有點意思,通過提供初始容量,計算了 sizeCtl,sizeCtl = 【 (1.5 * initialCapacity + 1),然后向上取最近的 2 的 n 次方】。如 initialCapacity 為 10,那么得到 sizeCtl 為 16,如果 initialCapacity 為 11,得到 sizeCtl 為 32。

sizeCtl 這個屬性使用的場景很多,不過只要跟著文章的思路來,就不會被它搞暈了。

如果你愛折騰,也可以看下另一個有三個參數(shù)的構(gòu)造方法,這里我就不說了,大部分時候,我們會使用無參構(gòu)造函數(shù)進行實例化,我們也按照這個思路來進行源碼分析吧。

put 過程分析

仔細(xì)地一行一行代碼看下去:

public V put(K key, V value) {
    return putVal(key, value, false);
}
final V putVal(K key, V value, boolean onlyIfAbsent) {
    if (key == null || value == null) throw new NullPointerException();
    // 得到 hash 值
    int hash = spread(key.hashCode());
    // 用于記錄相應(yīng)鏈表的長度
    int binCount = 0;
    for (Node<K,V>[] tab = table;;) {
        Node<K,V> f; int n, i, fh;
        // 如果數(shù)組"空",進行數(shù)組初始化
        if (tab == null || (n = tab.length) == 0)
            // 初始化數(shù)組,后面會詳細(xì)介紹
            tab = initTable();

        // 找該 hash 值對應(yīng)的數(shù)組下標(biāo),得到第一個節(jié)點 f
        else if ((f = tabAt(tab, i = (n - 1) & hash)) == null) {
            // 如果數(shù)組該位置為空,
            //    用一次 CAS 操作將這個新值放入其中即可,這個 put 操作差不多就結(jié)束了,可以拉到最后面了
            //          如果 CAS 失敗,那就是有并發(fā)操作,進到下一個循環(huán)就好了
            if (casTabAt(tab, i, null,
                         new Node<K,V>(hash, key, value, null)))
                break;                   // no lock when adding to empty bin
        }
        // hash 居然可以等于 MOVED,這個需要到后面才能看明白,不過從名字上也能猜到,肯定是因為在擴容
        else if ((fh = f.hash) == MOVED)
            // 幫助數(shù)據(jù)遷移,這個等到看完數(shù)據(jù)遷移部分的介紹后,再理解這個就很簡單了
            tab = helpTransfer(tab, f);

        else { // 到這里就是說,f 是該位置的頭結(jié)點,而且不為空

            V oldVal = null;
            // 獲取數(shù)組該位置的頭結(jié)點的監(jiān)視器鎖
            synchronized (f) {
                if (tabAt(tab, i) == f) {
                    if (fh >= 0) { // 頭結(jié)點的 hash 值大于 0,說明是鏈表
                        // 用于累加,記錄鏈表的長度
                        binCount = 1;
                        // 遍歷鏈表
                        for (Node<K,V> e = f;; ++binCount) {
                            K ek;
                            // 如果發(fā)現(xiàn)了"相等"的 key,判斷是否要進行值覆蓋,然后也就可以 break 了
                            if (e.hash == hash &&
                                ((ek = e.key) == key ||
                                 (ek != null && key.equals(ek)))) {
                                oldVal = e.val;
                                if (!onlyIfAbsent)
                                    e.val = value;
                                break;
                            }
                            // 到了鏈表的最末端,將這個新值放到鏈表的最后面
                            Node<K,V> pred = e;
                            if ((e = e.next) == null) {
                                pred.next = new Node<K,V>(hash, key,
                                                          value, null);
                                break;
                            }
                        }
                    }
                    else if (f instanceof TreeBin) { // 紅黑樹
                        Node<K,V> p;
                        binCount = 2;
                        // 調(diào)用紅黑樹的插值方法插入新節(jié)點
                        if ((p = ((TreeBin<K,V>)f).putTreeVal(hash, key,
                                                       value)) != null) {
                            oldVal = p.val;
                            if (!onlyIfAbsent)
                                p.val = value;
                        }
                    }
                }
            }

            if (binCount != 0) {
                // 判斷是否要將鏈表轉(zhuǎn)換為紅黑樹,臨界值和 HashMap 一樣,也是 8
                if (binCount >= TREEIFY_THRESHOLD)
                    // 這個方法和 HashMap 中稍微有一點點不同,那就是它不是一定會進行紅黑樹轉(zhuǎn)換,
                    // 如果當(dāng)前數(shù)組的長度小于 64,那么會選擇進行數(shù)組擴容,而不是轉(zhuǎn)換為紅黑樹
                    //    具體源碼我們就不看了,擴容部分后面說
                    treeifyBin(tab, i);
                if (oldVal != null)
                    return oldVal;
                break;
            }
        }
    }
    // 
    addCount(1L, binCount);
    return null;
}

put 的主流程看完了,但是至少留下了幾個問題,第一個是初始化,第二個是擴容,第三個是幫助數(shù)據(jù)遷移,這些我們都會在后面進行一一介紹。

初始化數(shù)組:initTable

這個比較簡單,主要就是初始化一個合適大小的數(shù)組,然后會設(shè)置 sizeCtl。

初始化方法中的并發(fā)問題是通過對 sizeCtl 進行一個 CAS 操作來控制的。

private final Node<K,V>[] initTable() {
    Node<K,V>[] tab; int sc;
    while ((tab = table) == null || tab.length == 0) {
        // 初始化的"功勞"被其他線程"搶去"了
        if ((sc = sizeCtl) < 0)
            Thread.yield(); // lost initialization race; just spin
        // CAS 一下,將 sizeCtl 設(shè)置為 -1,代表搶到了鎖
        else if (U.compareAndSwapInt(this, SIZECTL, sc, -1)) {
            try {
                if ((tab = table) == null || tab.length == 0) {
                    // DEFAULT_CAPACITY 默認(rèn)初始容量是 16
                    int n = (sc > 0) ? sc : DEFAULT_CAPACITY;
                    // 初始化數(shù)組,長度為 16 或初始化時提供的長度
                    Node<K,V>[] nt = (Node<K,V>[])new Node<?,?>[n];
                    // 將這個數(shù)組賦值給 table,table 是 volatile 的
                    table = tab = nt;
                    // 如果 n 為 16 的話,那么這里 sc = 12
                    // 其實就是 0.75 * n
                    sc = n - (n >>> 2);
                }
            } finally {
                // 設(shè)置 sizeCtl 為 sc,我們就當(dāng)是 12 吧
                sizeCtl = sc;
            }
            break;
        }
    }
    return tab;
}

鏈表轉(zhuǎn)紅黑樹: treeifyBin

前面我們在 put 源碼分析也說過,treeifyBin 不一定就會進行紅黑樹轉(zhuǎn)換,也可能是僅僅做數(shù)組擴容。我們還是進行源碼分析吧。

private final void treeifyBin(Node<K,V>[] tab, int index) {
    Node<K,V> b; int n, sc;
    if (tab != null) {
        // MIN_TREEIFY_CAPACITY 為 64
        // 所以,如果數(shù)組長度小于 64 的時候,其實也就是 32 或者 16 或者更小的時候,會進行數(shù)組擴容
        if ((n = tab.length) < MIN_TREEIFY_CAPACITY)
            // 后面我們再詳細(xì)分析這個方法
            tryPresize(n << 1);
        // b 是頭結(jié)點
        else if ((b = tabAt(tab, index)) != null && b.hash >= 0) {
            // 加鎖
            synchronized (b) {

                if (tabAt(tab, index) == b) {
                    // 下面就是遍歷鏈表,建立一顆紅黑樹
                    TreeNode<K,V> hd = null, tl = null;
                    for (Node<K,V> e = b; e != null; e = e.next) {
                        TreeNode<K,V> p =
                            new TreeNode<K,V>(e.hash, e.key, e.val,
                                              null, null);
                        if ((p.prev = tl) == null)
                            hd = p;
                        else
                            tl.next = p;
                        tl = p;
                    }
                    // 將紅黑樹設(shè)置到數(shù)組相應(yīng)位置中
                    setTabAt(tab, index, new TreeBin<K,V>(hd));
                }
            }
        }
    }
}

擴容:tryPresize

如果說 Java8 ConcurrentHashMap 的源碼不簡單,那么說的就是擴容操作和遷移操作。

這個方法要完完全全看懂還需要看之后的 transfer 方法,讀者應(yīng)該提前知道這點。

這里的擴容也是做翻倍擴容的,擴容后數(shù)組容量為原來的 2 倍。

// 首先要說明的是,方法參數(shù) size 傳進來的時候就已經(jīng)翻了倍了
private final void tryPresize(int size) {
    // c:size 的 1.5 倍,再加 1,再往上取最近的 2 的 n 次方。
    int c = (size >= (MAXIMUM_CAPACITY >>> 1)) ? MAXIMUM_CAPACITY :
        tableSizeFor(size + (size >>> 1) + 1);
    int sc;
    while ((sc = sizeCtl) >= 0) {
        Node<K,V>[] tab = table; int n;

        // 這個 if 分支和之前說的初始化數(shù)組的代碼基本上是一樣的,在這里,我們可以不用管這塊代碼
        if (tab == null || (n = tab.length) == 0) {
            n = (sc > c) ? sc : c;
            if (U.compareAndSwapInt(this, SIZECTL, sc, -1)) {
                try {
                    if (table == tab) {
                        @SuppressWarnings("unchecked")
                        Node<K,V>[] nt = (Node<K,V>[])new Node<?,?>[n];
                        table = nt;
                        sc = n - (n >>> 2); // 0.75 * n
                    }
                } finally {
                    sizeCtl = sc;
                }
            }
        }
        else if (c <= sc || n >= MAXIMUM_CAPACITY)
            break;
        else if (tab == table) {
            // 我沒看懂 rs 的真正含義是什么,不過也關(guān)系不大
            int rs = resizeStamp(n);

            if (sc < 0) {
                Node<K,V>[] nt;
                if ((sc >>> RESIZE_STAMP_SHIFT) != rs || sc == rs + 1 ||
                    sc == rs + MAX_RESIZERS || (nt = nextTable) == null ||
                    transferIndex <= 0)
                    break;
                // 2. 用 CAS 將 sizeCtl 加 1,然后執(zhí)行 transfer 方法
                //    此時 nextTab 不為 null
                if (U.compareAndSwapInt(this, SIZECTL, sc, sc + 1))
                    transfer(tab, nt);
            }
            // 1. 將 sizeCtl 設(shè)置為 (rs << RESIZE_STAMP_SHIFT) + 2)
            //     我是沒看懂這個值真正的意義是什么?不過可以計算出來的是,結(jié)果是一個比較大的負(fù)數(shù)
            //  調(diào)用 transfer 方法,此時 nextTab 參數(shù)為 null
            else if (U.compareAndSwapInt(this, SIZECTL, sc,
                                         (rs << RESIZE_STAMP_SHIFT) + 2))
                transfer(tab, null);
        }
    }
}

這個方法的核心在于 sizeCtl 值的操作,首先將其設(shè)置為一個負(fù)數(shù),然后執(zhí)行 transfer(tab, null),再下一個循環(huán)將 sizeCtl 加 1,并執(zhí)行 transfer(tab, nt),之后可能是繼續(xù) sizeCtl 加 1,并執(zhí)行 transfer(tab, nt)。

所以,可能的操作就是執(zhí)行 1 次 transfer(tab, null) + 多次 transfer(tab, nt),這里怎么結(jié)束循環(huán)的需要看完 transfer 源碼才清楚。

數(shù)據(jù)遷移:transfer

下面這個方法很點長,將原來的 tab 數(shù)組的元素遷移到新的 nextTab 數(shù)組中。

雖然我們之前說的 tryPresize 方法中多次調(diào)用 transfer 不涉及多線程,但是這個 transfer 方法可以在其他地方被調(diào)用,典型地,我們之前在說 put 方法的時候就說過了,請往上看 put 方法,是不是有個地方調(diào)用了 helpTransfer 方法,helpTransfer 方法會調(diào)用 transfer 方法的。

此方法支持多線程執(zhí)行,外圍調(diào)用此方法的時候,會保證第一個發(fā)起數(shù)據(jù)遷移的線程,nextTab 參數(shù)為 null,之后再調(diào)用此方法的時候,nextTab 不會為 null。

閱讀源碼之前,先要理解并發(fā)操作的機制。原數(shù)組長度為 n,所以我們有 n 個遷移任務(wù),讓每個線程每次負(fù)責(zé)一個小任務(wù)是最簡單的,每做完一個任務(wù)再檢測是否有其他沒做完的任務(wù),幫助遷移就可以了,而 Doug Lea 使用了一個 stride,簡單理解就是步長,每個線程每次負(fù)責(zé)遷移其中的一部分,如每次遷移 16 個小任務(wù)。所以,我們就需要一個全局的調(diào)度者來安排哪個線程執(zhí)行哪幾個任務(wù),這個就是屬性 transferIndex 的作用。

第一個發(fā)起數(shù)據(jù)遷移的線程會將 transferIndex 指向原數(shù)組最后的位置,然后從后往前的 stride 個任務(wù)屬于第一個線程,然后將 transferIndex 指向新的位置,再往前的 stride 個任務(wù)屬于第二個線程,依此類推。當(dāng)然,這里說的第二個線程不是真的一定指代了第二個線程,也可以是同一個線程,這個讀者應(yīng)該能理解吧。其實就是將一個大的遷移任務(wù)分為了一個個任務(wù)包。

private final void transfer(Node<K,V>[] tab, Node<K,V>[] nextTab) {
    int n = tab.length, stride;

    // stride 在單核下直接等于 n,多核模式下為 (n>>>3)/NCPU,最小值是 16
    // stride 可以理解為”步長“,有 n 個位置是需要進行遷移的,
    //   將這 n 個任務(wù)分為多個任務(wù)包,每個任務(wù)包有 stride 個任務(wù)
    if ((stride = (NCPU > 1) ? (n >>> 3) / NCPU : n) < MIN_TRANSFER_STRIDE)
        stride = MIN_TRANSFER_STRIDE; // subdivide range

    // 如果 nextTab 為 null,先進行一次初始化
    //    前面我們說了,外圍會保證第一個發(fā)起遷移的線程調(diào)用此方法時,參數(shù) nextTab 為 null
    //       之后參與遷移的線程調(diào)用此方法時,nextTab 不會為 null
    if (nextTab == null) {
        try {
            // 容量翻倍
            Node<K,V>[] nt = (Node<K,V>[])new Node<?,?>[n << 1];
            nextTab = nt;
        } catch (Throwable ex) {      // try to cope with OOME
            sizeCtl = Integer.MAX_VALUE;
            return;
        }
        // nextTable 是 ConcurrentHashMap 中的屬性
        nextTable = nextTab;
        // transferIndex 也是 ConcurrentHashMap 的屬性,用于控制遷移的位置
        transferIndex = n;
    }

    int nextn = nextTab.length;

    // ForwardingNode 翻譯過來就是正在被遷移的 Node
    // 這個構(gòu)造方法會生成一個Node,key、value 和 next 都為 null,關(guān)鍵是 hash 為 MOVED
    // 后面我們會看到,原數(shù)組中位置 i 處的節(jié)點完成遷移工作后,
    //    就會將位置 i 處設(shè)置為這個 ForwardingNode,用來告訴其他線程該位置已經(jīng)處理過了
    //    所以它其實相當(dāng)于是一個標(biāo)志。
    ForwardingNode<K,V> fwd = new ForwardingNode<K,V>(nextTab);


    // advance 指的是做完了一個位置的遷移工作,可以準(zhǔn)備做下一個位置的了
    boolean advance = true;
    boolean finishing = false; // to ensure sweep before committing nextTab

    /*
     * 下面這個 for 循環(huán),最難理解的在前面,而要看懂它們,應(yīng)該先看懂后面的,然后再倒回來看
     * 
     */

    // i 是位置索引,bound 是邊界,注意是從后往前
    for (int i = 0, bound = 0;;) {
        Node<K,V> f; int fh;

        // 下面這個 while 真的是不好理解
        // advance 為 true 表示可以進行下一個位置的遷移了
        //   簡單理解結(jié)局:i 指向了 transferIndex,bound 指向了 transferIndex-stride
        while (advance) {
            int nextIndex, nextBound;
            if (--i >= bound || finishing)
                advance = false;

            // 將 transferIndex 值賦給 nextIndex
            // 這里 transferIndex 一旦小于等于 0,說明原數(shù)組的所有位置都有相應(yīng)的線程去處理了
            else if ((nextIndex = transferIndex) <= 0) {
                i = -1;
                advance = false;
            }
            else if (U.compareAndSwapInt
                     (this, TRANSFERINDEX, nextIndex,
                      nextBound = (nextIndex > stride ?
                                   nextIndex - stride : 0))) {
                // 看括號中的代碼,nextBound 是這次遷移任務(wù)的邊界,注意,是從后往前
                bound = nextBound;
                i = nextIndex - 1;
                advance = false;
            }
        }
        if (i < 0 || i >= n || i + n >= nextn) {
            int sc;
            if (finishing) {
                // 所有的遷移操作已經(jīng)完成
                nextTable = null;
                // 將新的 nextTab 賦值給 table 屬性,完成遷移
                table = nextTab;
                // 重新計算 sizeCtl:n 是原數(shù)組長度,所以 sizeCtl 得出的值將是新數(shù)組長度的 0.75 倍
                sizeCtl = (n << 1) - (n >>> 1);
                return;
            }

            // 之前我們說過,sizeCtl 在遷移前會設(shè)置為 (rs << RESIZE_STAMP_SHIFT) + 2
            // 然后,每有一個線程參與遷移就會將 sizeCtl 加 1,
            // 這里使用 CAS 操作對 sizeCtl 進行減 1,代表做完了屬于自己的任務(wù)
            if (U.compareAndSwapInt(this, SIZECTL, sc = sizeCtl, sc - 1)) {
                // 任務(wù)結(jié)束,方法退出
                if ((sc - 2) != resizeStamp(n) << RESIZE_STAMP_SHIFT)
                    return;

                // 到這里,說明 (sc - 2) == resizeStamp(n) << RESIZE_STAMP_SHIFT,
                // 也就是說,所有的遷移任務(wù)都做完了,也就會進入到上面的 if(finishing){} 分支了
                finishing = advance = true;
                i = n; // recheck before commit
            }
        }
        // 如果位置 i 處是空的,沒有任何節(jié)點,那么放入剛剛初始化的 ForwardingNode ”空節(jié)點“
        else if ((f = tabAt(tab, i)) == null)
            advance = casTabAt(tab, i, null, fwd);
        // 該位置處是一個 ForwardingNode,代表該位置已經(jīng)遷移過了
        else if ((fh = f.hash) == MOVED)
            advance = true; // already processed
        else {
            // 對數(shù)組該位置處的結(jié)點加鎖,開始處理數(shù)組該位置處的遷移工作
            synchronized (f) {
                if (tabAt(tab, i) == f) {
                    Node<K,V> ln, hn;
                    // 頭結(jié)點的 hash 大于 0,說明是鏈表的 Node 節(jié)點
                    if (fh >= 0) {
                        // 下面這一塊和 Java7 中的 ConcurrentHashMap 遷移是差不多的,
                        // 需要將鏈表一分為二,
                        //   找到原鏈表中的 lastRun,然后 lastRun 及其之后的節(jié)點是一起進行遷移的
                        //   lastRun 之前的節(jié)點需要進行克隆,然后分到兩個鏈表中
                        int runBit = fh & n;
                        Node<K,V> lastRun = f;
                        for (Node<K,V> p = f.next; p != null; p = p.next) {
                            int b = p.hash & n;
                            if (b != runBit) {
                                runBit = b;
                                lastRun = p;
                            }
                        }
                        if (runBit == 0) {
                            ln = lastRun;
                            hn = null;
                        }
                        else {
                            hn = lastRun;
                            ln = null;
                        }
                        for (Node<K,V> p = f; p != lastRun; p = p.next) {
                            int ph = p.hash; K pk = p.key; V pv = p.val;
                            if ((ph & n) == 0)
                                ln = new Node<K,V>(ph, pk, pv, ln);
                            else
                                hn = new Node<K,V>(ph, pk, pv, hn);
                        }
                        // 其中的一個鏈表放在新數(shù)組的位置 i
                        setTabAt(nextTab, i, ln);
                        // 另一個鏈表放在新數(shù)組的位置 i+n
                        setTabAt(nextTab, i + n, hn);
                        // 將原數(shù)組該位置處設(shè)置為 fwd,代表該位置已經(jīng)處理完畢,
                        //    其他線程一旦看到該位置的 hash 值為 MOVED,就不會進行遷移了
                        setTabAt(tab, i, fwd);
                        // advance 設(shè)置為 true,代表該位置已經(jīng)遷移完畢
                        advance = true;
                    }
                    else if (f instanceof TreeBin) {
                        // 紅黑樹的遷移
                        TreeBin<K,V> t = (TreeBin<K,V>)f;
                        TreeNode<K,V> lo = null, loTail = null;
                        TreeNode<K,V> hi = null, hiTail = null;
                        int lc = 0, hc = 0;
                        for (Node<K,V> e = t.first; e != null; e = e.next) {
                            int h = e.hash;
                            TreeNode<K,V> p = new TreeNode<K,V>
                                (h, e.key, e.val, null, null);
                            if ((h & n) == 0) {
                                if ((p.prev = loTail) == null)
                                    lo = p;
                                else
                                    loTail.next = p;
                                loTail = p;
                                ++lc;
                            }
                            else {
                                if ((p.prev = hiTail) == null)
                                    hi = p;
                                else
                                    hiTail.next = p;
                                hiTail = p;
                                ++hc;
                            }
                        }
                        // 如果一分為二后,節(jié)點數(shù)少于 8,那么將紅黑樹轉(zhuǎn)換回鏈表
                        ln = (lc <= UNTREEIFY_THRESHOLD) ? untreeify(lo) :
                            (hc != 0) ? new TreeBin<K,V>(lo) : t;
                        hn = (hc <= UNTREEIFY_THRESHOLD) ? untreeify(hi) :
                            (lc != 0) ? new TreeBin<K,V>(hi) : t;

                        // 將 ln 放置在新數(shù)組的位置 i
                        setTabAt(nextTab, i, ln);
                        // 將 hn 放置在新數(shù)組的位置 i+n
                        setTabAt(nextTab, i + n, hn);
                        // 將原數(shù)組該位置處設(shè)置為 fwd,代表該位置已經(jīng)處理完畢,
                        //    其他線程一旦看到該位置的 hash 值為 MOVED,就不會進行遷移了
                        setTabAt(tab, i, fwd);
                        // advance 設(shè)置為 true,代表該位置已經(jīng)遷移完畢
                        advance = true;
                    }
                }
            }
        }
    }
}

說到底,transfer 這個方法并沒有實現(xiàn)所有的遷移任務(wù),每次調(diào)用這個方法只實現(xiàn)了 transferIndex 往前 stride 個位置的遷移工作,其他的需要由外圍來控制。

這個時候,再回去仔細(xì)看 tryPresize 方法可能就會更加清晰一些了。

get 過程分析

get 方法從來都是最簡單的,這里也不例外:

1.計算 hash 值

2.根據(jù) hash 值找到數(shù)組對應(yīng)位置: (n - 1) & h

3.根據(jù)該位置處結(jié)點性質(zhì)進行相應(yīng)查找

  • 如果該位置為 null,那么直接返回 null 就可以了
  • 如果該位置處的節(jié)點剛好就是我們需要的,返回該節(jié)點的值即可
  • 如果該位置節(jié)點的 hash 值小于 0,說明正在擴容,或者是紅黑樹,后面我們再介紹 find 方法
  • 如果以上 3 條都不滿足,那就是鏈表,進行遍歷比對即可
public V get(Object key) {
    Node<K,V>[] tab; Node<K,V> e, p; int n, eh; K ek;
    int h = spread(key.hashCode());
    if ((tab = table) != null && (n = tab.length) > 0 &&
        (e = tabAt(tab, (n - 1) & h)) != null) {
        // 判斷頭結(jié)點是否就是我們需要的節(jié)點
        if ((eh = e.hash) == h) {
            if ((ek = e.key) == key || (ek != null && key.equals(ek)))
                return e.val;
        }
        // 如果頭結(jié)點的 hash 小于 0,說明 正在擴容,或者該位置是紅黑樹
        else if (eh < 0)
            // 參考 ForwardingNode.find(int h, Object k) 和 TreeBin.find(int h, Object k)
            return (p = e.find(h, key)) != null ? p.val : null;

        // 遍歷鏈表
        while ((e = e.next) != null) {
            if (e.hash == h &&
                ((ek = e.key) == key || (ek != null && key.equals(ek))))
                return e.val;
        }
    }
    return null;
}

簡單說一句,此方法的大部分內(nèi)容都很簡單,只有正好碰到擴容的情況,F(xiàn)orwardingNode.find(int h, Object k) 稍微復(fù)雜一些,不過在了解了數(shù)據(jù)遷移的過程后,這個也就不難了,所以限于篇幅這里也不展開說了。

以上就是Java7和Java8中的ConcurrentHashMap原理解析的詳細(xì)內(nèi)容,更多關(guān)于ConcurrentHashMap原理的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Java11?中基于嵌套關(guān)系的訪問控制優(yōu)化問題

    Java11?中基于嵌套關(guān)系的訪問控制優(yōu)化問題

    在?Java?語言中,類和接口可以相互嵌套,這種組合之間可以不受限制的彼此訪問,包括訪問彼此的構(gòu)造函數(shù)、字段、方法,接下來通過本文給大家介紹Java11中基于嵌套關(guān)系的訪問控制優(yōu)化問題,感興趣的朋友一起看看吧
    2022-01-01
  • Java深入理解代碼塊的使用細(xì)節(jié)

    Java深入理解代碼塊的使用細(xì)節(jié)

    所謂代碼塊是指用"{}"括起來的一段代碼,根據(jù)其位置和聲明的不同,可以分為普通代碼塊、構(gòu)造塊、靜態(tài)塊、和同步代碼塊。如果在代碼塊前加上?synchronized關(guān)鍵字,則此代碼塊就成為同步代碼塊
    2022-05-05
  • java8 filter方法、Predicate接口的使用方式

    java8 filter方法、Predicate接口的使用方式

    這篇文章主要介紹了java8 filter方法、Predicate接口的使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • Spring超詳細(xì)講解BeanUtils改造

    Spring超詳細(xì)講解BeanUtils改造

    BeanUtils.copyProperties();確實為我們做了很多事情,雖然不能完美完成深拷貝,但是對于?po、vo、dto?的拷貝已經(jīng)足夠用了。但是其還是有一些不夠完美的地方,下面我們來探討一下有哪些不足以及改造
    2022-06-06
  • java彩色瓷磚編程題分析

    java彩色瓷磚編程題分析

    這篇文章主要介紹了java彩色瓷磚編程題的詳細(xì)解題思路以及解決方法分享,對此有興趣的參考下。
    2018-02-02
  • Java-lambda表達式入門看這一篇就夠了

    Java-lambda表達式入門看這一篇就夠了

    lambda表達式最簡單的作用就是用于簡化創(chuàng)建匿名內(nèi)部類對象,Lambda表達式是一個可傳遞的代碼塊,可以在以后執(zhí)行一次或多次,下面通過本文給大家介紹Java-lambda表達式入門教程,感興趣的朋友一起看看吧
    2021-05-05
  • 一文帶你掌握SpringBoot中常見定時任務(wù)的實現(xiàn)

    一文帶你掌握SpringBoot中常見定時任務(wù)的實現(xiàn)

    這篇文章主要為大家詳細(xì)介紹了Spring?Boot中定時任務(wù)的基本用法、高級特性以及最佳實踐,幫助開發(fā)人員更好地理解和應(yīng)用定時任務(wù),提高系統(tǒng)的穩(wěn)定性和可靠性,需要的可以參考下
    2024-03-03
  • Java中字節(jié)流和字符流的區(qū)別與聯(lián)系

    Java中字節(jié)流和字符流的區(qū)別與聯(lián)系

    Java中的字節(jié)流和字符流是用于處理輸入和輸出的兩種不同的流,本文主要介紹了Java中字節(jié)流和字符流的區(qū)別與聯(lián)系,字節(jié)流以字節(jié)為單位進行讀寫,適用于處理二進制數(shù)據(jù),本文結(jié)合實例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2024-12-12
  • 我勸你謹(jǐn)慎使用Spring中的@Scheduled注解

    我勸你謹(jǐn)慎使用Spring中的@Scheduled注解

    這篇文章主要介紹了Spring中的@Scheduled注解使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • 詳解java中List中set方法和add方法的區(qū)別

    詳解java中List中set方法和add方法的區(qū)別

    本文主要介紹了詳解java中List中set方法和add方法的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08

最新評論

97年大学生大白天操逼| 97人人模人人爽人人喊| 超污视频在线观看污污污| 黄片大全在线观看观看| 黄色大片免费观看网站| 欧美80老妇人性视频| 亚洲精品国产在线电影| 涩爱综合久久五月蜜臀| 国产精品黄大片在线播放| 红杏久久av人妻一区| 天天躁日日躁狠狠躁av麻豆| av久久精品北条麻妃av观看| 91天堂天天日天天操| 免费手机黄页网址大全| 亚洲精品 日韩电影| 人妻激情图片视频小说| 天堂av狠狠操蜜桃| 无套猛戳丰满少妇人妻| ka0ri在线视频| 亚洲免费成人a v| 粉嫩欧美美人妻小视频| 午夜国产福利在线观看| 国产美女一区在线观看| 国产黄色高清资源在线免费观看| 精品久久久久久久久久中文蒉| 国产亚洲欧美另类在线观看| 女同互舔一区二区三区| 国产精品成人xxxx| 黄色成人在线中文字幕| 黑人乱偷人妻中文字幕| 综合色区亚洲熟妇shxstz| 亚洲丝袜老师诱惑在线观看| 日本高清在线不卡一区二区| 欧美日本aⅴ免费视频| 免费岛国喷水视频在线观看 | 亚洲欧美清纯唯美另类 | 中文字幕在线永久免费播放| 中文亚洲欧美日韩无线码| 色综合久久五月色婷婷综合| 亚洲天堂第一页中文字幕| 成人24小时免费视频| 色综合久久久久久久久中文| 亚洲变态另类色图天堂网| 97年大学生大白天操逼| 天天日天天天天天天天天天天 | 亚洲国产精品久久久久久6| 亚洲欧美色一区二区| 在线观看的黄色免费网站| 精品人人人妻人人玩日产欧| 91片黄在线观看喷潮| 美女福利视频网址导航| 午夜婷婷在线观看视频| 亚洲精品一线二线在线观看| 好太好爽好想要免费| 在线观看操大逼视频| 内射久久久久综合网| 国产精品入口麻豆啊啊啊| 在线播放一区二区三区Av无码| 欧美精品伦理三区四区| 女生被男生插的视频网站| av中文字幕在线观看第三页| 欧美怡红院视频在线观看| 久久热久久视频在线观看| 欧美一区二区三区激情啪啪啪| 日本午夜爽爽爽爽爽视频在线观看 | 青青青国产免费视频| 视频啪啪啪免费观看| 性生活第二下硬不起来| japanese日本熟妇另类| 青草久久视频在线观看| 99热久久这里只有精品| 国产精彩福利精品视频| 亚洲国产第一页在线观看| 在线观看日韩激情视频| 欧美麻豆av在线播放| 青青草在观免费国产精品| 午夜激情精品福利视频| 天天综合天天综合天天网| 国产真实灌醉下药美女av福利| 亚洲的电影一区二区三区 | 日韩成人综艺在线播放| 亚洲欧美色一区二区| www久久久久久久久久久| 久久一区二区三区人妻欧美| 天天做天天干天天操天天射| 男生用鸡操女生视频动漫| 日本性感美女写真视频| 97人妻人人澡爽人人精品| 在线免费观看黄页视频| 青青青青青青青在线播放视频| 久久精品美女免费视频| 午夜的视频在线观看| 在线观看亚洲人成免费网址| 99av国产精品欲麻豆| 超碰在线中文字幕一区二区| 四川乱子伦视频国产vip| 中文字幕,亚洲人妻| 97年大学生大白天操逼| 天天想要天天操天天干| 中文字幕日韩精品就在这里| 亚洲一区二区三区uij| 亚洲av香蕉一区区二区三区犇| 天天日天天干天天要| 欧美性感尤物人妻在线免费看| 91色网站免费在线观看| 夜夜骑夜夜操夜夜奸| 中文字日产幕乱六区蜜桃| 在线观看的a站 最新| 东京热男人的av天堂| 制服丝袜在线人妻中文字幕| 国产97在线视频观看| 精品老妇女久久9g国产| 老司机福利精品视频在线| 2012中文字幕在线高清| av视网站在线观看| 国产在线观看黄色视频| 亚洲中文字幕人妻一区| 夫妻在线观看视频91| 综合激情网激情五月天| 在线免费观看靠比视频的网站| 欲满人妻中文字幕在线| 日本www中文字幕| 性色蜜臀av一区二区三区| 天天日天天爽天天干| 日本一区二区三区免费小视频| 欧美成人小视频在线免费看| 动漫精品视频在线观看| 亚洲 国产 成人 在线| 自拍偷拍亚洲欧美在线视频| jiuse91九色视频| 亚洲一区二区三区久久午夜| 快点插进来操我逼啊视频| 亚洲粉嫩av一区二区三区| 久久三久久三久久三久久| 99国产精品窥熟女精品| 97成人免费在线观看网站| 人妻少妇av在线观看| 精品黑人一区二区三区久久国产| 国产性感美女福利视频| 欧美成人综合视频一区二区| 亚洲人妻30pwc| 国产视频网站一区二区三区| 自拍偷拍亚洲另类色图| 激情人妻校园春色亚洲欧美| 国产熟妇人妻ⅹxxxx麻豆| 91精品一区二区三区站长推荐| 国产午夜亚洲精品不卡在线观看| 在线观看国产免费麻豆| 欧美第一页在线免费观看视频| 成人影片高清在线观看| 偷拍3456eee| 成年人免费看在线视频| 精品一区二区三四区| 国产真实乱子伦a视频| 欧美特色aaa大片| 被大鸡吧操的好舒服视频免费| 欧美性感尤物人妻在线免费看 | 免费男阳茎伸入女阳道视频 | 男人的网址你懂的亚洲欧洲av| 国产91久久精品一区二区字幕| 999久久久久999| 久久永久免费精品人妻专区| 熟女91pooyn熟女| 亚洲国产精品久久久久久6| 亚洲国产欧美一区二区三区…| 国产一线二线三线的区别在哪 | 欧美久久一区二区伊人| 91免费放福利在线观看| eeuss鲁片一区二区三区| 婷婷久久久久深爱网| 欧美日韩熟女一区二区三区| 大香蕉伊人国产在线| 天堂女人av一区二区| tube69日本少妇| 亚洲伊人av天堂有码在线| 欧美viboss性丰满| 中文字幕一区的人妻欧美日韩| 国产精品自拍在线视频| 天天日天天干天天要| 天天日天天舔天天射进去| 在线免费观看99视频| 2019av在线视频| 国产普通话插插视频| 久精品人妻一区二区三区 | 亚欧在线视频你懂的| 亚洲精品亚洲人成在线导航| 青青青青草手机在线视频免费看| 午夜在线观看一区视频| 国产视频网站一区二区三区| 国产1区,2区,3区| 大香蕉玖玖一区2区| 91传媒一区二区三区| 丰满少妇人妻xxxxx| 色97视频在线播放| 天天干天天爱天天色| 黄片色呦呦视频免费看| 狠狠躁狠狠爱网站视频| 欧美精品 日韩国产| 精品一区二区三区三区88| 九色精品视频在线播放| 欧亚日韩一区二区三区观看视频| 精品乱子伦一区二区三区免费播| 国产高清精品一区二区三区| 青青草在观免费国产精品| 国产精品一二三不卡带免费视频| 中文字幕在线观看国产片| 亚洲av色香蕉一区二区三区| 经典av尤物一区二区| 黄色成人在线中文字幕| 亚洲一区自拍高清免费视频| 在线制服丝袜中文字幕| 一区二区三区蜜臀在线| 亚洲1区2区3区精华液| 中文字幕免费在线免费| 国产一区av澳门在线观看| 亚洲 自拍 色综合图| 日韩精品中文字幕在线| 人人爽亚洲av人人爽av| 天堂av在线官网中文| 97人妻无码AV碰碰视频| 91试看福利一分钟| 日本中文字幕一二区视频| aaa久久久久久久久| 一区二区久久成人网| 姐姐的朋友2在线观看中文字幕| 大胆亚洲av日韩av| 精品91高清在线观看| 9国产精品久久久久老师| 成人乱码一区二区三区av| 亚洲精品中文字幕下载| 天天躁日日躁狠狠躁躁欧美av| 青青伊人一精品视频| 亚洲欧美一卡二卡三卡| 美女张开腿让男生操在线看| 老师让我插进去69AV| 91she九色精品国产| 中文人妻AV久久人妻水| 欧美色婷婷综合在线| 夜色撩人久久7777| 亚洲色偷偷综合亚洲AV伊人| 欧美成人小视频在线免费看| 日本熟女50视频免费| 久久www免费人成一看片| 亚洲乱码中文字幕在线| 青青草在观免费国产精品| 亚洲成人线上免费视频观看| 男人的天堂av日韩亚洲| 欧洲欧美日韩国产在线| 久久艹在线观看视频| 日韩欧美一级精品在线观看| 国产成人精品一区在线观看| 国产午夜男女爽爽爽爽爽视频| 日韩影片一区二区三区不卡免费 | 9色精品视频在线观看| 国产福利小视频大全| 亚洲欧美色一区二区| 玩弄人妻熟妇性色av少妇| 在线观看视频网站麻豆| 亚洲精品麻豆免费在线观看| heyzo蜜桃熟女人妻| 天天干天天插天天谢| 91精品国产高清自在线看香蕉网| 在线观看成人国产电影| 亚洲综合另类精品小说| 久青青草视频手机在线免费观看| 午夜激情久久不卡一区二区 | 中文字幕无码一区二区免费| 亚洲av男人的天堂你懂的| 亚洲天堂av最新网址| 97黄网站在线观看| 免费在线看的黄片视频| 青青青青青青青青青青草青青 | 亚洲一级特黄特黄黄色录像片| 婷婷色中文亚洲网68| 中文人妻AV久久人妻水| 超碰公开大香蕉97| 黄色片一级美女黄色片| 2o22av在线视频| 大屁股肉感人妻中文字幕在线| 美女 午夜 在线视频| 好男人视频在线免费观看网站| 中文字幕高清在线免费播放 | 免费在线看的黄片视频| 亚洲区欧美区另类最新章节| 91超碰青青中文字幕| 91亚洲手机在线视频播放| 肏插流水妹子在线乐播下载| 激情伦理欧美日韩中文字幕| 日韩精品中文字幕福利| 国产乱弄免费视频观看| 欧美一区二区三区在线资源| 天天干夜夜操天天舔| 中文字日产幕乱六区蜜桃| av手机在线免费观看日韩av| 大香蕉伊人国产在线| 久草视频在线一区二区三区资源站 | 亚洲天堂成人在线观看视频网站| 亚洲av一妻不如妾| 国产内射中出在线观看| 久久麻豆亚洲精品av| 久久午夜夜伦痒痒想咳嗽P| 国产午夜亚洲精品麻豆| 91精品高清一区二区三区| 午夜91一区二区三区| 亚洲中文字幕校园春色| 韩国女主播精品视频网站| 国产男女视频在线播放| 红杏久久av人妻一区| 国产黄色a级三级三级三级| 美女福利视频导航网站 | 极品性荡少妇一区二区色欲| 18禁网站一区二区三区四区| 亚洲高清国产拍青青草原| 亚洲av日韩av第一区二区三区| 欧美国品一二三产区区别| 播放日本一区二区三区电影| 果冻传媒av一区二区三区| 色狠狠av线不卡香蕉一区二区 | 欧美熟妇一区二区三区仙踪林| caoporn蜜桃视频| 欧美80老妇人性视频| 2022中文字幕在线| 久久久久91精品推荐99| 香港三日本三韩国三欧美三级| 一色桃子人妻一区二区三区| 欧美成人黄片一区二区三区| 国产熟妇人妻ⅹxxxx麻豆| 天天操天天爽天天干| 99热色原网这里只有精品| 日本熟妇喷水xxx| 免费看国产又粗又猛又爽又黄视频| 在线观看一区二区三级| 真实国产乱子伦一区二区| 黑人变态深video特大巨大| 大鸡吧插入女阴道黄色片| 黄色片黄色片wyaa| 中文字幕中文字幕人妻| 大香蕉大香蕉大香蕉大香蕉大香蕉| huangse网站在线观看| 天堂va蜜桃一区入口| 综合页自拍视频在线播放| 激情国产小视频在线| 大陆胖女人与丈夫操b国语高清| 岛国青草视频在线观看| 国产91久久精品一区二区字幕| av老司机精品在线观看| 国产日本精品久久久久久久| 午夜频道成人在线91| 78色精品一区二区三区| 日本少妇人妻xxxxxhd| 亚洲av无女神免非久久| 日韩精品激情在线观看| 成人国产小视频在线观看| 51国产成人精品视频| caoporn蜜桃视频| 91 亚洲视频在线观看| 99一区二区在线观看| 熟女人妻一区二区精品视频| 国产精品久久久久国产三级试频| 久久人人做人人妻人人玩精品vr| 午夜精品在线视频一区| 精品视频一区二区三区四区五区| 男人的天堂在线黄色| 日本福利午夜电影在线观看| 2022国产综合在线干| 鸡巴操逼一级黄色气| 99精品一区二区三区的区| 午夜91一区二区三区| caoporm超碰国产| 99国内精品永久免费视频| 成年女人免费播放视频| 97色视频在线观看| 欧美视频中文一区二区三区| 91试看福利一分钟| 黄色大片男人操女人逼| 青青青aaaa免费| 黄色大片男人操女人逼| 51国产偷自视频在线播放| 亚洲视频在线观看高清| 男人插女人视频网站| 一区二区视频在线观看免费观看| 亚洲精品av在线观看| 国产三级精品三级在线不卡| www日韩毛片av| 精品首页在线观看视频| 国产性色生活片毛片春晓精品| 伊人综合免费在线视频| 国产普通话插插视频| 99热久久这里只有精品| 极品粉嫩小泬白浆20p主播| 高清一区二区欧美系列| 青青青青青免费视频| 一个人免费在线观看ww视频| 在线播放一区二区三区Av无码| 91啪国自产中文字幕在线| 人妻熟女在线一区二区| 亚洲成人熟妇一区二区三区 | 亚洲精品久久视频婷婷| 在线视频这里只有精品自拍| 国产高清在线观看1区2区| 深田咏美亚洲一区二区 | 91麻豆精品91久久久久同性| 精品少妇一二三视频在线| 国产精品系列在线观看一区二区| 播放日本一区二区三区电影| 欧美精产国品一二三产品价格 | 亚洲精品成人网久久久久久小说 | 这里有精品成人国产99| 老熟妇凹凸淫老妇女av在线观看| 午夜在线观看一区视频| 日韩三级黄色片网站| 老司机免费视频网站在线看| 成人H精品动漫在线无码播放| 国内精品在线播放第一页| 都市激情校园春色狠狠| 亚洲乱码中文字幕在线| 女警官打开双腿沦为性奴| 国内自拍第一页在线观看| 熟女人妻三十路四十路人妻斩| 亚洲 图片 欧美 图片| 午夜美女少妇福利视频| 热思思国产99re| 亚洲人成精品久久久久久久| 久久久久久久99精品| 小穴多水久久精品免费看| 9l人妻人人爽人人爽| 日本最新一二三区不卡在线| 五月婷婷在线观看视频免费| 亚洲午夜电影在线观看| 亚洲国产最大av综合| 日韩加勒比东京热二区| 欧美黑人巨大性xxxxx猛交| 免费在线观看污污视频网站| 日日操夜夜撸天天干| av中文字幕网址在线| 中国视频一区二区三区| 久久久久久9999久久久久| aiss午夜免费视频| 精品国产污污免费网站入口自| 超碰97人人做人人爱| 美味人妻2在线播放| yy96视频在线观看| 不卡一不卡二不卡三| 欧美色呦呦最新网址| 中国黄片视频一区91| 日本男女操逼视频免费看| 国产一区二区火爆视频| 欧美在线一二三视频| 97年大学生大白天操逼| 一区二区在线视频中文字幕| 一区二区三区的久久的蜜桃的视频| 在线可以看的视频你懂的| 在线免费观看av日韩| 淫秽激情视频免费观看| 在线免费91激情四射| 日本少妇人妻xxxxxhd| 青青青青青青青在线播放视频| 91精品视频在线观看免费| 经典av尤物一区二区| 一区二区三区久久中文字幕| 青青青青青青青青青国产精品视频| 国产性色生活片毛片春晓精品| 日本啪啪啪啪啪啪啪| 福利视频一区二区三区筱慧| 亚洲男人在线天堂网| 欧美乱妇无乱码一区二区| av破解版在线观看| 成人资源在线观看免费官网| 自拍偷拍日韩欧美亚洲| 亚洲视频在线视频看视频在线| 中文字幕人妻熟女在线电影| 日本三极片中文字幕| 亚洲在线免费h观看网站| 红杏久久av人妻一区| 99久久中文字幕一本人| 天天草天天色天天干| 青青尤物在线观看视频网站| 在线观看欧美黄片一区二区三区| 无码国产精品一区二区高潮久久4 日韩欧美一级精品在线观看 | 欧美精品欧美极品欧美视频| 91chinese在线视频| 国产精品午夜国产小视频 | 狠狠操操操操操操操操操| 一区二区三区欧美日韩高清播放| 内射久久久久综合网| 人妻少妇av在线观看| 亚洲超碰97人人做人人爱| 少妇ww搡性bbb91| 成人区人妻精品一区二视频| 人妻丝袜诱惑我操她视频| 午夜精彩视频免费一区| 亚洲精品中文字幕下载| 天天日天天爽天天爽| 日美女屁股黄邑视频| 日韩无码国产精品强奸乱伦| avjpm亚洲伊人久久| 国产精品黄片免费在线观看| 免费观看理论片完整版| 婷婷五月亚洲综合在线| av大全在线播放免费| 青青青青爽手机在线| 天堂va蜜桃一区入口| 美女大bxxxx内射| 99久久超碰人妻国产| 91精品视频在线观看免费| 狠狠操操操操操操操操操| 国产午夜亚洲精品不卡在线观看| 中文字幕在线乱码一区二区| 精品久久久久久久久久久a√国产| 久久精品视频一区二区三区四区| 免费观看国产综合视频| 91九色国产porny蝌蚪| 日韩少妇人妻精品无码专区| 免费成人av中文字幕| 少妇露脸深喉口爆吞精| 97人人妻人人澡人人爽人人精品| 日本欧美视频在线观看三区| 亚洲av可乐操首页| 欧美在线一二三视频| 91破解版永久免费| 亚洲在线一区二区欧美| 国产高清女主播在线| 在线网站你懂得老司机| 18禁美女羞羞免费网站| 成年人中文字幕在线观看| 91亚洲手机在线视频播放| 淫秽激情视频免费观看| 大肉大捧一进一出好爽在线视频| 免费费一级特黄真人片| 欧美精品 日韩国产| 欧美精品欧美极品欧美视频| 国产欧美精品不卡在线| 亚洲人妻30pwc| 日本18禁久久久久久| 亚洲va国产va欧美精品88| 一二三中文乱码亚洲乱码one| 3344免费偷拍视频| 在线免费观看日本片| gav成人免费播放| 亚洲最大免费在线观看| 男人插女人视频网站| 免费看国产av网站| 欧美日韩熟女一区二区三区| 五十路老熟女码av| 熟女在线视频一区二区三区| 天天操天天干天天艹| 伊人成人综合开心网| 日本阿v视频在线免费观看| 100%美女蜜桃视频| 久久久久91精品推荐99| 女人精品内射国产99| 国产密臀av一区二区三| 国产综合精品久久久久蜜臀| 国产成人一区二区三区电影网站 | 蜜桃久久久久久久人妻| 亚洲一级美女啪啪啪| 精品一区二区三区欧美| 国产一线二线三线的区别在哪| 国产午夜亚洲精品不卡在线观看| 中文字幕在线免费第一页| 欧美国产亚洲中英文字幕| 国产精品久久综合久久| 精品一区二区亚洲欧美| 乱亲女秽乱长久久久| 蜜桃色婷婷久久久福利在线| 男生舔女生逼逼视频| 一区二区三区 自拍偷拍| 亚洲av无硬久久精品蜜桃| 很黄很污很色的午夜网站在线观看 | 国产白嫩美女一区二区| 欧美黑人巨大性xxxxx猛交| 成人av天堂丝袜在线观看| 日本18禁久久久久久| 日韩一区二区电国产精品| 国产亚洲天堂天天一区| 色噜噜噜噜18禁止观看| 中文字幕国产专区欧美激情| 青青青青操在线观看免费| 1000部国产精品成人观看视频| 女蜜桃臀紧身瑜伽裤| 精品人人人妻人人玩日产欧| 视频在线免费观看你懂得| 中文字幕乱码人妻电影| 水蜜桃一区二区三区在线观看视频 | 欧美精品国产综合久久| 亚洲视频在线视频看视频在线| 四川乱子伦视频国产vip| 精品一区二区三四区| 无码精品一区二区三区人| 好吊视频—区二区三区| 自拍偷拍 国产资源| 男人天堂色男人av| 欧美日韩熟女一区二区三区| 天天操夜夜骑日日摸| 中文字幕在线欧美精品| 综合激情网激情五月天| 天天摸天天亲天天舔天天操天天爽| 亚洲成高清a人片在线观看| 精品人妻伦一二三区久| 欧美日韩一级黄片免费观看| 国产一区二区欧美三区| 11久久久久久久久久久| 国产性感美女福利视频| 日韩av熟妇在线观看| 人妻少妇性色欲欧美日韩| 亚洲中文字幕乱码区| 综合精品久久久久97| 亚洲一区二区久久久人妻| 五月色婷婷综合开心网4438| 国产视频在线视频播放| 天堂v男人视频在线观看| 欧美亚洲免费视频观看| 国产一区二区神马久久| 亚洲特黄aaaa片| 欧美久久一区二区伊人| 日本人妻少妇18—xx| 狠狠躁夜夜躁人人爽天天天天97| 黄色大片免费观看网站| 亚洲视频在线观看高清| 人妻另类专区欧美制服| 久久精品久久精品亚洲人| 亚洲在线观看中文字幕av| 蜜臀成人av在线播放| 成人av久久精品一区二区| 亚欧在线视频你懂的| 国产一区成人在线观看视频| 日本免费一级黄色录像| 欧美地区一二三专区| 精品一区二区三区在线观看| 欧美专区日韩专区国产专区| 999久久久久999| 国产福利在线视频一区| 成年人中文字幕在线观看| 99的爱精品免费视频| 好了av中文字幕在线| 成人av在线资源网站| 888亚洲欧美国产va在线播放| 久久久久久久亚洲午夜综合福利| 婷婷综合亚洲爱久久| 中国熟女一区二区性xx| 国产精品黄页网站视频| 亚洲高清自偷揄拍自拍| 亚洲欧美国产麻豆综合| 亚洲国产中文字幕啊啊啊不行了| 在线视频自拍第三页| 亚洲欧美国产麻豆综合| 亚洲国产成人最新资源| 一区二区视频在线观看免费观看| 国产精品人妻一区二区三区网站 | 在线免费观看日本伦理| 国产麻豆国语对白露脸剧情| 天天日天天日天天射天天干| 亚洲av无硬久久精品蜜桃| 国产97在线视频观看| 北条麻妃av在线免费观看| 日日夜夜狠狠干视频| av网站色偷偷婷婷网男人的天堂| 一区二区在线观看少妇| 2020国产在线不卡视频| 欧美 亚洲 另类综合| 日本韩国亚洲综合日韩欧美国产 | 成人24小时免费视频| 欧美视频一区免费在线| 特一级特级黄色网片| 亚洲国产香蕉视频在线播放| 后入美女人妻高清在线| 黄色三级网站免费下载| 五十路在线观看完整版| 2022中文字幕在线| 欧美日韩v中文在线| 免费观看污视频网站| 99热这里只有精品中文| 丝袜美腿欧美另类 中文字幕| 亚洲一区二区久久久人妻| 白白操白白色在线免费视频| 一区二区三区四区视频| 2022国产综合在线干| 色天天天天射天天舔| 欧美成人一二三在线网| 2020久久躁狠狠躁夜夜躁| 国产精品3p和黑人大战| 又色又爽又黄又刺激av网站| 中文字幕一区二 区二三区四区 | 天天想要天天操天天干| 亚洲午夜精品小视频| 97超碰免费在线视频| 自拍偷拍亚洲欧美在线视频| 黄色录像鸡巴插进去| 五十路丰满人妻熟妇| 男人和女人激情视频| 国产使劲操在线播放| 在线观看视频网站麻豆| 日比视频老公慢点好舒服啊| 青青青视频自偷自拍38碰| 91免费观看在线网站| 国内自拍第一页在线观看| 黄色视频在线观看高清无码| 夜夜躁狠狠躁日日躁麻豆内射 | 欧美色呦呦最新网址| 国产精品日韩欧美一区二区| 97黄网站在线观看| 天天日夜夜干天天操| 国产性感美女福利视频| 国产成人自拍视频播放| 亚洲国产免费av一区二区三区| av天堂中文免费在线| 伊人综合免费在线视频| 狠狠躁狠狠爱网站视频| 国产女人叫床高潮大片视频| 成年人免费看在线视频| 中文字幕av一区在线观看| 欧美黄片精彩在线免费观看| 自拍偷拍日韩欧美亚洲| 亚洲卡1卡2卡三卡四老狼| 国产女人露脸高潮对白视频| 激情伦理欧美日韩中文字幕| 青青伊人一精品视频| 亚洲激情偷拍一区二区| 亚洲精品午夜aaa久久| 欧洲亚洲欧美日韩综合| 做爰视频毛片下载蜜桃视频1| 国产精品日韩欧美一区二区| 超碰97人人澡人人| 涩涩的视频在线观看视频| 日韩欧美中文国产在线 | 日本性感美女写真视频| 直接能看的国产av| 日韩av熟妇在线观看| 日本免费一级黄色录像| 红桃av成人在线观看| 2020久久躁狠狠躁夜夜躁| 欧美第一页在线免费观看视频 | 99热这里只有精品中文| 亚洲人一区二区中文字幕| 搡老妇人老女人老熟女| 中文字幕日韩无敌亚洲精品| 久久国产精品精品美女| 国产一区二区三免费视频| 经典国语激情内射视频| 亚洲欧美激情人妻偷拍| 国产亚洲国产av网站在线| 1区2区3区4区视频在线观看| 9久在线视频只有精品| 97色视频在线观看| 80电影天堂网官网| 精品91自产拍在线观看一区| 午夜成午夜成年片在线观看| 中文字幕网站你懂的| 欧美日韩国产一区二区三区三州| 欧美va亚洲va天堂va| 91‖亚洲‖国产熟女| 一区二区三区在线视频福利| 免费在线观看污污视频网站| 超黄超污网站在线观看| 亚洲变态另类色图天堂网| 粉嫩欧美美人妻小视频| 九色精品视频在线播放| 午夜精品一区二区三区4| 国产综合精品久久久久蜜臀| 久久一区二区三区人妻欧美| 亚洲精品国产在线电影| 亚洲午夜精品小视频| av网址国产在线观看| 男人天堂av天天操| 国产第一美女一区二区三区四区| 97精品成人一区二区三区| 午夜91一区二区三区| 国产视频一区二区午夜| 福利视频广场一区二区| 久草视频在线一区二区三区资源站 | 午夜精品一区二区三区福利视频| 91精品国产91青青碰| yellow在线播放av啊啊啊| 日韩成人性色生活片| 黄色片年轻人在线观看| 欧美专区日韩专区国产专区| 久青青草视频手机在线免费观看 | 中国无遮挡白丝袜二区精品 | 欧美特级特黄a大片免费| 日韩成人免费电影二区| 青青青青青手机视频| 自拍偷区二区三区麻豆| 国产+亚洲+欧美+另类| av天堂中文字幕最新| 日韩av大胆在线观看| 骚逼被大屌狂草视频免费看| 99久久99一区二区三区| 韩国爱爱视频中文字幕| 亚洲一区二区激情在线| 国产精品久久久黄网站| 欧美成一区二区三区四区| 日韩欧美中文国产在线 | 久久午夜夜伦痒痒想咳嗽P| 国产精品手机在线看片| 538精品在线观看视频| 一个色综合男人天堂| 国产激情av网站在线观看| 青青青激情在线观看视频| 日韩欧美一级aa大片| 啊啊啊视频试看人妻| 11久久久久久久久久久| 日韩午夜福利精品试看| 888亚洲欧美国产va在线播放| 天天插天天色天天日| 黑人大几巴狂插日本少妇| 丰满熟女午夜福利视频| 日本一道二三区视频久久| 激情人妻校园春色亚洲欧美| 亚洲日本一区二区久久久精品| 自拍偷拍 国产资源| 亚洲国产欧美国产综合在线| 成人福利视频免费在线| yellow在线播放av啊啊啊| 果冻传媒av一区二区三区| 69精品视频一区二区在线观看| 又色又爽又黄的美女裸体| 午夜成午夜成年片在线观看| 日韩美女综合中文字幕pp| 欧美一区二区三区乱码在线播放| 伊人成人综合开心网| 视频二区在线视频观看| 老司机在线精品福利视频| 北条麻妃高跟丝袜啪啪| 偷拍自拍 中文字幕| 成人av免费不卡在线观看| 99av国产精品欲麻豆| 亚洲护士一区二区三区| 亚洲成人国产综合一区| 欧美一区二区三区激情啪啪啪 | 丝袜长腿第一页在线| 亚洲精品福利网站图片| 欧美亚洲少妇福利视频| 亚洲天堂av最新网址| 国产视频网站一区二区三区| 三级等保密码要求条款| 国产性生活中老年人视频网站| www骚国产精品视频| 亚洲另类综合一区小说| 在线观看的黄色免费网站| 91精品高清一区二区三区| 国产91精品拍在线观看| 欧美精品激情在线最新观看视频| 欧美成人精品欧美一级黄色| 少妇与子乱在线观看| 91高清成人在线视频| 精品亚洲国产中文自在线| 夜夜骑夜夜操夜夜奸| 一区二区三区另类在线| 日韩成人综艺在线播放| 2022国产精品视频| 免费69视频在线看| 欧美一区二区三区高清不卡tv| 91人妻人人做人人爽在线| 免费一级特黄特色大片在线观看| 亚洲免费视频欧洲免费视频| 日本一道二三区视频久久| 晚上一个人看操B片| 亚洲熟妇x久久av久久| 91麻豆精品91久久久久同性| 成年人黄色片免费网站| 青青尤物在线观看视频网站| 三级等保密码要求条款| 国产一区自拍黄视频免费观看| 伊拉克及约旦宣布关闭领空| 大香蕉福利在线观看| 黄色资源视频网站日韩| 欧美黄片精彩在线免费观看| 91在线视频在线精品3| 久久久久久久久久性潮| 最近中文2019年在线看| 黄工厂精品视频在线观看| 国产又大又黄免费观看| 亚洲成人国产综合一区| 男人天堂最新地址av| 成人亚洲国产综合精品| 一个人免费在线观看ww视频| 国产品国产三级国产普通话三级| 一二三中文乱码亚洲乱码one| 亚洲综合图片20p| 大学生A级毛片免费视频| 亚洲午夜精品小视频| 久久久久只精品国产三级| 1区2区3区4区视频在线观看| 久久人人做人人妻人人玩精品vr| 亚洲精品国产综合久久久久久久久| 精品一线二线三线日本| 天天干天天操天天玩天天射| 国产成人精品午夜福利训2021| 精品av国产一区二区三区四区| 国产日本精品久久久久久久| 97国产精品97久久| 国产视频一区在线观看| 99精品一区二区三区的区| 全国亚洲男人的天堂| 天天艹天天干天天操| 97黄网站在线观看| 99re国产在线精品| 三级等保密码要求条款| 久久国产精品精品美女| 国产麻豆剧果冻传媒app| 传媒在线播放国产精品一区| aiss午夜免费视频| 亚洲成av人无码不卡影片一| 人人妻人人澡欧美91精品| 亚洲第一黄色在线观看| 国产露脸对白在线观看| 一级A一级a爰片免费免会员| 久久久制服丝袜中文字幕| 日韩美av高清在线| 果冻传媒av一区二区三区 | 少妇人妻二三区视频| 日曰摸日日碰夜夜爽歪歪| 亚洲综合另类精品小说| 国产白袜脚足J棉袜在线观看| 99精品免费久久久久久久久a| 四川五十路熟女av| 天天干夜夜操啊啊啊| 男人插女人视频网站| 天堂av在线最新版在线| 综合国产成人在线观看| 高潮喷水在线视频观看| 亚洲欧美一区二区三区爱爱动图 | 亚洲成人精品女人久久久| 亚洲国产香蕉视频在线播放| 2020久久躁狠狠躁夜夜躁| 天天干夜夜操天天舔| 无码精品一区二区三区人| 伊人成人在线综合网| 97欧洲一区二区精品免费| 亚洲免费福利一区二区三区| 国产精品黄色的av| 四川五十路熟女av| 亚洲最大黄了色网站| 揄拍成人国产精品免费看视频| 亚洲av在线观看尤物| 亚洲天堂精品福利成人av| 久草视频福利在线首页| 亚洲激情唯美亚洲激情图片| 久草福利电影在线观看| 国产91精品拍在线观看| 国产男女视频在线播放| 国产污污污污网站在线| 欧美精产国品一二三区| 99久久久无码国产精品性出奶水 | 国产真实乱子伦a视频| 性感美女诱惑福利视频| 可以免费看的www视频你懂的| 精品av久久久久久久| 国产精品亚洲在线观看| 最近中文字幕国产在线| 51国产偷自视频在线播放| 亚洲免费视频欧洲免费视频| 五十路丰满人妻熟妇| 午夜影院在线观看视频羞羞羞| av视屏免费在线播放| 99国内小视频在现欢看| 欧美精品国产综合久久| 又黄又刺激的午夜小视频| 非洲黑人一级特黄片| 青青操免费日综合视频观看| 国产在线一区二区三区麻酥酥| 黑人3p华裔熟女普通话| 午夜精品一区二区三区城中村| 福利视频网久久91| 成人24小时免费视频| 亚洲精品久久视频婷婷| 日本丰满熟妇BBXBBXHD| 99国内小视频在现欢看| 国产欧美日韩第三页| 青青在线视频性感少妇和隔壁黑丝| 国产三级片久久久久久久| 不卡一区一区三区在线| 精品国产亚洲av一淫| 日本免费午夜视频网站| 岛国青草视频在线观看| 国产精品视频欧美一区二区| 91超碰青青中文字幕| 少妇露脸深喉口爆吞精| 人妻少妇性色欲欧美日韩| 亚洲中文精品人人免费| 久久这里只有精品热视频 | 精产国品久久一二三产区区别| 青青草原网站在线观看| 亚洲国产香蕉视频在线播放| 骚逼被大屌狂草视频免费看| 国产精品精品精品999| 性色av一区二区三区久久久| 亚洲国产成人av在线一区| 97人妻无码AV碰碰视频| 亚洲综合一区成人在线| 亚洲欧美成人综合视频| 福利在线视频网址导航| 国产成人精品福利短视频| 免费看国产又粗又猛又爽又黄视频| 亚洲成人三级在线播放| 人妻少妇中文有码精品| 日本免费视频午夜福利视频| 欧美精品资源在线观看| av大全在线播放免费| 日本18禁久久久久久| 国产在线自在拍91国语自产精品| 色婷婷六月亚洲综合香蕉| 欧美一区二区中文字幕电影| 亚洲视频在线观看高清| 免费国产性生活视频| 亚洲天天干 夜夜操| 青娱乐最新视频在线| 欧美成人精品在线观看| 色综合久久无码中文字幕波多| 五十路丰满人妻熟妇| 国产综合高清在线观看| 在线观看视频一区麻豆| 瑟瑟视频在线观看免费视频| 国产视频一区二区午夜| 亚洲一区二区三区五区| 在线免费观看日本片| 免费一级黄色av网站| 国产欧美精品一区二区高清| 欧美精品久久久久久影院| 色呦呦视频在线观看视频| 日韩美女精品视频在线观看网站 | 男人在床上插女人视频| 大鸡巴后入爆操大屁股美女| 欧美黑人性暴力猛交喷水| 欧美性感尤物人妻在线免费看| 国产真实灌醉下药美女av福利| 男人在床上插女人视频| 91 亚洲视频在线观看| 成年人午夜黄片视频资源| 亚洲精品 日韩电影| 青青青青青青青青青青草青青 | 免费人成黄页网站在线观看国产| 又粗又硬又猛又黄免费30| 热思思国产99re| 肏插流水妹子在线乐播下载| 中文字幕人妻熟女在线电影| 色秀欧美视频第一页| 91国产在线免费播放| 亚洲伊人av天堂有码在线| 丰满的继坶3中文在线观看| 精品国产污污免费网站入口自| 欧美专区第八页一区在线播放| 大鸡八强奸视频在线观看| 欧美在线精品一区二区三区视频| 国产一级精品综合av| 国产揄拍高清国内精品对白 | 熟女人妻在线中出观看完整版| 亚洲一区二区三区在线高清| 亚洲高清国产自产av| 黄色片一级美女黄色片| 国产亚洲精品视频合集| 久久久久久国产精品| 亚洲中文精品字幕在线观看| 91久久国产成人免费网站| 视频在线亚洲一区二区| 青青社区2国产视频| 成年人免费看在线视频| 亚洲精品亚洲人成在线导航| 欧美80老妇人性视频| 在线亚洲天堂色播av电影| 换爱交换乱高清大片| 在线视频国产欧美日韩| 亚洲黄色av网站免费播放| 五月色婷婷综合开心网4438| 亚洲激情,偷拍视频| 人妻爱爱 中文字幕| 漂亮 人妻被中出中文| 国产一区av澳门在线观看| 日本最新一二三区不卡在线| 亚洲欧美激情中文字幕| 中文字幕 亚洲av| 午夜av一区二区三区| 亚洲天堂有码中文字幕视频| 在线观看视频网站麻豆| 亚洲特黄aaaa片| 韩国三级aaaaa高清视频| 国产麻豆国语对白露脸剧情| 成年女人免费播放视频| 中出中文字幕在线观看| 欧美黄色录像免费看的| 色婷婷综合激情五月免费观看 | 欧美va亚洲va天堂va| 国产在线观看免费人成短视频| av新中文天堂在线网址| 天天躁日日躁狠狠躁躁欧美av| 国产成人精品午夜福利训2021| 久久久久久久精品老熟妇| 青草久久视频在线观看| 99热这里只有精品中文| 日本成人一区二区不卡免费在线| 国产片免费观看在线观看| 欲满人妻中文字幕在线| 综合国产成人在线观看| 色综合色综合色综合色| 老司机午夜精品视频资源| 亚洲福利精品福利精品福利| 午夜久久久久久久99| 亚洲人妻av毛片在线| 成人av天堂丝袜在线观看| 黄色在线观看免费观看在线| 国产成人一区二区三区电影网站| 一区二区三区精品日本| 免费大片在线观看视频网站| 国产视频在线视频播放| 夜夜嗨av一区二区三区中文字幕| 粉嫩av蜜乳av蜜臀| 日本女人一级免费片| 伊人综合免费在线视频| 亚洲av无硬久久精品蜜桃| 免费在线福利小视频| 91人妻精品一区二区在线看| 黑人巨大精品欧美视频| 孕妇奶水仑乱A级毛片免费看| eeuss鲁片一区二区三区| 欧美麻豆av在线播放| 黄色三级网站免费下载| 激情啪啪啪啪一区二区三区| 五色婷婷综合狠狠爱| 欧美另类z0z变态| 国产福利在线视频一区| 人妻自拍视频中国大陆| 免费岛国喷水视频在线观看| 午夜免费体验区在线观看| 国产精品午夜国产小视频| 国产亚洲精品视频合集| 啊用力插好舒服视频| 色97视频在线播放| 青青青青草手机在线视频免费看| 亚洲在线观看中文字幕av| 狠狠操操操操操操操操操| 最新的中文字幕 亚洲| 天天日天天爽天天干| 亚洲国产精品久久久久久6| 无码精品一区二区三区人| 国产又粗又猛又爽又黄的视频美国| 巨乳人妻日下部加奈被邻居中出| 日本三极片视频网站观看| 亚洲中文精品字幕在线观看| 超碰97免费人妻麻豆| 日本韩国免费一区二区三区视频| 午夜在线精品偷拍一区二| 91精品综合久久久久3d动漫| 开心 色 六月 婷婷| 国产亚州色婷婷久久99精品| 夏目彩春在线中文字幕| 国产黄色片蝌蚪九色91| caoporm超碰国产| 中文字幕日韩精品就在这里| 亚洲综合在线观看免费| 91超碰青青中文字幕| 全国亚洲男人的天堂| 国产亚洲四十路五十路| 日韩人妻在线视频免费| 岛国一区二区三区视频在线| 人妻久久无码中文成人| 久久久极品久久蜜桃| 亚洲精品在线资源站| 精品国产污污免费网站入口自 | 很黄很污很色的午夜网站在线观看| 同居了嫂子在线播高清中文| 特级欧美插插插插插bbbbb| 国产+亚洲+欧美+另类| 欲满人妻中文字幕在线| 久久久超爽一二三av| 绯色av蜜臀vs少妇| 一级a看免费观看网站| 国产91精品拍在线观看| 大鸡巴插入美女黑黑的阴毛| 亚洲va天堂va国产va久| 人人人妻人人澡人人| 久草视频首页在线观看| 97超碰最新免费在线观看| 少妇与子乱在线观看| 无码中文字幕波多野不卡| 韩国亚洲欧美超一级在线播放视频| 午夜精品久久久久久99热| 自拍偷拍一区二区三区图片| 18禁美女羞羞免费网站| 成人av在线资源网站| 久久一区二区三区人妻欧美| 欧美成人精品在线观看| 欧美aa一级一区三区四区| av视屏免费在线播放| 国产视频一区二区午夜| 国产普通话插插视频| 精品人妻一二三区久久| a v欧美一区=区三区| 一个人免费在线观看ww视频| 久久久麻豆精亚洲av麻花| 免费十精品十国产网站| 最新91精品视频在线| 九色视频在线观看免费| 2020国产在线不卡视频 | 一本久久精品一区二区| 大香蕉大香蕉大香蕉大香蕉大香蕉| 狠狠躁夜夜躁人人爽天天天天97| 超碰公开大香蕉97| 一区二区三区四区中文| 国产露脸对白在线观看| 国产成人综合一区2区| 人妻丝袜榨强中文字幕| 中文字幕视频一区二区在线观看| 3337p日本欧洲大胆色噜噜| 一本一本久久a久久精品综合不卡| 亚洲国产精品久久久久久6| 国产亚洲视频在线二区| av资源中文字幕在线观看| 亚洲av日韩av网站| 极品丝袜一区二区三区| 色噜噜噜噜18禁止观看| 91精品视频在线观看免费| 综合色区亚洲熟妇shxstz| 亚洲第一黄色在线观看| 欧洲国产成人精品91铁牛tv| 大肉大捧一进一出好爽在线视频 | 蜜桃视频入口久久久| 99精品久久久久久久91蜜桃| 视频一区二区在线免费播放| 亚洲在线观看中文字幕av| 亚洲欧美一区二区三区爱爱动图| 一区二区麻豆传媒黄片| rct470中文字幕在线| 一区二区麻豆传媒黄片| 欧美另类重口味极品在线观看| 一区二区视频在线观看免费观看 | av天堂资源最新版在线看| 亚洲欧美在线视频第一页| 日本少妇高清视频xxxxx| 日韩二区视频一线天婷婷五| 中文字幕高清免费在线人妻| 欧美久久久久久三级网| 黄色中文字幕在线播放| 亚洲精品乱码久久久本| 日本少妇的秘密免费视频| 福利视频一区二区三区筱慧| 在线可以看的视频你懂的| 热99re69精品8在线播放| av在线免费中文字幕| 色综合久久五月色婷婷综合| av手机在线观播放网站| 亚洲成a人片777777| 久久久人妻一区二区| 十八禁在线观看地址免费| 亚洲第17页国产精品| 国产精品自拍偷拍a| 国产精品一二三不卡带免费视频 | 欧美爆乳肉感大码在线观看| 9久在线视频只有精品| 香港一级特黄大片在线播放| 亚洲av在线观看尤物| 亚洲国产精品美女在线观看| 青草青永久在线视频18| 91社福利《在线观看| 成人乱码一区二区三区av| 韩国亚洲欧美超一级在线播放视频| av久久精品北条麻妃av观看| 91福利视频免费在线观看| 边摸边做超爽毛片18禁色戒 | 免费av岛国天堂网站| 夏目彩春在线中文字幕| 2020国产在线不卡视频 | 91亚洲手机在线视频播放| 久久热这里这里只有精品| 大尺度激情四射网站| 久久久久久97三级| 国产亚洲视频在线二区| 超碰公开大香蕉97| 亚洲中文精品人人免费| 在线免费观看日本伦理| 一区二区三区欧美日韩高清播放| 亚洲乱码中文字幕在线| 色97视频在线播放| 骚逼被大屌狂草视频免费看| 中文字幕在线视频一区二区三区| 久久精品国产999| 色综合色综合色综合色| 久久精品久久精品亚洲人| xxx日本hd高清| 欧美日韩激情啪啪啪| sw137 中文字幕 在线| 亚洲蜜臀av一区二区三区九色 | 国产精品精品精品999| 欧美成人精品在线观看| 国产精彩对白一区二区三区| 黄色无码鸡吧操逼视频| 九色精品视频在线播放| 亚洲福利天堂久久久久久| 欲满人妻中文字幕在线| 天天插天天色天天日| av一区二区三区人妻| 免费黄色成人午夜在线网站| 国产精品大陆在线2019不卡| 亚洲人成精品久久久久久久| 欧美在线精品一区二区三区视频| 国产欧美精品不卡在线| 国产精品视频一区在线播放| 亚洲中文精品人人免费| 美女福利写真在线观看视频| 国产麻豆乱子伦午夜视频观看| 日本女人一级免费片| 一区二区三区的久久的蜜桃的视频| 日韩精品电影亚洲一区| 亚洲福利天堂久久久久久| 亚洲青青操骚货在线视频| 国产一区二区欧美三区| 亚洲天堂第一页中文字幕| 人妻少妇性色欲欧美日韩| 大白屁股精品视频国产| 福利片区一区二体验区| 手机看片福利盒子日韩在线播放| 午夜国产福利在线观看| 亚洲成人国产av在线| 东京热男人的av天堂| 2021天天色天天干| 99热99这里精品6国产| 91精品国产91青青碰| 丰满少妇人妻xxxxx| 天天干天天操天天扣| 78色精品一区二区三区| 四川五十路熟女av| 又粗又长 明星操逼小视频| 天天日天天干天天干天天日| 亚洲熟女久久久36d| 日本午夜福利免费视频| 福利视频广场一区二区| 男生舔女生逼逼的视频| 中出中文字幕在线观看| 国产精品久久久久国产三级试频 | 涩涩的视频在线观看视频| 亚洲av无码成人精品区辽| jiuse91九色视频| 97a片免费在线观看| 自拍偷拍,中文字幕| 日韩视频一区二区免费观看| 任你操视频免费在线观看| 91av精品视频在线| 蜜桃视频在线欧美一区| 午夜久久香蕉电影网| jul—619中文字幕在线| 91中文字幕最新合集| 午夜美女少妇福利视频| 国产成人无码精品久久久电影| 日韩av免费观看一区| 福利视频广场一区二区| 日韩av大胆在线观看| 免费看高清av的网站| 欧美偷拍自拍色图片| 亚洲人成精品久久久久久久| 天天摸天天干天天操科普| 午夜精品一区二区三区福利视频| 国产精品中文av在线播放| 亚洲 中文 自拍 无码| 99精品国产自在现线观看| 欧美中文字幕一区最新网址| 中国无遮挡白丝袜二区精品| 亚洲熟妇无码一区二区三区| 91高清成人在线视频| 精品人妻伦一二三区久| 综合页自拍视频在线播放| 中英文字幕av一区| 经典亚洲伊人第一页| 久久久久久性虐视频| 亚洲视频在线观看高清| 男人天堂色男人av| 92福利视频午夜1000看| 免费观看国产综合视频| 九色视频在线观看免费| 岛国av高清在线成人在线| 亚洲码av无色中文| 中文字幕,亚洲人妻| 综合色区亚洲熟妇shxstz| 欧美xxx成人在线| 午夜国产免费福利av| 国产熟妇一区二区三区av| 黄片三级三级三级在线观看| 青青青青青青青在线播放视频| 欧美中国日韩久久精品| 性色蜜臀av一区二区三区| 小穴多水久久精品免费看| 亚洲精品无码色午夜福利理论片| 美味人妻2在线播放| 天天日天天日天天擦| 亚洲av男人的天堂你懂的| 91精品一区二区三区站长推荐| 免费成人va在线观看| 沈阳熟妇28厘米大战黑人| 亚洲天堂av最新网址| 欧美 亚洲 另类综合| 中文字幕成人日韩欧美| 91传媒一区二区三区| 天天干天天操天天插天天日| 66久久久久久久久久久| 91桃色成人网络在线观看| 亚洲国产精品中文字幕网站| 国产精品熟女久久久久浪潮| 岛国av高清在线成人在线| 污污小视频91在线观看| 91精品国产黑色丝袜| 欧美一区二区三区乱码在线播放| 国产又粗又黄又硬又爽| 国产一级麻豆精品免费| 97瑟瑟超碰在线香蕉| 啊慢点鸡巴太大了啊舒服视频| 春色激情网欧美成人| av手机在线观播放网站| av中文字幕在线导航| 日韩少妇人妻精品无码专区| 中国黄色av一级片| 久久麻豆亚洲精品av| 中文字幕日本人妻中出| 久久精品国产23696| 中文字幕人妻被公上司喝醉在线| 国产又粗又猛又爽又黄的视频美国| 超碰在线观看免费在线观看| 国产中文字幕四区在线观看| 午夜精品一区二区三区4| 美女日逼视频免费观看| 日本少妇人妻xxxxxhd| 欧美va不卡视频在线观看| 中文字幕在线永久免费播放| 大香蕉大香蕉在线有码 av| 国产一区二区欧美三区| 国产大学生援交正在播放| 夜夜嗨av一区二区三区中文字幕| 久久久久久久亚洲午夜综合福利| 国产真实乱子伦a视频| 大白屁股精品视频国产| 国产精品久久久久久美女校花| 一级a看免费观看网站| 亚洲欧美另类自拍偷拍色图| 天堂av在线播放免费| 欧美成人综合色在线噜噜| tube69日本少妇| 久久久精品欧洲亚洲av| 视频啪啪啪免费观看| 午夜免费体验区在线观看| 青青草在观免费国产精品| 狠狠躁夜夜躁人人爽天天久天啪| 欧美一区二区中文字幕电影 | 亚洲成人情色电影在线观看| 亚洲特黄aaaa片| 久久这里有免费精品| 瑟瑟视频在线观看免费视频| 在线观看操大逼视频| 成人av电影免费版| 日韩av有码中文字幕| av无限看熟女人妻另类av| 98视频精品在线观看| 社区自拍揄拍尻屁你懂的| 蜜桃久久久久久久人妻| 成熟熟女国产精品一区| 中文字幕第三十八页久久| 欧美精品一区二区三区xxxx| 人妻av无码专区久久绿巨人| 91av中文视频在线| 人妻少妇av在线观看| 在线视频国产欧美日韩| 91麻豆精品传媒国产黄色片| 亚洲视频在线观看高清| 最新激情中文字幕视频| 啪啪啪18禁一区二区三区 | 91精品免费久久久久久| 国产一级精品综合av| 欧美精产国品一二三区| 婷婷综合亚洲爱久久| 日韩美女综合中文字幕pp| 自拍偷拍日韩欧美亚洲| 国产大学生援交正在播放| 成人免费公开视频无毒 | 亚洲av色图18p| 果冻传媒av一区二区三区| 一区二区三区四区中文| 天天爽夜夜爽人人爽QC| 日美女屁股黄邑视频| 换爱交换乱高清大片| 人妻素人精油按摩中出| 国产男女视频在线播放| av在线免费观看亚洲天堂| 日本在线一区二区不卡视频| 日本一二三中文字幕| 国产91精品拍在线观看| 亚洲一区av中文字幕在线观看| 亚洲 图片 欧美 图片| 国产精品手机在线看片| 日韩欧美一级黄片亚洲| 国产伊人免费在线播放| 黄色成人在线中文字幕| 亚洲欧美色一区二区| 99久久久无码国产精品性出奶水| 人妻无码色噜噜狠狠狠狠色| 日韩三级黄色片网站| 天天射夜夜操综合网| 成人蜜臀午夜久久一区| 2020久久躁狠狠躁夜夜躁| 亚洲精品欧美日韩在线播放| 亚洲天堂有码中文字幕视频| 红杏久久av人妻一区| av俺也去在线播放| 欧美香蕉人妻精品一区二区| 日韩人妻xxxxx| 黑人巨大的吊bdsm| 深夜男人福利在线观看| 看一级特黄a大片日本片黑人| 超污视频在线观看污污污| 91精品国产高清自在线看香蕉网 | 大尺度激情四射网站| 中国老熟女偷拍第一页| 91社福利《在线观看| 97超碰免费在线视频| 国产九色91在线观看精品| 成年人中文字幕在线观看| 国产露脸对白在线观看| 欧美日韩不卡一区不区二区| 在线免费视频 自拍| 亚洲国产成人最新资源| 精品人妻伦一二三区久| av网址国产在线观看| 高清一区二区欧美系列| 1区2区3区4区视频在线观看| 免费人成黄页网站在线观看国产| a v欧美一区=区三区| 岛国免费大片在线观看| 人妻熟女中文字幕aⅴ在线| 亚洲在线免费h观看网站| 亚洲久久午夜av一区二区| 小泽玛利亚视频在线观看| 最新国产精品拍在线观看| 青娱乐极品视频青青草| 桃色视频在线观看一区二区| 91chinese在线视频| av老司机亚洲一区二区| 91av精品视频在线| 91精品国产麻豆国产| 午夜精品久久久久麻豆影视| 韩国爱爱视频中文字幕| 91免费观看国产免费| 国产熟妇乱妇熟色T区| 绝色少妇高潮3在线观看| 免费费一级特黄真人片| 人妻最新视频在线免费观看| 91九色国产熟女一区二区| 精品av国产一区二区三区四区| 国产成人综合一区2区| 日韩精品中文字幕福利| japanese日本熟妇另类| 非洲黑人一级特黄片| 亚洲伊人久久精品影院一美女洗澡 | 女生自摸在线观看一区二区三区 | 免费在线福利小视频| 色综合久久五月色婷婷综合| 91精品国产91久久自产久强| 精品91自产拍在线观看一区| 亚洲国产精品免费在线观看| 亚洲国产精品美女在线观看| 91国产在线免费播放| 亚洲国产精品久久久久蜜桃| 老司机99精品视频在线观看| 93人妻人人揉人人澡人人| 久久热这里这里只有精品| 孕妇奶水仑乱A级毛片免费看| 大香蕉伊人中文字幕| 日韩人妻在线视频免费| 把腿张开让我插进去视频| 日韩人妻xxxxx| 国产超码片内射在线| 欧美另类重口味极品在线观看| 国产欧美精品不卡在线| 色在线观看视频免费的| 1000部国产精品成人观看视频| 香港一级特黄大片在线播放| 欧美一区二区三区久久久aaa| 天天日夜夜操天天摸 | 老司机午夜精品视频资源 | 免费看高清av的网站| 在线观看av观看av| 日韩欧美制服诱惑一区在线| 蜜桃视频17c在线一区二区| 日本又色又爽又黄又粗| 欧美偷拍自拍色图片| 亚洲av日韩av第一区二区三区| 超pen在线观看视频公开97| 无套猛戳丰满少妇人妻| 婷婷综合亚洲爱久久| 人妻另类专区欧美制服| 亚洲综合另类精品小说| 国产 在线 免费 精品| 亚国产成人精品久久久| 91av精品视频在线| 青青青青青操视频在线观看| 一区二区三区av高清免费| 人妻自拍视频中国大陆| 特一级特级黄色网片| 亚欧在线视频你懂的| 日本三极片视频网站观看| 久久久久久久亚洲午夜综合福利 | 蜜桃久久久久久久人妻| 中文字幕日韩精品就在这里| 国产精品人妻熟女毛片av久| 中文字幕av第1页中文字幕| 老司机免费视频网站在线看| 国产精品福利小视频a| 中文字幕人妻av在线观看| 国产精品久久久久久美女校花| 91久久精品色伊人6882| 伊人综合aⅴ在线网| 91九色国产熟女一区二区| 亚洲av男人天堂久久| 亚洲成人精品女人久久久| 只有精品亚洲视频在线观看| 福利在线视频网址导航| 91一区精品在线观看| 人妻无码色噜噜狠狠狠狠色| 黄色录像鸡巴插进去| 大鸡巴操b视频在线| 日本一二三区不卡无| 97人妻人人澡爽人人精品| 少妇高潮无套内谢麻豆| 免费在线看的黄片视频| 国产成人精品久久二区91| 日本性感美女视频网站| 91快播视频在线观看| 97瑟瑟超碰在线香蕉| 亚洲综合在线视频可播放| 亚洲高清一区二区三区视频在线| 欧美日本aⅴ免费视频| xxx日本hd高清| 亚洲综合一区二区精品久久| 亚洲一区制服丝袜美腿| 日辽宁老肥女在线观看视频| 欧美一区二区三区乱码在线播放| 激情图片日韩欧美人妻| 沙月文乃人妻侵犯中文字幕在线| 无套猛戳丰满少妇人妻| 亚洲 欧美 精品 激情 偷拍| 天天干天天操天天扣| 国产精品成人xxxx| 99久久超碰人妻国产| 久久尻中国美女视频| 亚洲av日韩av网站| 欧美日本aⅴ免费视频| 夏目彩春在线中文字幕| 91av精品视频在线| 中文 成人 在线 视频| 欧美精品一二三视频| 国产精品自拍视频大全| 亚洲精品欧美日韩在线播放| 男人的天堂在线黄色| 成人24小时免费视频| 夜夜嗨av蜜臀av| 日韩av有码一区二区三区4| 超黄超污网站在线观看| 直接观看免费黄网站| lutube在线成人免费看| 丝袜亚洲另类欧美变态| 桃色视频在线观看一区二区 | 狠狠躁夜夜躁人人爽天天天天97| 欧美一级视频一区二区| 亚洲欧美清纯唯美另类| 久久午夜夜伦痒痒想咳嗽P| 超级福利视频在线观看| 黑人大几巴狂插日本少妇| 中文字幕av一区在线观看| 精品av国产一区二区三区四区 | 韩国男女黄色在线观看| 欧美va亚洲va天堂va| 亚洲欧洲一区二区在线观看| 亚洲护士一区二区三区| 特级欧美插插插插插bbbbb| 日韩不卡中文在线视频网站| 亚洲高清免费在线观看视频| 91精品国产麻豆国产| 蜜桃色婷婷久久久福利在线| 五月天久久激情视频| 国产一级麻豆精品免费| 色av色婷婷人妻久久久精品高清| 99久久成人日韩欧美精品| 风流唐伯虎电视剧在线观看| 青青青青青操视频在线观看| 在线视频国产欧美日韩| 日本午夜爽爽爽爽爽视频在线观看| 大鸡巴操娇小玲珑的女孩逼| 亚洲高清自偷揄拍自拍| 国产欧美精品不卡在线| 日本人妻少妇18—xx| 在线免费观看日本伦理| 97小视频人妻一区二区| 超碰97人人做人人爱| 久久久久久久久久性潮| 91国内精品自线在拍白富美| av一本二本在线观看| 亚洲码av无色中文| 欧美日韩不卡一区不区二区| 99精品视频之69精品视频 | 日本一本午夜在线播放| 精品久久久久久久久久中文蒉| 亚洲一级特黄特黄黄色录像片| 丝袜美腿欧美另类 中文字幕| 狠狠的往里顶撞h百合| 欧美少妇性一区二区三区| 国产 在线 免费 精品| 精品国产在线手机在线| 免费福利av在线一区二区三区| 久久午夜夜伦痒痒想咳嗽P| 最后99天全集在线观看| 亚洲熟女久久久36d| 日韩三级电影华丽的外出| 狠狠躁狠狠爱网站视频| 色吉吉影音天天干天天操| 国产精品亚洲在线观看| 黑人借宿ntr人妻的沦陷2| 蜜臀av久久久久久久| 亚洲国产精品免费在线观看| 91中文字幕免费在线观看| 亚洲激情,偷拍视频| 污污小视频91在线观看| 欧美一级视频一区二区| 加勒比视频在线免费观看| 欧美日本aⅴ免费视频| 午夜精品福利一区二区三区p| 成人av久久精品一区二区| 亚洲av男人的天堂你懂的| 美洲精品一二三产区区别| 中文字幕成人日韩欧美| 中国熟女@视频91| 免费在线看的黄片视频| 综合页自拍视频在线播放| 国产精选一区在线播放| chinese国产盗摄一区二区 | 久草视频在线免播放| 不卡一不卡二不卡三| 亚洲成av人无码不卡影片一| 亚洲中文字幕人妻一区| 熟女人妻在线观看视频| 色综合久久五月色婷婷综合| 成人影片高清在线观看| 啊啊啊视频试看人妻| 国产美女一区在线观看| 好太好爽好想要免费| 欧美视频不卡一区四区| 日韩一区二区电国产精品| 青青草成人福利电影| 青青尤物在线观看视频网站| 人妻久久无码中文成人| 91天堂天天日天天操| 色综合天天综合网国产成人| 中文字幕网站你懂的| 2022国产精品视频| 亚洲国产美女一区二区三区软件| 亚洲欧美福利在线观看| 在线播放国产黄色av| 男生用鸡操女生视频动漫| 中国黄色av一级片| 国产成人一区二区三区电影网站 | 亚洲欧洲一区二区在线观看| 亚洲男人的天堂a在线| av天堂加勒比在线| 午夜大尺度无码福利视频| 唐人色亚洲av嫩草| 日本午夜久久女同精女女| 日韩a级精品一区二区| 国产精品人妻一区二区三区网站| 伊人综合免费在线视频| 国产一区自拍黄视频免费观看| 久久久久久久久久性潮| 白白操白白色在线免费视频| 国产av欧美精品高潮网站| 美女少妇亚洲精选av| 日韩中文字幕福利av| 日本a级视频老女人| 男生舔女生逼逼视频| 风流唐伯虎电视剧在线观看| av老司机亚洲一区二区| 亚洲国产美女一区二区三区软件 | 国产普通话插插视频| 中文字日产幕乱六区蜜桃| 精品国产亚洲av一淫| 天天爽夜夜爽人人爽QC| 亚洲av琪琪男人的天堂| 91chinese在线视频| 亚洲精品av在线观看| 91精品激情五月婷婷在线| 污污小视频91在线观看| 一区二区视频在线观看免费观看 | 亚洲激情,偷拍视频| 九一传媒制片厂视频在线免费观看| 午夜精品一区二区三区更新| 欧美日韩不卡一区不区二区| 在线播放国产黄色av| 日韩不卡中文在线视频网站| 欧美成人精品在线观看| 亚洲av自拍天堂网| 一个色综合男人天堂| 热99re69精品8在线播放| 黑人乱偷人妻中文字幕| 成人性爱在线看四区| 亚洲成人av在线一区二区| 欧洲精品第一页欧洲精品亚洲 | 国产视频网站一区二区三区| 韩国AV无码不卡在线播放| 久久久91蜜桃精品ad| 久草福利电影在线观看| 国产黄色片在线收看| 亚洲成人情色电影在线观看| 日韩国产乱码中文字幕| 天天日天天爽天天干| 97人人妻人人澡人人爽人人精品| 99精品久久久久久久91蜜桃| 最新91精品视频在线| 91色老99久久九九爱精品| 中文字幕高清在线免费播放 | 亚洲粉嫩av一区二区三区| 欧美一级色视频美日韩| 亚洲免费va在线播放| 在线观看国产网站资源| 亚洲精品欧美日韩在线播放| 国产亚洲精品欧洲在线观看| 欧美成人小视频在线免费看| 97青青青手机在线视频| 2018最新中文字幕在线观看| 三级等保密码要求条款| 国产成人午夜精品福利| 精品国产午夜视频一区二区| 天堂中文字幕翔田av| 骚货自慰被发现爆操| 天天躁日日躁狠狠躁躁欧美av| 啪啪啪18禁一区二区三区| 天天干天天插天天谢| 精品首页在线观看视频| 欧美视频一区免费在线| 国产黄色片在线收看| eeuss鲁片一区二区三区| 春色激情网欧美成人| 天天操夜夜骑日日摸| 一区二区三区精品日本| 国产亚洲精品视频合集| 中文字幕 亚洲av| 大陆精品一区二区三区久久| 亚洲成人线上免费视频观看| 91福利视频免费在线观看| 久久久久久cao我的性感人妻| 沙月文乃人妻侵犯中文字幕在线| 日本少妇精品免费视频| 国产综合高清在线观看| 亚洲福利精品福利精品福利| 老司机免费视频网站在线看| 亚洲视频乱码在线观看| 91自产国产精品视频| 国产va精品免费观看| 2021久久免费视频| 国产三级精品三级在线不卡| 亚洲精品精品国产综合| 天天色天天操天天透| 亚洲国产香蕉视频在线播放| 精品久久久久久久久久久99| 懂色av蜜桃a v| 2021最新热播中文字幕| 一区二区三区麻豆福利视频| 亚洲成a人片777777| 亚洲人妻av毛片在线| 精品视频中文字幕在线播放| 欧美特级特黄a大片免费| 一级黄片久久久久久久久| 2022精品久久久久久中文字幕| 在线新三级黄伊人网| 中文字幕在线一区精品| 在线免费观看日本伦理| 色哟哟在线网站入口| 在线不卡成人黄色精品| AV天堂一区二区免费试看| 中字幕人妻熟女人妻a62v网| 在线观看av亚洲情色| 国产高清女主播在线| chinese国产盗摄一区二区| 久草视频福利在线首页| 激情啪啪啪啪一区二区三区| 人人爽亚洲av人人爽av| 日韩北条麻妃一区在线| 人人妻人人人操人人人爽| 激情图片日韩欧美人妻| AV天堂一区二区免费试看| 日本韩国免费福利精品| 国产精品国产三级国产精东| 亚洲图库另类图片区| 亚洲一级 片内射视正片| 欧美在线精品一区二区三区视频| 亚洲一区二区三区久久午夜| 欧美精品久久久久久影院| 欧美香蕉人妻精品一区二区| av在线免费资源站| 91色老99久久九九爱精品| 丰满少妇人妻xxxxx| 久久农村老妇乱69系列| 亚洲中文字幕国产日韩| 亚洲精品无码久久久久不卡 | 国产一级麻豆精品免费| 亚洲 国产 成人 在线| 国内资源最丰富的网站| 真实国产乱子伦一区二区| 中文字幕亚洲久久久| 亚洲成人av一区在线| 欧美熟妇一区二区三区仙踪林| 亚洲码av无色中文| 青草久久视频在线观看| 中文字幕在线一区精品| 鸡巴操逼一级黄色气| 成人av电影免费版| 国产精品久久久久久久久福交| 久久久久久97三级| 91精品一区二区三区站长推荐| 中文字幕一区二区三区蜜月| 亚洲中文字幕人妻一区| 9久在线视频只有精品| 黄色视频成年人免费观看| 国产极品精品免费视频| 夜夜操,天天操,狠狠操| 欧美怡红院视频在线观看| 天天干天天啪天天舔| 国产大学生援交正在播放| 日本成人不卡一区二区| 性色av一区二区三区久久久| 在线国产中文字幕视频| 一二三区在线观看视频| 清纯美女在线观看国产| 亚洲推理片免费看网站| 日韩精品一区二区三区在线播放| 久久尻中国美女视频| 免费观看理论片完整版| 青青青国产免费视频| 成人av电影免费版| 大黑人性xxxxbbbb| 女同性ⅹxx女同h偷拍| 精品少妇一二三视频在线| 亚洲综合在线视频可播放| 久草视频在线一区二区三区资源站 | 国产女孩喷水在线观看| 欧美xxx成人在线| 中文字幕+中文字幕| 亚洲免费av在线视频| 韩国女主播精品视频网站| 亚洲午夜伦理视频在线| 国产精品污污污久久| 日本真人性生活视频免费看| 大白屁股精品视频国产| 日韩国产乱码中文字幕| 99热久久极品热亚洲| 久久久久久久一区二区三| 在线观看欧美黄片一区二区三区| 韩国女主播精品视频网站| 欧美精品资源在线观看| 大香蕉大香蕉在线看| 黑人性生活视频免费看| 亚洲va国产va欧美精品88| 国产黄色a级三级三级三级| 国产大学生援交正在播放| 黑人变态深video特大巨大| 老熟妇xxxhd老熟女| 亚洲一级av无码一级久久精品| 日本熟女50视频免费| 日本av高清免费网站| 欧美熟妇一区二区三区仙踪林| 国产精品久久9999| 一区国内二区日韩三区欧美| 青青在线视频性感少妇和隔壁黑丝 | v888av在线观看视频| 激情小视频国产在线| 99精品免费久久久久久久久a| 国产麻豆91在线视频| 91破解版永久免费| 97年大学生大白天操逼| 黑人乱偷人妻中文字幕| 久久精品国产23696| wwwxxx一级黄色片| 无忧传媒在线观看视频| 色婷婷综合激情五月免费观看 | 大香蕉伊人国产在线| 97人妻无码AV碰碰视频| 日本人竟这样玩学生妹| 午夜美女少妇福利视频| 中文字幕国产专区欧美激情| 日韩少妇人妻精品无码专区 | 国产97在线视频观看| 一区二区熟女人妻视频| 日本啪啪啪啪啪啪啪| 亚洲卡1卡2卡三卡四老狼| 日韩精品中文字幕在线| 男女啪啪视频免费在线观看| 久久这里有免费精品| 插逼视频双插洞国产操逼插洞| 91国产在线视频免费观看| 另类av十亚洲av| 在线视频免费观看网| 麻豆精品成人免费视频| 亚洲特黄aaaa片| 动漫av网站18禁| 亚洲天堂成人在线观看视频网站| 老司机福利精品视频在线| av手机在线免费观看日韩av| 激情小视频国产在线| 亚洲av日韩高清hd| 日韩无码国产精品强奸乱伦| 成人伊人精品色xxxx视频| 中文字幕在线乱码一区二区 | 欧亚日韩一区二区三区观看视频| 国产黄色片在线收看| 亚洲日本一区二区久久久精品| 大香蕉伊人国产在线| 天码人妻一区二区三区在线看| 91亚洲手机在线视频播放| 老司机99精品视频在线观看| 青青草国内在线视频精选| 精品成人啪啪18免费蜜臀| 精品黑人巨大在线一区| 日韩欧美一级黄片亚洲| 亚洲精品无码久久久久不卡| 欧美成人小视频在线免费看| 最新国产精品网址在线观看| 爆乳骚货内射骚货内射在线| jul—619中文字幕在线| av老司机精品在线观看| 欧美成人黄片一区二区三区| 国产福利在线视频一区| 亚洲成人国产av在线| 亚洲激情偷拍一区二区| 91国产在线视频免费观看| 欧美性感尤物人妻在线免费看| 青青青青青青青在线播放视频| 国产高清女主播在线| 黑人巨大的吊bdsm| 黄色视频成年人免费观看| 91精品国产91久久自产久强| 免费观看污视频网站| 日韩av熟妇在线观看| 中文字幕+中文字幕| 偷拍自拍 中文字幕| 3337p日本欧洲大胆色噜噜| 大鸡八强奸视频在线观看| 视频一区 二区 三区 综合| 欧美成人一二三在线网| 天天日天天爽天天干| 福利在线视频网址导航| 国产卡一卡二卡三乱码手机| 亚洲熟妇久久无码精品| 日日夜夜大香蕉伊人| 中文字幕中文字幕人妻| 天天色天天舔天天射天天爽| 狠狠鲁狠狠操天天晚上干干| 亚洲一区制服丝袜美腿| 亚洲一级av大片免费观看| 极品性荡少妇一区二区色欲| 国产乱弄免费视频观看| 天天干天天日天天谢综合156| 色综合久久无码中文字幕波多| 日本一区美女福利视频| 亚洲天堂av最新网址| 亚洲一区二区激情在线| aⅴ五十路av熟女中出| 91精品国产高清自在线看香蕉网| 亚洲av自拍偷拍综合| 97色视频在线观看| 亚洲高清免费在线观看视频| 国产成人精品久久二区91| 中文字幕日韩精品日本| 国产麻豆国语对白露脸剧情 | 欧美日本aⅴ免费视频| 丝袜肉丝一区二区三区四区在线| 青青青青爽手机在线| 欧美精品中文字幕久久二区| 人人妻人人爽人人添夜| 精品少妇一二三视频在线| 韩国爱爱视频中文字幕| 亚洲一区自拍高清免费视频| 国产成人精品午夜福利训2021| 成人免费做爰高潮视频| 夏目彩春在线中文字幕| 美女在线观看日本亚洲一区| 无码国产精品一区二区高潮久久4| 男人和女人激情视频| 中文字幕高清免费在线人妻| 日比视频老公慢点好舒服啊| 综合激情网激情五月五月婷婷| 日本三极片中文字幕| 91中文字幕免费在线观看| 中国黄色av一级片| 亚洲av无乱一区二区三区性色| 国产视频精品资源网站| 91极品大一女神正在播放| 男人的天堂av日韩亚洲| 久久久精品国产亚洲AV一| 一本久久精品一区二区| 麻豆精品成人免费视频| 午夜精彩视频免费一区| 熟妇一区二区三区高清版| yy6080国产在线视频| 天天干天天操天天插天天日| 免费看美女脱光衣服的视频| 男女啪啪视频免费在线观看| 中文字幕一区二区人妻电影冢本| 色吉吉影音天天干天天操| 国产精品一区二区久久久av| 桃色视频在线观看一区二区 | 美女福利视频导航网站| 深田咏美亚洲一区二区| 大鸡巴后入爆操大屁股美女| 在线观看免费岛国av| 亚洲福利午夜久久久精品电影网| 精品久久久久久久久久中文蒉 | 99精品免费观看视频| asmr福利视频在线观看| 天堂女人av一区二区| 操操网操操伊剧情片中文字幕网| 成人免费公开视频无毒| 精品91自产拍在线观看一区| 午夜精品亚洲精品五月色| 和邻居少妇愉情中文字幕| 免费69视频在线看| 国产精品黄片免费在线观看| 欧美日本在线观看一区二区| 日韩av大胆在线观看| 国产av自拍偷拍盛宴| 天天日天天舔天天射进去| 粉嫩欧美美人妻小视频| 久久久久久久久久久免费女人| 国产1区,2区,3区| 欧美亚洲少妇福利视频| 中文字幕在线视频一区二区三区| 久久久人妻一区二区| 中文字幕免费在线免费| 青青操免费日综合视频观看| 午夜精品一区二区三区城中村| 久久这里只有精彩视频免费| 国产剧情演绎系列丝袜高跟| av久久精品北条麻妃av观看| 在线观看黄色成年人网站| 性感美女福利视频网站| 亚洲一区二区三区av网站| 白嫩白嫩美女极品国产在线观看| 人妻熟女中文字幕aⅴ在线| 亚洲欧美成人综合视频| 亚洲高清免费在线观看视频| 专门看国产熟妇的网站| 天堂中文字幕翔田av| 天天操天天干天天艹| 日韩伦理短片在线观看| 91麻豆精品传媒国产黄色片| 成人蜜桃美臀九一一区二区三区| 91免费观看国产免费| 人妻少妇精品久久久久久 | 老熟妇凹凸淫老妇女av在线观看| 国产一区成人在线观看视频| 亚洲专区激情在线观看视频| 日本免费一级黄色录像| 日韩无码国产精品强奸乱伦| 美女大bxxxx内射| 国产精品黄片免费在线观看| 日本一本午夜在线播放| 中国熟女@视频91| 自拍偷拍亚洲精品第2页| 91国语爽死我了不卡| 久久久久久97三级| 美女吃鸡巴操逼高潮视频| 绝顶痉挛大潮喷高潮无码 | 国产丰满熟女成人视频| 午夜极品美女福利视频| 男人天堂最新地址av| av天堂加勒比在线| 51国产偷自视频在线播放| 97资源人妻免费在线视频| 成人亚洲国产综合精品| 亚洲国产成人av在线一区| 欧美一区二区三区在线资源| 亚洲激情av一区二区| 91成人精品亚洲国产| 狠狠躁夜夜躁人人爽天天久天啪| 青草亚洲视频在线观看| 免费看国产av网站| av在线免费观看亚洲天堂| 免费av岛国天堂网站| 40道精品招牌菜特色| 一区二区三区四区五区性感视频 | 成人蜜臀午夜久久一区| 亚洲精品无码久久久久不卡| 亚洲av在线观看尤物| 99精品免费久久久久久久久a| 日韩美女综合中文字幕pp| 少妇人妻二三区视频| 中文字幕第三十八页久久| asmr福利视频在线观看| 国产剧情演绎系列丝袜高跟| 特一级特级黄色网片| 2020韩国午夜女主播在线| 夜鲁夜鲁狠鲁天天在线| 亚洲免费视频欧洲免费视频| 亚洲欧美一区二区三区爱爱动图| 欧美成人精品在线观看| 日本最新一二三区不卡在线 | 中文字幕一区二 区二三区四区| 国产亚洲天堂天天一区| 1000部国产精品成人观看视频| 免费岛国喷水视频在线观看 | 夜夜骑夜夜操夜夜奸| 人妻少妇一区二区三区蜜桃| 精品国产高潮中文字幕| 亚洲国产精品免费在线观看| 国产福利在线视频一区| 91精品免费久久久久久| 青青色国产视频在线| 18禁美女无遮挡免费| 97a片免费在线观看| 99亚洲美女一区二区三区| 激情五月婷婷免费视频| 激情啪啪啪啪一区二区三区| 97超碰人人搞人人| 日韩激情文学在线视频| 午夜精品福利91av| 婷婷六月天中文字幕| 亚洲欧洲av天堂综合| 亚洲国产最大av综合| 18禁网站一区二区三区四区| 日本丰满熟妇BBXBBXHD| 动漫美女的小穴视频| 婷婷综合蜜桃av在线| 97国产精品97久久| 日日夜夜精品一二三| 中文字幕人妻熟女在线电影| 国产日韩欧美美利坚蜜臀懂色| 一区二区三区美女毛片| 老司机在线精品福利视频| 中国老熟女偷拍第一页| 视频一区二区在线免费播放| 少妇露脸深喉口爆吞精| 天天日天天日天天射天天干| 在线免费观看日本伦理| 日韩近亲视频在线观看| 日韩一区二区三区三州| 日韩美女综合中文字幕pp| caoporm超碰国产| 欧美一级片免费在线成人观看| 成年人该看的视频黄免费| 国产精品污污污久久| 啪啪啪啪啪啪啪啪啪啪黄色| 19一区二区三区在线播放| 国产aⅴ一线在线观看| 精品区一区二区三区四区人妻| 不戴胸罩引我诱的隔壁的人妻| 宅男噜噜噜666免费观看| 中文字幕人妻熟女在线电影| av大全在线播放免费| 午夜福利人人妻人人澡人人爽| 欧美日韩高清午夜蜜桃大香蕉| 日韩欧美高清免费在线| 亚洲人妻av毛片在线| 精品视频国产在线观看| 换爱交换乱高清大片| 亚洲欧美在线视频第一页| 五色婷婷综合狠狠爱| 亚洲午夜伦理视频在线| 一区二区三区日本伦理| 亚洲欧美成人综合视频| 亚洲女人的天堂av| 中文字幕综合一区二区| 亚洲2021av天堂| 大胸性感美女羞爽操逼毛片| 经典国语激情内射视频| 在线免费观看欧美小视频| 亚洲精品一区二区三区老狼| 国产视频在线视频播放| 日本女人一级免费片| 2021天天色天天干| 视频在线亚洲一区二区| 亚洲 色图 偷拍 欧美| 欧美一区二区三区久久久aaa| 国产亚洲视频在线观看| 国产精品人妻熟女毛片av久| 午夜福利人人妻人人澡人人爽| 大香蕉大香蕉大香蕉大香蕉大香蕉| 视频 国产 精品 熟女 | 成人免费公开视频无毒| 亚洲一区二区三区精品乱码| 521精品视频在线观看| sspd152中文字幕在线| 黄色黄色黄片78在线| 六月婷婷激情一区二区三区| 黑人巨大精品欧美视频| 日韩三级黄色片网站| 欧美 亚洲 另类综合| 婷婷色国产黑丝少妇勾搭AV| 国产免费高清视频视频| 中国黄色av一级片| 欧洲日韩亚洲一区二区三区| 最新国产亚洲精品中文在线| 青青热久免费精品视频在线观看| 国产精品日韩欧美一区二区| av中文字幕国产在线观看| 狠狠操狠狠操免费视频| 少妇人妻100系列| 大鸡巴插入美女黑黑的阴毛| 不卡一不卡二不卡三| 超碰中文字幕免费观看| 三级av中文字幕在线观看| 国产精品久久久久网| 99久久激情婷婷综合五月天| 精品av国产一区二区三区四区| 欧美日韩在线精品一区二区三| 欧美一区二区三区在线资源 | 亚洲超碰97人人做人人爱| 99的爱精品免费视频| 91免费观看在线网站| 中文字幕 码 在线视频| 亚洲精品一线二线在线观看| 日本人妻精品久久久久久| 18禁美女羞羞免费网站| 只有精品亚洲视频在线观看| 成人性黑人一级av| 久久人人做人人妻人人玩精品vr| 欧美国产亚洲中英文字幕| 男人的天堂av日韩亚洲| 天天操天天干天天插| 骚逼被大屌狂草视频免费看| 亚洲国产欧美国产综合在线| 男人天堂最新地址av| 日韩一区二区三区三州| 国产黄色片在线收看| 国产成人午夜精品福利| 熟女人妻三十路四十路人妻斩| 又粗又硬又猛又黄免费30| 好男人视频在线免费观看网站| 久久久超爽一二三av| av天堂资源最新版在线看| 97人妻无码AV碰碰视频| 国产janese在线播放| 中文字幕人妻av在线观看| 中文字幕在线永久免费播放| 制丝袜业一区二区三区| 久久精品国产23696| 天天干天天插天天谢| 精品suv一区二区69| 女生自摸在线观看一区二区三区| 国产熟妇一区二区三区av| 成人蜜臀午夜久久一区| av手机免费在线观看高潮| 91大神福利视频网| 亚洲成人线上免费视频观看| 91大屁股国产一区二区| 日韩美女综合中文字幕pp| 人妻自拍视频中国大陆| 国产在线91观看免费观看| 青青青视频自偷自拍38碰| 欧美专区第八页一区在线播放| 男人操女人逼逼视频网站| 手机看片福利盒子日韩在线播放| 777奇米久久精品一区| AV天堂一区二区免费试看| 综合精品久久久久97| 免费在线福利小视频| 边摸边做超爽毛片18禁色戒| 一本久久精品一区二区| 五月激情婷婷久久综合网| 精品国产成人亚洲午夜| 成人蜜桃美臀九一一区二区三区| 视频一区二区在线免费播放| 国产va精品免费观看| 日韩二区视频一线天婷婷五| 国产不卡av在线免费| 丰满的子国产在线观看| 九色视频在线观看免费| 天天操天天干天天艹| 国产成人自拍视频在线免费观看| 日本三极片中文字幕| 亚洲成人av在线一区二区| 日本精品视频不卡一二三| gay gay男男瑟瑟在线网站| 91av中文视频在线| 在线观看亚洲人成免费网址| 欧美特色aaa大片| 天天日天天干天天爱| 国产亚洲欧美45p| 2018在线福利视频| 少妇系列一区二区三区视频| 久久麻豆亚洲精品av| 国产精品黄大片在线播放| 93精品视频在线观看| 蜜桃视频在线欧美一区| 57pao国产一区二区| 成人在线欧美日韩国产| 在线免费观看99视频| 性色蜜臀av一区二区三区| 天天日天天日天天射天天干| 午夜精品福利一区二区三区p| 色婷婷久久久久swag精品| 19一区二区三区在线播放| 青青青青青青青青青国产精品视频| 日韩特级黄片高清在线看| 日韩av大胆在线观看| 五十路熟女人妻一区二区9933| 韩国黄色一级二级三级| 人妻无码中文字幕专区| 国产精品入口麻豆啊啊啊| 免费在线福利小视频| 国产自拍在线观看成人| 99久久成人日韩欧美精品| 中文字幕人妻一区二区视频| 精品国产乱码一区二区三区乱| 中文字幕av男人天堂| 日本一二三区不卡无| 中文字幕+中文字幕| 亚洲在线免费h观看网站| 一区二区三区精品日本| 成人免费毛片aaaa| 欧美亚洲自偷自拍 在线| 青青青青青手机视频| 99久久中文字幕一本人| 一区二区三区毛片国产一区| 国产午夜亚洲精品麻豆| 欧美视频不卡一区四区| 成人精品在线观看视频| 国产成人精品福利短视频| 人妻丝袜av在线播放网址| 欧美一级色视频美日韩| 免费岛国喷水视频在线观看| 日韩精品中文字幕福利| 99精品国产aⅴ在线观看| 国产精品久久久久国产三级试频| 99久久中文字幕一本人| 亚洲日产av一区二区在线| 涩涩的视频在线观看视频| 人妻少妇中文有码精品| 欧美aa一级一区三区四区| 2018在线福利视频| 亚洲欧美色一区二区|