国产无遮挡裸体免费直播视频,久久精品国产蜜臀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

最新評論

亚洲激情唯美亚洲激情图片| 热99re69精品8在线播放| 狍和女人的王色毛片| 国产视频网站一区二区三区| 欧美日韩亚洲国产无线码| 东京干手机福利视频| 日韩美av高清在线| 黄色成年网站午夜在线观看| 大香蕉大香蕉在线有码 av| 超级av免费观看一区二区三区| 久久热久久视频在线观看| 日韩av熟妇在线观看| 99久久成人日韩欧美精品| 福利片区一区二体验区| 日本乱人一区二区三区| 欧美黑人性暴力猛交喷水| 日本女人一级免费片| 国产在线拍揄自揄视频网站| 在线可以看的视频你懂的| 日韩视频一区二区免费观看| 亚洲中文字幕人妻一区| 丝袜亚洲另类欧美变态| 久久久久久99国产精品| 被大鸡吧操的好舒服视频免费| 五月婷婷在线观看视频免费| 日韩欧美国产精品91| 久久国产精品精品美女| av老司机亚洲一区二区| 亚洲免费福利一区二区三区| 中文字幕一区二区人妻电影冢本| 我想看操逼黄色大片| 超碰公开大香蕉97| 蜜臀成人av在线播放| 精品亚洲中文字幕av| 中文字幕人妻熟女在线电影| 日本美女成人在线视频| 三级等保密码要求条款| 天美传媒mv视频在线观看| 亚洲熟妇无码一区二区三区| 国产视频一区在线观看| 蜜桃色婷婷久久久福利在线| 亚洲精品麻豆免费在线观看| 在线免费观看99视频| 国产真实灌醉下药美女av福利| 亚洲另类在线免费观看| 国产精品三级三级三级| av老司机精品在线观看| 美味人妻2在线播放| 在线免费91激情四射 | 亚洲另类在线免费观看| 精彩视频99免费在线| 国产乱子伦一二三区| 在线免费观看视频一二区| av天堂中文字幕最新| 天天射夜夜操狠狠干| 欧洲欧美日韩国产在线| 天天操夜夜骑日日摸| 人人妻人人爽人人澡人人精品| 91国产在线视频免费观看| 伊人精品福利综合导航| 少妇一区二区三区久久久| 日韩精品二区一区久久| 日韩av熟妇在线观看| 久久午夜夜伦痒痒想咳嗽P| 成人午夜电影在线观看 久久| 中文字幕第三十八页久久| 可以在线观看的av中文字幕| 日韩北条麻妃一区在线| 日韩黄色片在线观看网站| 亚洲综合色在线免费观看| 黄片三级三级三级在线观看| 日韩欧美中文国产在线| 日韩人妻在线视频免费| 日本高清撒尿pissing| 欧美精品免费aaaaaa| 亚洲va国产va欧美精品88| 无套猛戳丰满少妇人妻| 啪啪啪啪啪啪啪啪av| 天堂av狠狠操蜜桃| caoporn蜜桃视频| 国产大鸡巴大鸡巴操小骚逼小骚逼| 社区自拍揄拍尻屁你懂的| 人妻少妇精品久久久久久| 欧美精品免费aaaaaa| 老熟妇xxxhd老熟女| 丰满的子国产在线观看| 欧美亚洲少妇福利视频| 国产福利小视频免费观看| 最新97国产在线视频| 粉嫩欧美美人妻小视频| 国产品国产三级国产普通话三级| 亚洲第一伊人天堂网| 日本欧美视频在线观看三区| 嫩草aⅴ一区二区三区| 精品国产成人亚洲午夜| 少妇人妻久久久久视频黄片| 成人蜜桃美臀九一一区二区三区| 色哟哟国产精品入口| 青青青aaaa免费| 韩国亚洲欧美超一级在线播放视频| 在线国产精品一区二区三区| 欧美另类重口味极品在线观看| 天堂av在线最新版在线| 亚洲欧美成人综合视频| 国产亚洲国产av网站在线| 91国产在线视频免费观看| 国内精品在线播放第一页| 国产成人精品福利短视频| 欧美区一区二区三视频| 国产福利小视频二区| 在线播放一区二区三区Av无码| www久久久久久久久久久| 动漫黑丝美女的鸡巴| 国产美女一区在线观看| 色伦色伦777国产精品| 一个色综合男人天堂| 婷婷色国产黑丝少妇勾搭AV| 少妇高潮一区二区三区| 中国把吊插入阴蒂的视频| 日本成人不卡一区二区| 黄色资源视频网站日韩| 一级黄色av在线观看| 欧美成人黄片一区二区三区| 97黄网站在线观看| av在线资源中文字幕| 国产使劲操在线播放| 久久精品国产亚洲精品166m| 青娱乐在线免费视频盛宴| 午夜青青草原网在线观看| 在线不卡日韩视频播放| 日本阿v视频在线免费观看| 在线观看免费岛国av| 国产精品女邻居小骚货| 中文字幕乱码av资源| 夏目彩春在线中文字幕| 77久久久久国产精产品| 女同久久精品秋霞网| 色综合久久五月色婷婷综合| 亚洲国产在人线放午夜| 中文字幕av第1页中文字幕| 98精产国品一二三产区区别| 播放日本一区二区三区电影| 最新中文字幕乱码在线| 亚洲第一黄色在线观看| 一区二区三区久久中文字幕| 人妻丝袜av在线播放网址| 爆乳骚货内射骚货内射在线| 人妻av无码专区久久绿巨人| 无码中文字幕波多野不卡| 福利午夜视频在线合集| jiujiure精品视频在线| 91啪国自产中文字幕在线| 亚洲黄色av网站免费播放| 韩国三级aaaaa高清视频 | 国产 在线 免费 精品| 在线 中文字幕 一区| 78色精品一区二区三区| 快点插进来操我逼啊视频| 国产麻豆91在线视频| 夜夜嗨av一区二区三区中文字幕| 色婷婷久久久久swag精品| 中文字幕最新久久久| 大黑人性xxxxbbbb| 中文字幕日韩精品日本| 色爱av一区二区三区| 一区二区免费高清黄色视频| 9色精品视频在线观看| 亚洲av无码成人精品区辽| 操的小逼流水的文章| 中文字幕人妻一区二区视频| 美洲精品一二三产区区别| 人妻丝袜诱惑我操她视频| 操人妻嗷嗷叫视频一区二区| 91亚洲国产成人精品性色| 亚洲激情,偷拍视频| 18禁精品网站久久| 一区二区三区日本伦理| 中国熟女@视频91| tube69日本少妇| 在线观看操大逼视频| 亚洲久久午夜av一区二区| 岛国青草视频在线观看| av新中文天堂在线网址| 久久精品国产999| 在线观看视频一区麻豆| 免费69视频在线看| 亚洲av可乐操首页| 自拍偷区二区三区麻豆| 亚洲国产最大av综合| 91av精品视频在线| 100%美女蜜桃视频| 欧美va亚洲va天堂va| 国产女人露脸高潮对白视频| 欧美成人综合视频一区二区| 欧美色婷婷综合在线| 老司机欧美视频在线看| 中文字幕 码 在线视频| 大鸡吧插逼逼视频免费看 | 欧美成人综合色在线噜噜| 丰满熟女午夜福利视频| 大屁股肉感人妻中文字幕在线| 成年美女黄网站18禁久久| 欧美一区二区三区啪啪同性| 任你操任你干精品在线视频| 大黑人性xxxxbbbb| 日本黄在免费看视频| 欧美一区二区三区久久久aaa| 超级av免费观看一区二区三区| 抽查舔水白紧大视频| 国产美女精品福利在线| 国产精品日韩欧美一区二区| 国产清纯美女al在线| 国产va精品免费观看| 亚洲视频在线观看高清| 99热这里只有精品中文| 性欧美激情久久久久久久| 欧美va亚洲va天堂va| 骚货自慰被发现爆操| 97精品综合久久在线| 2021天天色天天干| japanese五十路熟女熟妇| 亚洲成人免费看电影| 国产黄网站在线观看播放| 青青草成人福利电影| 成人av天堂丝袜在线观看| 一区二区三区 自拍偷拍| 在线观看av2025| 偷拍自拍亚洲美腿丝袜| 亚洲第17页国产精品| 最新的中文字幕 亚洲| 端庄人妻堕落挣扎沉沦| 六月婷婷激情一区二区三区| 后入美女人妻高清在线| 亚洲欧美色一区二区| 人妻素人精油按摩中出| 久久久久久性虐视频| 免费福利av在线一区二区三区| 少妇露脸深喉口爆吞精| 精品久久久久久久久久中文蒉| 日韩在线视频观看有码在线| 中文字幕无码一区二区免费| 久久久精品精品视频视频| 中国熟女@视频91| 99国内精品永久免费视频| 91亚洲手机在线视频播放| 日韩欧美亚洲熟女人妻| 欧洲国产成人精品91铁牛tv | 日本女人一级免费片| 91国内精品自线在拍白富美| 2022精品久久久久久中文字幕| 中文字幕无码一区二区免费| 一区二区三区蜜臀在线| 亚洲中文字幕人妻一区| 中文字幕日本人妻中出| 国产黄色片蝌蚪九色91| 男人操女人逼逼视频网站| 一区二区三区四区视频在线播放 | 亚洲精品乱码久久久久久密桃明| 日日操夜夜撸天天干| 少妇ww搡性bbb91| 少妇深喉口爆吞精韩国| 亚洲一区二区久久久人妻| 黄色黄色黄片78在线| 日韩美女综合中文字幕pp| 亚洲激情偷拍一区二区| 人人爱人人妻人人澡39| 99久久激情婷婷综合五月天| 国产黄色a级三级三级三级 | 日本黄色特一级视频| 一区二区熟女人妻视频| 韩国女主播精品视频网站| 欧洲亚洲欧美日韩综合| av线天堂在线观看| 亚洲老熟妇日本老妇| 久久久久久9999久久久久| 免费69视频在线看| 婷婷色国产黑丝少妇勾搭AV| 水蜜桃国产一区二区三区| 亚洲av日韩av第一区二区三区| 午夜av一区二区三区| 日本美女性生活一级片| 又黄又刺激的午夜小视频| 1024久久国产精品| 97黄网站在线观看| 蜜桃视频入口久久久| 91国偷自产一区二区三区精品| 懂色av蜜桃a v| 大鸡巴后入爆操大屁股美女| 国产综合视频在线看片| 热久久只有这里有精品| 亚洲人一区二区中文字幕| 蝴蝶伊人久久中文娱乐网| 久久久超爽一二三av| 毛片av在线免费看| 日本少妇人妻xxxxxhd| 端庄人妻堕落挣扎沉沦| 晚上一个人看操B片| 100%美女蜜桃视频| 亚洲国产香蕉视频在线播放| 婷婷色中文亚洲网68| 国产亚洲成人免费在线观看| 国产三级精品三级在线不卡| 岳太深了紧紧的中文字幕| 69精品视频一区二区在线观看| 亚洲最大黄了色网站| 伊人情人综合成人久久网小说| 抽查舔水白紧大视频| 天天日天天操天天摸天天舔| 无套猛戳丰满少妇人妻| 日本女人一级免费片| 在线免费观看99视频| 大学生A级毛片免费视频| 成年人午夜黄片视频资源| 午夜在线一区二区免费| 大肉大捧一进一出好爽在线视频| 精品乱子伦一区二区三区免费播| 成人免费毛片aaaa| 人人妻人人爽人人澡人人精品| 亚洲狠狠婷婷综合久久app| 自拍偷拍一区二区三区图片| 天码人妻一区二区三区在线看 | 国产视频网站一区二区三区| 精品国产在线手机在线| 亚洲国产在人线放午夜| 91人妻精品久久久久久久网站| 日韩成人性色生活片| 欧美激情精品在线观看| 99国产精品窥熟女精品| 亚洲伊人久久精品影院一美女洗澡| 久久久久久久久久性潮| 国产一线二线三线的区别在哪| 午夜精品一区二区三区4| 在线免费观看日本伦理| 自拍偷拍亚洲精品第2页| 人妻丝袜榨强中文字幕| 沈阳熟妇28厘米大战黑人| 在线观看国产免费麻豆| 亚洲蜜臀av一区二区三区九色 | 国产日本欧美亚洲精品视| 黄色视频在线观看高清无码| 天天干天天日天天干天天操| 亚洲美女美妇久久字幕组| 护士特殊服务久久久久久久| 国产麻豆91在线视频| www,久久久,com| 91av精品视频在线| 最新97国产在线视频| 人妻爱爱 中文字幕| 亚洲av无硬久久精品蜜桃| 开心 色 六月 婷婷| 偷拍美女一区二区三区| 偷拍美女一区二区三区| 少妇人妻久久久久视频黄片| 日韩欧美制服诱惑一区在线| 亚洲 中文 自拍 另类 欧美| 久草视频中文字幕在线观看| 亚洲高清自偷揄拍自拍| 色噜噜噜噜18禁止观看| 好男人视频在线免费观看网站| 伊人网中文字幕在线视频| 在线成人日韩av电影| 韩国一级特黄大片做受| 阴茎插到阴道里面的视频| 国产精品探花熟女在线观看| 亚洲公开视频在线观看| 玩弄人妻熟妇性色av少妇| av在线观看网址av| 天天干天天日天天谢综合156| 熟妇一区二区三区高清版| brazzers欧熟精品系列| 果冻传媒av一区二区三区| 国产亚州色婷婷久久99精品| 丝袜美腿欧美另类 中文字幕| 精品美女久久久久久| 在线观看视频网站麻豆| 久久永久免费精品人妻专区| 最新的中文字幕 亚洲| 国产日韩精品免费在线| 瑟瑟视频在线观看免费视频| 青春草视频在线免费播放| 狠狠嗨日韩综合久久| 美女被肏内射视频网站| 中文字幕人妻一区二区视频| weyvv5国产成人精品的视频| 少妇高潮无套内谢麻豆| 日视频免费在线观看| 国产精品一区二区三区蜜臀av| 亚洲欧洲av天堂综合| 熟女视频一区,二区,三区| 都市家庭人妻激情自拍视频| 亚洲精品精品国产综合| 久久永久免费精品人妻专区| 在线不卡成人黄色精品| 亚洲av可乐操首页| 四川五十路熟女av| 黑人性生活视频免费看| 99re6热在线精品| 天天草天天色天天干| 天天干天天操天天玩天天射| 国产日韩欧美视频在线导航| 亚洲欧美久久久久久久久| 黄工厂精品视频在线观看| 男人在床上插女人视频| 不卡日韩av在线观看| 国产精品福利小视频a| av老司机精品在线观看| 在线免费观看国产精品黄色| 动漫精品视频在线观看| 国产黑丝高跟鞋视频在线播放| 午夜福利资源综合激情午夜福利资| 在线免费观看日本伦理| 超污视频在线观看污污污| 极品粉嫩小泬白浆20p主播| 午夜精品九一唐人麻豆嫩草成人| 青娱乐最新视频在线| 欧美精品资源在线观看| 天天射夜夜操狠狠干| 任你操任你干精品在线视频| 91免费观看国产免费| 亚洲熟妇无码一区二区三区| 3344免费偷拍视频| 午夜精品福利一区二区三区p| 激情内射在线免费观看| 人人妻人人爽人人澡人人精品| 1769国产精品视频免费观看| 93视频一区二区三区| 色狠狠av线不卡香蕉一区二区| 搡老熟女一区二区在线观看| av新中文天堂在线网址| 在线观看av亚洲情色| 日韩人妻在线视频免费| 自拍偷拍一区二区三区图片 | 婷婷色中文亚洲网68| 好吊操视频这里只有精品| 久久永久免费精品人妻专区 | 自拍偷拍日韩欧美亚洲| caoporn蜜桃视频| 日韩精品一区二区三区在线播放| 播放日本一区二区三区电影| 91av精品视频在线| 国产高清在线在线视频| 国产伦精品一区二区三区竹菊| 熟女91pooyn熟女| 狠狠躁夜夜躁人人爽天天久天啪| 无码中文字幕波多野不卡| 美洲精品一二三产区区别| 青青在线视频性感少妇和隔壁黑丝| 日韩午夜福利精品试看| 日本人妻少妇18—xx| 任你操视频免费在线观看| av天堂中文字幕最新| 青青伊人一精品视频| 蜜臀成人av在线播放| 97超碰免费在线视频| 偷拍自拍 中文字幕| 福利在线视频网址导航| 丝袜肉丝一区二区三区四区在线看| 偷拍自拍视频图片免费| 成年女人免费播放视频| 又粗又长 明星操逼小视频| 精品久久久久久久久久久久人妻 | 亚洲一区二区三区久久午夜| 日本av在线一区二区三区| 一区二区三区的久久的蜜桃的视频| 91超碰青青中文字幕| 免费男阳茎伸入女阳道视频| 日韩av有码中文字幕| 中文字幕人妻被公上司喝醉在线| 欧美一区二区三区在线资源 | 超碰中文字幕免费观看| av一区二区三区人妻| 亚洲美女高潮喷浆视频| 97人人模人人爽人人喊| 黑人解禁人妻叶爱071| 又色又爽又黄的美女裸体| 91久久综合男人天堂| 人人妻人人澡人人爽人人dvl| 88成人免费av网站| 91试看福利一分钟| 91精品国产综合久久久蜜| 欧美亚洲一二三区蜜臀| 欧美成人精品在线观看| 天堂av狠狠操蜜桃| 日韩欧美国产一区不卡| 国产成人精品福利短视频| 国产中文字幕四区在线观看| 香港一级特黄大片在线播放| 最新中文字幕免费视频| 在线播放国产黄色av| 欧美成人小视频在线免费看| 成人H精品动漫在线无码播放| 成人区人妻精品一区二视频| 少妇高潮一区二区三区| 熟女俱乐部一二三区| 久久久久久国产精品| 精品久久久久久久久久久a√国产| 国产精品手机在线看片| 精品一区二区亚洲欧美| 亚洲一级av大片免费观看| 不卡精品视频在线观看| 国产亚洲国产av网站在线| 午夜毛片不卡在线看| 丝袜亚洲另类欧美变态| 国产97在线视频观看| 成人区人妻精品一区二视频| 国产亚洲欧美另类在线观看| 天天日天天日天天射天天干| 亚洲一区二区三区五区| 一级黄片大鸡巴插入美女| 日本免费一级黄色录像| 国产男女视频在线播放| 色av色婷婷人妻久久久精品高清 | 最新国产精品拍在线观看| 五十路熟女人妻一区二| 91免费黄片可看视频| 亚洲免费va在线播放| 99热碰碰热精品a中文| 91欧美在线免费观看| 日本性感美女视频网站| 国产女人叫床高潮大片视频| 色综合久久无码中文字幕波多| 亚洲av香蕉一区区二区三区犇| 欧美日韩精品永久免费网址| 婷婷激情四射在线观看视频| 国产精品3p和黑人大战| 蜜桃色婷婷久久久福利在线| 婷婷六月天中文字幕| 国产成人午夜精品福利| 国语对白xxxx乱大交| 国产高清精品极品美女| 9色精品视频在线观看| 国产1区,2区,3区| mm131美女午夜爽爽爽| 99精品视频之69精品视频| 天天插天天狠天天操| 在线观看av亚洲情色| 人妻少妇av在线观看| av在线免费观看亚洲天堂| 久久久久久cao我的性感人妻| 久久久久国产成人精品亚洲午夜| 国产精品久久久久久美女校花| 岛国一区二区三区视频在线| 偷拍自拍亚洲美腿丝袜| 99精品久久久久久久91蜜桃| av天堂加勒比在线| 99精品久久久久久久91蜜桃| 亚洲一区二区三区av网站| 亚洲麻豆一区二区三区| 91传媒一区二区三区| 91超碰青青中文字幕| 2019av在线视频| 中文字幕无码一区二区免费| 欧洲国产成人精品91铁牛tv| 97超碰国语国产97超碰| 中文字幕在线观看极品视频| 天天操天天干天天日狠狠插| 91中文字幕免费在线观看| 亚洲女人的天堂av| 亚洲福利午夜久久久精品电影网| 日韩精品电影亚洲一区| eeuss鲁片一区二区三区| 中文字幕—97超碰网| 日本在线一区二区不卡视频| 蜜桃视频入口久久久| 日本又色又爽又黄又粗| 国产高清精品极品美女| 中文字幕 亚洲av| 日韩精品中文字幕播放| 一区二区久久成人网| 欧洲日韩亚洲一区二区三区| 夜鲁夜鲁狠鲁天天在线| 亚洲另类伦春色综合小| 国产一级精品综合av| 亚洲视频在线观看高清| 福利一二三在线视频观看 | 18禁无翼鸟成人在线| 国产伊人免费在线播放| 亚洲最大黄 嗯色 操 啊| 日韩欧美制服诱惑一区在线| 人人妻人人澡欧美91精品| 午夜场射精嗯嗯啊啊视频| 欧美黄色录像免费看的| 最新中文字幕乱码在线| 午夜极品美女福利视频| 成年午夜影片国产片| 青青青视频自偷自拍38碰| 亚洲护士一区二区三区| 天天色天天操天天透| 国产精品女邻居小骚货| 一区二区三区在线视频福利| 精品久久久久久久久久久a√国产| 端庄人妻堕落挣扎沉沦| 一区二区视频在线观看视频在线| av一区二区三区人妻| 3344免费偷拍视频| 国产精品国产三级国产精东| 一区二区在线观看少妇| 沈阳熟妇28厘米大战黑人| 久久精品国产23696| 国产janese在线播放| 十八禁在线观看地址免费| 国产精品大陆在线2019不卡| 亚洲av午夜免费观看| 国产精品成人xxxx| 最新中文字幕乱码在线| 91精品啪在线免费| aaa久久久久久久久| 2022天天干天天操| av天堂中文字幕最新| 久久热久久视频在线观看| 三级黄色亚洲成人av| 成年女人免费播放视频| 91九色国产熟女一区二区| 热99re69精品8在线播放| 在线网站你懂得老司机| 色综合色综合色综合色| 精品一区二区亚洲欧美| 亚洲国产最大av综合| 日韩人妻xxxxx| 伊人综合免费在线视频| 91精品激情五月婷婷在线| 亚洲国产成人av在线一区| 日噜噜噜夜夜噜噜噜天天噜噜噜 | 国产91久久精品一区二区字幕| 国产欧美精品不卡在线| 欧美性感尤物人妻在线免费看| 日韩美在线观看视频黄| 亚洲最大黄 嗯色 操 啊| 男生舔女生逼逼的视频| 97资源人妻免费在线视频| 福利午夜视频在线观看| 国产欧美精品一区二区高清 | 国产一区二区久久久裸臀| 国产精品人妻一区二区三区网站| 亚洲精品国品乱码久久久久| 国产三级精品三级在线不卡| 含骚鸡巴玩逼逼视频| 国产午夜福利av导航| 亚洲成人精品女人久久久| 黄色大片免费观看网站| 深田咏美亚洲一区二区| 欧美3p在线观看一区二区三区| 久草福利电影在线观看| 日韩欧美国产精品91| 2020av天堂网在线观看| 香蕉91一区二区三区| 精品一区二区三区欧美| 亚洲最大黄了色网站| 免费无码人妻日韩精品一区二区| 中国把吊插入阴蒂的视频| 天天通天天透天天插| 亚洲精品成人网久久久久久小说| 成人sm视频在线观看| 国产精品一区二区久久久av| 国产在线拍揄自揄视频网站| 中文字幕人妻被公上司喝醉在线 | 成人av免费不卡在线观看| 人妻少妇亚洲一区二区| www日韩毛片av| 美日韩在线视频免费看| 91免费观看国产免费| 香港一级特黄大片在线播放| 欧美日韩精品永久免费网址| 国产黄色高清资源在线免费观看| 秋霞午夜av福利经典影视| 精品国产午夜视频一区二区| 少妇与子乱在线观看| 瑟瑟视频在线观看免费视频| 国产成人综合一区2区| 日本一二三中文字幕| 中文字幕亚洲中文字幕| 亚洲精品 日韩电影| 亚洲特黄aaaa片| 亚洲av无码成人精品区辽| 超碰在线中文字幕一区二区| 狠狠躁夜夜躁人人爽天天天天97| 美女 午夜 在线视频| 日辽宁老肥女在线观看视频| av日韩在线免费播放| 亚洲午夜福利中文乱码字幕| 日本性感美女三级视频| 最新国产亚洲精品中文在线| 欧美视频一区免费在线| 搞黄色在线免费观看| 超级福利视频在线观看| 国产成人小视频在线观看无遮挡| 天天日天天鲁天天操| 国产性色生活片毛片春晓精品 | 爱有来生高清在线中文字幕| aiss午夜免费视频| 亚洲精品国产久久久久久| 久久精品国产999| 亚洲国产成人av在线一区| 岛国黄色大片在线观看| 国产麻豆91在线视频| 欧美aa一级一区三区四区| 国产大学生援交正在播放| 中文字幕综合一区二区| 欧美在线偷拍视频免费看| 欧美精品亚洲精品日韩在线| 欧美日韩国产一区二区三区三州 | 这里有精品成人国产99| 黄色中文字幕在线播放| 精品少妇一二三视频在线| 丝袜美腿欧美另类 中文字幕| 日本人妻精品久久久久久| 欧美偷拍亚洲一区二区| 免费在线看的黄网站| 久久丁香花五月天色婷婷| 国产精品国产三级国产精东 | 在线观看黄色成年人网站| 麻豆精品成人免费视频| 亚洲综合在线观看免费| 亚洲推理片免费看网站| 在线免费观看亚洲精品电影| 爱有来生高清在线中文字幕| 2020av天堂网在线观看| 亚洲午夜在线视频福利| 又粗又硬又猛又黄免费30| 热99re69精品8在线播放| 亚洲人成精品久久久久久久| 成人乱码一区二区三区av| 偷拍美女一区二区三区| 亚洲福利午夜久久久精品电影网 | 亚洲午夜伦理视频在线| 国产美女午夜福利久久| 日韩一区二区三区三州| 在线观看视频污一区| 亚洲av人人澡人人爽人人爱| 在线观看黄色成年人网站| 日比视频老公慢点好舒服啊| 激情啪啪啪啪一区二区三区| 欧美一区二区三区乱码在线播放 | 视频在线免费观看你懂得| 中文字幕奴隷色的舞台50| 蜜桃视频入口久久久| 国内精品在线播放第一页| 国产高潮无码喷水AV片在线观看 | 亚洲另类综合一区小说| 在线不卡日韩视频播放| 黄色的网站在线免费看| 国产a级毛久久久久精品| 免费高清自慰一区二区三区网站| 91人妻精品一区二区在线看| 1000小视频在线| 国产三级片久久久久久久| 精品国产在线手机在线| 日本少妇精品免费视频| gay gay男男瑟瑟在线网站| 摧残蹂躏av一二三区| 欧美日本在线观看一区二区| 三级等保密码要求条款| 成人av天堂丝袜在线观看| 老师让我插进去69AV| 亚洲另类图片蜜臀av| 黄色片黄色片wyaa| 在线免费观看国产精品黄色| 99国内小视频在现欢看| 日韩欧美中文国产在线| 大胸性感美女羞爽操逼毛片| 91久久人澡人人添人人爽乱| 天天干天天操天天插天天日| 国产精品熟女久久久久浪潮| 日曰摸日日碰夜夜爽歪歪| 日韩a级精品一区二区| 99久久激情婷婷综合五月天| 首之国产AV医生和护士小芳| 精品av国产一区二区三区四区| 521精品视频在线观看| 又大又湿又爽又紧A视频| 国产精品成人xxxx| 国产av自拍偷拍盛宴| 天天日天天干天天干天天日| 欧美精品一区二区三区xxxx| 成人av在线资源网站| 国产高清在线观看1区2区| 97成人免费在线观看网站| 日本免费一级黄色录像| 视频啪啪啪免费观看| 亚洲中文字字幕乱码| 大鸡吧插入女阴道黄色片| 久久久久久久亚洲午夜综合福利| 亚洲高清免费在线观看视频| 国产麻豆国语对白露脸剧情| 又大又湿又爽又紧A视频| 三上悠亚和黑人665番号| 国产91久久精品一区二区字幕| 在线视频精品你懂的| 欧美精品一区二区三区xxxx| 欧美va亚洲va天堂va| 黄色资源视频网站日韩| 3344免费偷拍视频| 午夜频道成人在线91| 天天日天天操天天摸天天舔| 国产不卡av在线免费| 亚洲乱码中文字幕在线| 日韩欧美制服诱惑一区在线| 人妻少妇亚洲一区二区| 日韩美女综合中文字幕pp| 夜夜骑夜夜操夜夜奸| 中文 成人 在线 视频| 在线免费观看黄页视频| 97少妇精品在线观看| 一本一本久久a久久精品综合不卡 亚洲另类综合一区小说 | 亚洲av无码成人精品区辽| av视网站在线观看| 888亚洲欧美国产va在线播放| 粉嫩av懂色av蜜臀av| 大学生A级毛片免费视频| 日韩近亲视频在线观看| 少妇高潮一区二区三区| 啪啪啪啪啪啪啪免费视频| 无套猛戳丰满少妇人妻| 天天做天天爽夜夜做少妇| 中文字幕一区二区亚洲一区| 国产三级影院在线观看| 视频 一区二区在线观看| 高潮喷水在线视频观看| 久久这里只有精品热视频| 在线国产中文字幕视频| 在线观看亚洲人成免费网址| 日本熟女50视频免费| 白白操白白色在线免费视频| av线天堂在线观看| 日韩不卡中文在线视频网站| 97人妻色免费视频| 国产精品久久久久国产三级试频| 香蕉av影视在线观看| 亚洲另类在线免费观看| 国内资源最丰富的网站| 黄色男人的天堂视频| 天天操天天操天天碰| 免费在线看的黄片视频| 国产a级毛久久久久精品| 国产精品久久久久久久女人18| 在线观看的黄色免费网站| 国产剧情演绎系列丝袜高跟| 老鸭窝日韩精品视频观看| 亚洲精品无码久久久久不卡| 日韩av中文在线免费观看| 亚洲av男人天堂久久| 伊人成人在线综合网| 中文字幕人妻av在线观看| 老师让我插进去69AV| 2022天天干天天操| 精品国产在线手机在线| 欧美成人一二三在线网| 国产变态另类在线观看| 热99re69精品8在线播放| 久久精品国产999| 狠狠躁夜夜躁人人爽天天久天啪| 天天色天天舔天天射天天爽| 2021年国产精品自拍| 久久久久久久99精品| 亚洲av色香蕉一区二区三区| 日韩a级黄色小视频| 在线免费观看日本伦理| 色婷婷六月亚洲综合香蕉| 亚洲欧美一区二区三区爱爱动图| 亚洲激情,偷拍视频| 亚洲在线观看中文字幕av| 日曰摸日日碰夜夜爽歪歪| 中文字幕av第1页中文字幕| 人人爱人人妻人人澡39| 国产在线自在拍91国语自产精品| 久久久精品999精品日本 | 天天色天天操天天舔| 精品久久久久久久久久久99| 91亚洲国产成人精品性色| 最新激情中文字幕视频| 欧美亚洲自偷自拍 在线| 女人精品内射国产99| nagger可以指黑人吗| av一区二区三区人妻| 99精品一区二区三区的区| 粉嫩av懂色av蜜臀av| 欧美成人小视频在线免费看| 男人天堂最新地址av| 午夜在线观看岛国av,com| 欧美亚洲一二三区蜜臀| 伊人开心婷婷国产av| 女同久久精品秋霞网| 91老熟女连续高潮对白| 日韩av免费观看一区| 999热精品视频在线| 丰满的继坶3中文在线观看| 亚洲 欧美 精品 激情 偷拍 | 天天操天天干天天艹| 丝袜美腿欧美另类 中文字幕| 日本少妇人妻xxxxxhd| 99久久超碰人妻国产| 国产乱弄免费视频观看| 999热精品视频在线| 888欧美视频在线| 精品一区二区三区三区88| 色花堂在线av中文字幕九九| 这里只有精品双飞在线播放| 美女操逼免费短视频下载链接| 91久久综合男人天堂| 中文字日产幕乱六区蜜桃| 五十路熟女av天堂| 99热久久这里只有精品8| 天堂中文字幕翔田av | 亚洲图片欧美校园春色| 欧美视频综合第一页| 精彩视频99免费在线| 久久精品视频一区二区三区四区| 任你操视频免费在线观看| 韩国一级特黄大片做受| 国产乱弄免费视频观看| 亚洲精品欧美日韩在线播放| 爱爱免费在线观看视频| 成人国产激情自拍三区| 亚洲欧美色一区二区| 亚洲欧美在线视频第一页| 不卡精品视频在线观看| 社区自拍揄拍尻屁你懂的| 成年人免费看在线视频| 啪啪啪啪啪啪啪啪av| 天天色天天舔天天射天天爽| 91老师蜜桃臀大屁股| 91片黄在线观看喷潮| 亚洲视频在线观看高清| 亚洲国产免费av一区二区三区| 都市激情校园春色狠狠| 啪啪啪18禁一区二区三区| 国产精品成久久久久三级蜜臀av | 亚洲人人妻一区二区三区| 欧美亚洲中文字幕一区二区三区| 中国黄色av一级片| 天天日天天干天天搡| 中文字幕在线观看极品视频| 香蕉91一区二区三区| 欧美日韩一区二区电影在线观看 | 亚洲av一妻不如妾| 国产成人精品亚洲男人的天堂| 日韩伦理短片在线观看| 亚洲欧美自拍另类图片| 久久久久久99国产精品| 性生活第二下硬不起来| 日本熟妇丰满厨房55| 97国产精品97久久| 亚洲日产av一区二区在线| 丝袜国产专区在线观看| av中文字幕在线导航| 中文字幕人妻av在线观看| 国产普通话插插视频| 57pao国产一区二区| 美女 午夜 在线视频| 91精品国产麻豆国产| 国产综合高清在线观看| 精品人妻每日一部精品| 熟女人妻在线观看视频| 在线制服丝袜中文字幕| 亚洲精品高清自拍av| 亚洲欧美成人综合在线观看| 久久这里只有精彩视频免费| 在线观看成人国产电影| 夜女神免费福利视频| 大骚逼91抽插出水视频| 日本五十路熟新垣里子| 国产成人精品福利短视频| 55夜色66夜色国产精品站| 亚洲激情,偷拍视频| av老司机亚洲一区二区| 国产成人精品午夜福利训2021 | 二区中出在线观看老师| 激情伦理欧美日韩中文字幕| 一区二区三区久久中文字幕| 久久这里只有精品热视频| 国产真实灌醉下药美女av福利| 五月精品丁香久久久久福利社| 天天摸天天日天天操| 日本精品视频不卡一二三| 一区二区三区久久中文字幕| 97色视频在线观看| 色综合久久无码中文字幕波多| 都市激情校园春色狠狠| 超级福利视频在线观看| 国产一区二区欧美三区| 人妻少妇性色欲欧美日韩| 亚洲男人让女人爽的视频| 99久久99一区二区三区| 日韩欧美国产精品91| 最新国产精品网址在线观看| 亚洲欧美激情中文字幕| 丰满的继坶3中文在线观看| 少妇人妻久久久久视频黄片| 九九视频在线精品播放| 国产亚洲视频在线观看| 大陆av手机在线观看| 78色精品一区二区三区| 国产精品一区二区三区蜜臀av| 2o22av在线视频| 大鸡巴插入美女黑黑的阴毛| 日本丰满熟妇BBXBBXHD| 超碰97免费人妻麻豆| 中文字幕视频一区二区在线观看| 人妻少妇亚洲一区二区| 久久香蕉国产免费天天| 亚洲国产成人av在线一区| 性生活第二下硬不起来| 黑人3p华裔熟女普通话| 亚洲1区2区3区精华液| 在线观看免费视频网| 91高清成人在线视频| www天堂在线久久| 动漫美女的小穴视频| 亚洲成高清a人片在线观看| okirakuhuhu在线观看| 99re6热在线精品| 亚洲午夜福利中文乱码字幕| 99的爱精品免费视频| 午夜福利人人妻人人澡人人爽| 熟女91pooyn熟女| 人人妻人人人操人人人爽| 成年女人免费播放视频| av破解版在线观看| 中文字幕在线乱码一区二区 | 在线免费观看日本伦理| 被大鸡吧操的好舒服视频免费| 天天干天天操天天摸天天射| 老司机深夜免费福利视频在线观看| 日韩在线中文字幕色| 国产清纯美女al在线| 精品人人人妻人人玩日产欧| 国内精品在线播放第一页| 久久久久久久亚洲午夜综合福利| 亚洲综合乱码一区二区| 成人sm视频在线观看| 欧美日本在线观看一区二区| 国产高潮无码喷水AV片在线观看| 亚洲欧美清纯唯美另类| 欧美一区二区三区啪啪同性| 中文字幕综合一区二区| 小泽玛利亚视频在线观看| 涩涩的视频在线观看视频| 超碰97人人澡人人| 91综合久久亚洲综合| 深夜男人福利在线观看| 日韩熟女av天堂系列| 亚洲激情偷拍一区二区| av中文字幕在线导航| 日本黄色特一级视频| 岛国av高清在线成人在线| 天天日天天舔天天射进去| 只有精品亚洲视频在线观看| 亚洲av无码成人精品区辽| 亚洲最大黄 嗯色 操 啊| 日本一区精品视频在线观看| 亚洲特黄aaaa片| 91九色国产熟女一区二区| 亚洲国产精品免费在线观看| 国产九色91在线视频| 99av国产精品欲麻豆| 免费一级黄色av网站| 2021国产一区二区| 免费男阳茎伸入女阳道视频| 熟女在线视频一区二区三区| 在线观看的a站 最新| 久久精品国产999| 亚洲高清免费在线观看视频| 欧美日韩国产一区二区三区三州| 国产+亚洲+欧美+另类| 中文字幕奴隷色的舞台50| 日本人妻欲求不满中文字幕| 福利视频广场一区二区| 久草视频 久草视频2| 中文字幕亚洲久久久| 欧美另类z0z变态| 91九色国产熟女一区二区| av高潮迭起在线观看| 欧美日韩熟女一区二区三区| av完全免费在线观看av| 中文 成人 在线 视频| 欧美成人一二三在线网| 日韩av中文在线免费观看| 亚洲1069综合男同| 97精品综合久久在线| 韩国爱爱视频中文字幕| 色在线观看视频免费的| 超鹏97历史在线观看| 亚洲成人精品女人久久久| 亚洲av成人免费网站| 少妇人妻久久久久视频黄片| 国产精品人妻熟女毛片av久| 国产夫妻视频在线观看免费| 久久久超爽一二三av| 亚洲高清国产自产av| 2o22av在线视频| 日日夜夜狠狠干视频| 国产91精品拍在线观看| 免费十精品十国产网站| 一级A一级a爰片免费免会员| 美女福利写真在线观看视频| 国产精品成人xxxx| 天堂av狠狠操蜜桃| 在线国产日韩欧美视频| 亚洲av自拍偷拍综合| 一区二区视频在线观看视频在线 | 自拍 日韩 欧美激情| 亚洲国产成人av在线一区| 18禁网站一区二区三区四区| 老司机你懂得福利视频| 欧美熟妇一区二区三区仙踪林| 东游记中文字幕版哪里可以看到| 亚洲超碰97人人做人人爱| 成人高潮aa毛片免费| 一区二区三区欧美日韩高清播放| 一区二区三区综合视频| av亚洲中文天堂字幕网| 青青草原色片网站在线观看| av线天堂在线观看| 国产女孩喷水在线观看| 中文字幕av男人天堂| aaa久久久久久久久| gav成人免费播放| 精品一区二区三区午夜| 日韩美在线观看视频黄| 国产在线免费观看成人| 久久久人妻一区二区| 一级黄片久久久久久久久| 午夜久久久久久久99| 免费看高清av的网站| 亚洲成人激情视频免费观看了| 春色激情网欧美成人| 骚货自慰被发现爆操| 丝袜肉丝一区二区三区四区在线看| 亚洲激情唯美亚洲激情图片| 香蕉91一区二区三区| 亚洲一区久久免费视频| 久久久久久性虐视频| 国产日韩欧美视频在线导航| 香港一级特黄大片在线播放| 成人蜜桃美臀九一一区二区三区| 999久久久久999| 操日韩美女视频在线免费看| 午夜精彩视频免费一区| 欧美日韩精品永久免费网址| 女生被男生插的视频网站| 人妻3p真实偷拍一二区| 91亚洲国产成人精品性色| 99热这里只有国产精品6| 二区中出在线观看老师| 国产亚州色婷婷久久99精品| 欧美va亚洲va天堂va| 精品区一区二区三区四区人妻| 欧美交性又色又爽又黄麻豆| 免费岛国喷水视频在线观看| 日韩人妻在线视频免费| 亚洲成人熟妇一区二区三区 | 传媒在线播放国产精品一区| 亚洲 国产 成人 在线| 激情综合治理六月婷婷| gogo国模私拍视频| 国产精品久久久黄网站| 啪啪啪18禁一区二区三区| 亚洲老熟妇日本老妇| 美女被肏内射视频网站| 青娱乐极品视频青青草| 一区二区三区在线视频福利| 色av色婷婷人妻久久久精品高清| 久久热这里这里只有精品| 亚洲av成人网在线观看| 色天天天天射天天舔| 亚洲一区制服丝袜美腿| 啊啊好慢点插舔我逼啊啊啊视频| 天天操天天干天天艹| 91色九色porny| 天天操天天插天天色| 国产精品人妻熟女毛片av久| 久久丁香婷婷六月天| 超碰在线中文字幕一区二区| 亚洲免费福利一区二区三区| 欧美少妇性一区二区三区| 五十路熟女av天堂| 天天射,天天操,天天说| 不卡一区一区三区在线| 无码国产精品一区二区高潮久久4 日韩欧美一级精品在线观看 | 黄页网视频在线免费观看| 国产午夜男女爽爽爽爽爽视频| 日本av熟女在线视频| 天天日天天爽天天爽| 久草视频首页在线观看| 内射久久久久综合网| 久久精品国产23696| 欧美区一区二区三视频| 中国熟女@视频91| 青青青国产免费视频| 人人人妻人人澡人人| 在线播放 日韩 av| 少妇与子乱在线观看| 日美女屁股黄邑视频| 精品日产卡一卡二卡国色天香| caoporn蜜桃视频| 国产中文字幕四区在线观看| 国产精品国产三级麻豆| 动漫黑丝美女的鸡巴| 骚逼被大屌狂草视频免费看| 91色秘乱一区二区三区| 2020久久躁狠狠躁夜夜躁 | 日本少妇精品免费视频| 国产精品系列在线观看一区二区 | 97黄网站在线观看| 97超碰国语国产97超碰| 久久久极品久久蜜桃| 免费高清自慰一区二区三区网站 | av手机在线观播放网站| 动漫美女的小穴视频| 在线观看视频网站麻豆| 中文字幕AV在线免费看 | 亚洲免费va在线播放| 中文字幕乱码人妻电影| 伊人精品福利综合导航| 喷水视频在线观看这里只有精品| 成人综合亚洲欧美一区| 亚洲精品乱码久久久久久密桃明| 非洲黑人一级特黄片| 欧美一区二区三区啪啪同性| 早川濑里奈av黑人番号| 日韩欧美中文国产在线| 91老熟女连续高潮对白| 日本在线一区二区不卡视频| 三级av中文字幕在线观看| 中文字幕在线乱码一区二区| 嫩草aⅴ一区二区三区| 国产精品sm调教视频| 中文字幕奴隷色的舞台50| 男人的网址你懂的亚洲欧洲av| 亚洲午夜精品小视频| 成人综合亚洲欧美一区| 国产久久久精品毛片| japanese五十路熟女熟妇| 欧美偷拍亚洲一区二区| 国产第一美女一区二区三区四区| 福利视频一区二区三区筱慧| 亚洲精品福利网站图片| 久久人人做人人妻人人玩精品vr| 亚洲va国产va欧美精品88| 中文人妻AV久久人妻水| 免费岛国喷水视频在线观看| 馒头大胆亚洲一区二区| 青青青青在线视频免费观看| 熟女俱乐部一二三区| 九色视频在线观看免费| lutube在线成人免费看| 色噜噜噜噜18禁止观看| 五月天中文字幕内射| 人妻久久无码中文成人| 国产九色91在线观看精品| 91精品国产高清自在线看香蕉网 | 久久久久久九九99精品| 农村胖女人操逼视频| 日韩精品电影亚洲一区| 国产亚洲四十路五十路| 精品国产午夜视频一区二区| 午夜久久香蕉电影网| 久久免费看少妇高潮完整版| 国内自拍第一页在线观看| 日本最新一二三区不卡在线| 欧亚日韩一区二区三区观看视频| 亚洲护士一区二区三区| 后入美女人妻高清在线| 狠狠嗨日韩综合久久| 中文字幕—97超碰网| 人妻少妇中文有码精品| 欧美日韩精品永久免费网址| 少妇高潮无套内谢麻豆| 人人爽亚洲av人人爽av| 亚洲精品国偷自产在线观看蜜桃| 偷拍美女一区二区三区| 社区自拍揄拍尻屁你懂的| 手机看片福利盒子日韩在线播放 | 超碰97人人澡人人| 啪啪啪啪啪啪啪啪av| 午夜精品一区二区三区更新| 538精品在线观看视频| 91精品国产综合久久久蜜| 国产精品国色综合久久| 天天干天天操天天摸天天射| 好吊视频—区二区三区| 成年人免费看在线视频| 精品91自产拍在线观看一区| 亚洲国际青青操综合网站| jul—619中文字幕在线| 欧美一级片免费在线成人观看| 护士特殊服务久久久久久久| 4个黑人操素人视频网站精品91 | 2022国产精品视频| 18禁美女黄网站色大片下载| 日视频免费在线观看| 福利在线视频网址导航| 国产欧美日韩第三页| 欧美黑人与人妻精品| 亚洲国产精品免费在线观看| 1000部国产精品成人观看视频 | 国产精品久久久黄网站| 亚洲欧美久久久久久久久| 一区二区三区麻豆福利视频| 18禁污污污app下载| 欲满人妻中文字幕在线| 欧美黑人巨大性xxxxx猛交| 成人av电影免费版| 69精品视频一区二区在线观看| 亚洲一区二区三区偷拍女厕91| 亚洲综合在线视频可播放| 久久香蕉国产免费天天| 偷拍自拍国产在线视频| 色综合久久无码中文字幕波多| 我想看操逼黄色大片| 国产精品福利小视频a| 18禁美女无遮挡免费| 亚洲成人国产综合一区| 中文字幕高清在线免费播放| av破解版在线观看| 狠狠躁夜夜躁人人爽天天天天97| 亚洲一区二区三区精品视频在线| 超pen在线观看视频公开97| 国产欧美精品一区二区高清| 最近中文字幕国产在线| 亚洲高清国产一区二区三区| 最新激情中文字幕视频| 日韩一区二区电国产精品| 欧美亚洲中文字幕一区二区三区| 男人操女人的逼免费视频| 国产午夜男女爽爽爽爽爽视频 | 啊用力插好舒服视频| 鸡巴操逼一级黄色气| 国产成人无码精品久久久电影| av大全在线播放免费| 国产精品久久久久久美女校花| 91九色porny蝌蚪国产成人| 少妇与子乱在线观看| 久久永久免费精品人妻专区| 亚洲男人在线天堂网| 日本韩国在线观看一区二区| 日本男女操逼视频免费看| 亚洲欧美清纯唯美另类 | 国产剧情演绎系列丝袜高跟| 93精品视频在线观看| 中国把吊插入阴蒂的视频| 精品一区二区亚洲欧美| 性感美女诱惑福利视频| 极品性荡少妇一区二区色欲| 成人精品视频99第一页| 五十路丰满人妻熟妇| 成人18禁网站在线播放| 国产夫妻视频在线观看免费| 欧美精品免费aaaaaa| 午夜精品一区二区三区更新| 沈阳熟妇28厘米大战黑人| 手机看片福利盒子日韩在线播放| 国产精品伦理片一区二区| 岛国毛片视频免费在线观看| 91天堂天天日天天操| 国产av自拍偷拍盛宴| 天天艹天天干天天操| 日韩欧美一级aa大片| 激情色图一区二区三区| 中文字幕在线一区精品| 四川乱子伦视频国产vip| 欧美精品亚洲精品日韩在线| 欧美国品一二三产区区别| 一区二区三区四区视频在线播放| 成人影片高清在线观看| 免费黄页网站4188| 高潮喷水在线视频观看| 伊人综合aⅴ在线网| 欧美色婷婷综合在线| 91精品一区二区三区站长推荐| 青青草国内在线视频精选| 欧美日韩在线精品一区二区三| 亚洲激情av一区二区| 成人性爱在线看四区| 中国视频一区二区三区| 老司机福利精品视频在线| 国产普通话插插视频| 国产视频一区在线观看| 免费黄色成人午夜在线网站| 神马午夜在线观看视频| 成年人中文字幕在线观看| 国产精品视频男人的天堂| 国产va精品免费观看| 亚洲 中文字幕在线 日韩| 日本熟妇一区二区x x| 国产精品一区二区三区蜜臀av| 日韩伦理短片在线观看| 欧亚日韩一区二区三区观看视频 | 国产高清精品一区二区三区| 亚洲青青操骚货在线视频| 亚洲高清国产拍青青草原| 亚洲精品一线二线在线观看| 亚洲偷自拍高清视频| 视频一区二区综合精品| 日韩成人性色生活片| 91色秘乱一区二区三区| 孕妇奶水仑乱A级毛片免费看| 亚洲免费av在线视频| 天天日天天鲁天天操| 亚洲黄色av网站免费播放| 精品人妻一二三区久久| 9国产精品久久久久老师| 91av中文视频在线| 亚洲福利精品福利精品福利| 欧美3p在线观看一区二区三区| 亚洲av日韩精品久久久| 国产aⅴ一线在线观看| 日本a级视频老女人| 亚洲欧美在线视频第一页| 1区2区3区不卡视频| 97超碰免费在线视频| 婷婷五月亚洲综合在线| 福利国产视频在线观看| 91she九色精品国产| 欧美偷拍亚洲一区二区| 人妻丝袜诱惑我操她视频| 在线不卡成人黄色精品| 91免费观看国产免费| 阿v天堂2014 一区亚洲| 青青青青青青青在线播放视频| 久草视频首页在线观看| 天天干天天操天天扣| 亚洲国产精品久久久久蜜桃| 大尺度激情四射网站| 大香蕉伊人中文字幕| 91在线免费观看成人| 国产欧美日韩在线观看不卡| 国产亚州色婷婷久久99精品| 懂色av蜜桃a v| 欧美日韩不卡一区不区二区| 97国产福利小视频合集| 欧美精品免费aaaaaa| 亚洲一区二区三区av网站| japanese五十路熟女熟妇| 一区二区三区av高清免费| 热久久只有这里有精品| 国产熟妇乱妇熟色T区| 91中文字幕最新合集| 精品91高清在线观看| 性生活第二下硬不起来| 阿v天堂2014 一区亚洲| 日本一道二三区视频久久| 久久美欧人妻少妇一区二区三区| 九色精品视频在线播放| 国产又粗又黄又硬又爽| 国产成人午夜精品福利| 一区二区三区视频,福利一区二区| 免费一级特黄特色大片在线观看 | 亚洲第17页国产精品| 91人妻人人做人人爽在线| 搡老妇人老女人老熟女| 欧美男同性恋69视频| 春色激情网欧美成人| 少妇ww搡性bbb91| 99精品久久久久久久91蜜桃| 93精品视频在线观看| 人人超碰国字幕观看97| av中文字幕国产在线观看| 青青青国产片免费观看视频| 亚洲欧美一卡二卡三卡| 亚洲麻豆一区二区三区| 久草电影免费在线观看| 绯色av蜜臀vs少妇| 无码精品一区二区三区人| 日本免费视频午夜福利视频| 春色激情网欧美成人| 乱亲女秽乱长久久久| 一二三中文乱码亚洲乱码one| 国产1区,2区,3区| 免费成人av中文字幕| av完全免费在线观看av| 99精品国产aⅴ在线观看| av森泽佳奈在线观看| 五十路熟女人妻一区二区9933| 二区中出在线观看老师 | 欧美日韩人妻久久精品高清国产| 搡老妇人老女人老熟女| 中文字幕网站你懂的| 亚洲国产在线精品国偷产拍| 中文乱理伦片在线观看| 蜜臀av久久久久蜜臀av麻豆| 日本黄在免费看视频| 97瑟瑟超碰在线香蕉| 美女少妇亚洲精选av| 中文字幕一区二区三区人妻大片| 中文字幕人妻一区二区视频| 不卡日韩av在线观看| 亚洲一区二区三区在线高清| 国产一区成人在线观看视频 | 成年午夜免费无码区| av亚洲中文天堂字幕网| 91传媒一区二区三区| 精品久久久久久高潮| 自拍偷拍一区二区三区图片| 日韩人妻在线视频免费| 亚洲乱码中文字幕在线| 免费十精品十国产网站| 热久久只有这里有精品| 亚洲精品一区二区三区老狼| 2022国产精品视频| 香港一级特黄大片在线播放| 成人激情文学网人妻| 久久久久久久久久性潮| 精品国产成人亚洲午夜| 亚洲乱码中文字幕在线| 国产真实灌醉下药美女av福利| 亚洲成人精品女人久久久| 岛国av高清在线成人在线| 国产福利在线视频一区| 精品国产乱码一区二区三区乱| 一区二区三区久久中文字幕| 中文字幕日韩精品日本| 亚洲美女自偷自拍11页| 亚洲美女美妇久久字幕组| 国产乱弄免费视频观看| 精品视频中文字幕在线播放| 2o22av在线视频| 日本少妇在线视频大香蕉在线观看| 福利一二三在线视频观看| 国产chinesehd精品麻豆| 日本美女性生活一级片| 日本韩国免费一区二区三区视频| 亚洲中文精品字幕在线观看 | aⅴ五十路av熟女中出| 国产黄色大片在线免费播放| 丁香花免费在线观看中文字幕| 国产精品3p和黑人大战| 强行扒开双腿猛烈进入免费版| 欧美在线偷拍视频免费看| 午夜场射精嗯嗯啊啊视频| 80电影天堂网官网| 2021国产一区二区| 51国产成人精品视频| 红杏久久av人妻一区| 在线观看视频 你懂的| 九色视频在线观看免费| 丝袜亚洲另类欧美变态| 鸡巴操逼一级黄色气| 夜女神免费福利视频| 欧美精产国品一二三区| 66久久久久久久久久久| 亚洲av黄色在线网站| 美女日逼视频免费观看| 九九视频在线精品播放| 亚洲高清免费在线观看视频| 精品一线二线三线日本| 日本熟妇一区二区x x| huangse网站在线观看| 久久久久久久久久性潮| 亚洲一区自拍高清免费视频| 91福利在线视频免费观看| 五月天久久激情视频| 熟女视频一区,二区,三区| 久草视频 久草视频2| 国产精品国产三级国产精东| 人妻丝袜诱惑我操她视频| 在线观看视频 你懂的| 婷婷激情四射在线观看视频| av手机免费在线观看高潮| 中文字幕第1页av一天堂网| 欧美老鸡巴日小嫩逼| 十八禁在线观看地址免费| 中文字母永久播放1区2区3区| 又黄又刺激的午夜小视频| 66久久久久久久久久久| 老师让我插进去69AV| 亚洲成人熟妇一区二区三区| 国产美女午夜福利久久| 国产精品黄页网站视频| 久碰精品少妇中文字幕av| 日本韩国免费福利精品| 2020av天堂网在线观看| 开心 色 六月 婷婷| 91极品大一女神正在播放| 亚洲精品福利网站图片| 日本人妻少妇18—xx| 在线免费观看欧美小视频| 91国产在线视频免费观看| 亚洲专区激情在线观看视频| 欧美aa一级一区三区四区| 黄色视频成年人免费观看| 国产成人一区二区三区电影网站| 激情小视频国产在线| 亚洲综合一区成人在线| 在线免费观看av日韩| 2020av天堂网在线观看| av在线免费资源站| 我想看操逼黄色大片| 国产日韩一区二区在线看| 91传媒一区二区三区| 91大屁股国产一区二区| 国产+亚洲+欧美+另类| 中文字幕人妻熟女在线电影| 韩国一级特黄大片做受| 欧美精品亚洲精品日韩在线| 国产亚洲国产av网站在线| 丝袜国产专区在线观看| 国产一级麻豆精品免费| 黑人解禁人妻叶爱071| 丰满少妇翘臀后进式| 日韩av中文在线免费观看| 成人精品在线观看视频| 亚洲蜜臀av一区二区三区九色| 99一区二区在线观看| 老司机免费视频网站在线看| 3337p日本欧洲大胆色噜噜| 粉嫩欧美美人妻小视频| 女人精品内射国产99| 青娱乐极品视频青青草| 婷婷久久久综合中文字幕| 黑人性生活视频免费看| 伊人精品福利综合导航| 日韩美av高清在线| 国产精品国产三级麻豆| 欧美另类重口味极品在线观看| 视频一区 视频二区 视频| 日韩av大胆在线观看| 超级碰碰在线视频免费观看| 美女av色播在线播放| 国产91久久精品一区二区字幕| 中文字幕av第1页中文字幕| 一本久久精品一区二区| 亚洲一区制服丝袜美腿| 亚洲一区二区久久久人妻| 亚洲久久午夜av一区二区| 91色秘乱一区二区三区| 一区二区在线视频中文字幕 | 少妇与子乱在线观看| 国产91久久精品一区二区字幕| 欧洲亚洲欧美日韩综合| 久久久久久cao我的性感人妻| 91国偷自产一区二区三区精品| 18禁精品网站久久| 亚洲图库另类图片区| 欧美性受xx黑人性猛交| 国产普通话插插视频| 亚洲综合一区二区精品久久| 亚洲午夜福利中文乱码字幕| 动漫黑丝美女的鸡巴| 日本性感美女三级视频| 中文字幕日韩人妻在线三区| 黄色资源视频网站日韩| 日韩精品电影亚洲一区| 午夜美女福利小视频| 搞黄色在线免费观看| 国产麻豆91在线视频| 成年人中文字幕在线观看| 这里有精品成人国产99| eeuss鲁片一区二区三区| 不卡精品视频在线观看| 5528327男人天堂| 国内自拍第一页在线观看| yellow在线播放av啊啊啊| 日韩欧美高清免费在线| 美女吃鸡巴操逼高潮视频| 国产性色生活片毛片春晓精品| 久久精品国产亚洲精品166m| 国产免费av一区二区凹凸四季| 天天做天天干天天操天天射| 亚洲免费av在线视频| 一区二区三区 自拍偷拍| 福利在线视频网址导航| 黄色视频在线观看高清无码| 青青青视频手机在线观看| 成年美女黄网站18禁久久| 久久精品亚洲成在人线a| 欧美乱妇无乱码一区二区| 国产剧情演绎系列丝袜高跟| 日韩在线视频观看有码在线| 欧美中国日韩久久精品| 欧美精品久久久久久影院| 成人乱码一区二区三区av| 中文字幕最新久久久| 人人妻人人爽人人添夜| 一色桃子人妻一区二区三区| 欧美亚洲国产成人免费在线| 亚洲男人在线天堂网| 福利在线视频网址导航| 亚洲欧美一卡二卡三卡| 久久这里只有精彩视频免费| 在线免费91激情四射| 91综合久久亚洲综合| 国产伊人免费在线播放| 久久久久久国产精品| 国产成人无码精品久久久电影| 国产日韩精品一二三区久久久| 国产在线自在拍91国语自产精品| 中英文字幕av一区| 综合激情网激情五月五月婷婷| 亚洲欧美综合在线探花| 欧美另类重口味极品在线观看| 极品粉嫩小泬白浆20p主播| 欧美激情精品在线观看| 亚洲午夜伦理视频在线| 三上悠亚和黑人665番号| 天天操天天干天天插| 欧美日韩一区二区电影在线观看| 久久久麻豆精亚洲av麻花| 国产熟妇乱妇熟色T区| 亚洲av黄色在线网站| 国产一区二区火爆视频| av大全在线播放免费| 人人妻人人爽人人添夜| 99精品久久久久久久91蜜桃| 东京热男人的av天堂| 亚洲国产精品久久久久久6| 美女av色播在线播放| 午夜精品久久久久久99热| 日本欧美视频在线观看三区| 蜜桃臀av蜜桃臀av| 国产亚州色婷婷久久99精品| 11久久久久久久久久久| 性生活第二下硬不起来| 国产日本欧美亚洲精品视| 亚洲美女美妇久久字幕组| 九色视频在线观看免费| 五月天色婷婷在线观看视频免费| 黄色成年网站午夜在线观看 | 日本在线不卡免费视频| 精品一线二线三线日本| 亚洲av可乐操首页| 天天操天天射天天操天天天| 天天射夜夜操综合网| 韩国亚洲欧美超一级在线播放视频| 蜜桃视频17c在线一区二区| 欧美黑人性猛交xxxxⅹooo| 青青青视频自偷自拍38碰| 精品黑人一区二区三区久久国产| a v欧美一区=区三区| 日韩精品中文字幕播放| 岛国免费大片在线观看| 人妻熟女中文字幕aⅴ在线| 香蕉91一区二区三区| 9色精品视频在线观看| 免费看国产av网站| 欧美色呦呦最新网址| 99人妻视频免费在线| 国产男女视频在线播放| 欧美一级色视频美日韩| 午夜久久久久久久精品熟女| 亚洲一区二区三区精品视频在线 | caoporn蜜桃视频| 日日操综合成人av| 亚洲男人让女人爽的视频| 亚洲高清国产一区二区三区| 国产第一美女一区二区三区四区| 青青草在观免费国产精品| 五十路熟女人妻一区二区9933| 黄色av网站免费在线| 老司机免费视频网站在线看| 欧美一区二区三区在线资源| 国产黄色大片在线免费播放| 九色porny九色9l自拍视频| 欧美一级片免费在线成人观看| 国产精品日韩欧美一区二区| 精品一区二区三区午夜| 国产日本欧美亚洲精品视| 特黄老太婆aa毛毛片| 天天操天天干天天日狠狠插| 日韩精品啪啪视频一道免费| 欧美国产亚洲中英文字幕| 国产麻豆国语对白露脸剧情 | 五月色婷婷综合开心网4438| 狠狠躁狠狠爱网站视频| 欧美色婷婷综合在线| 在线观看国产网站资源| 国产av欧美精品高潮网站| 亚洲综合在线观看免费| 91九色porny国产在线| 日本乱人一区二区三区| 亚洲激情av一区二区| 亚洲欧美另类自拍偷拍色图| 国产精品污污污久久| 夜色福利视频在线观看| 天堂av狠狠操蜜桃| 2020av天堂网在线观看| 欧美成人黄片一区二区三区 | 首之国产AV医生和护士小芳| 在线播放一区二区三区Av无码| 北条麻妃高跟丝袜啪啪| 午夜蜜桃一区二区三区| 曰本无码人妻丰满熟妇啪啪| 视频一区二区在线免费播放| 欧美黑人与人妻精品| 亚洲日本一区二区三区| 亚洲精品国偷自产在线观看蜜桃| 粉嫩av蜜乳av蜜臀| 红杏久久av人妻一区| 国产视频网站一区二区三区| 国产成人精品亚洲男人的天堂| 大香蕉日本伊人中文在线| 日本美女成人在线视频| 大学生A级毛片免费视频| 最新中文字幕免费视频| 亚洲一级 片内射视正片| 和邻居少妇愉情中文字幕| 97国产在线观看高清| 久久亚洲天堂中文对白| 国产一区二区火爆视频 | 97国产在线观看高清| 97人妻夜夜爽二区欧美极品| 超级av免费观看一区二区三区| 无码国产精品一区二区高潮久久4| 香蕉aⅴ一区二区三区| 少妇深喉口爆吞精韩国| 2o22av在线视频| 青青尤物在线观看视频网站| 在线观看免费岛国av| 果冻传媒av一区二区三区| 扒开让我视频在线观看| 国产精品人妻熟女毛片av久| 日本熟女精品一区二区三区| 国产免费高清视频视频| 岛国一区二区三区视频在线| 啪啪啪啪啪啪啪免费视频| 淫秽激情视频免费观看| 国产在线一区二区三区麻酥酥| 欧美精品中文字幕久久二区| 日韩美av高清在线| 午夜精品亚洲精品五月色| 第一福利视频在线观看| 2017亚洲男人天堂| 91超碰青青中文字幕| 欧美少妇性一区二区三区| 免费一级黄色av网站| 欧美viboss性丰满| 久久久制服丝袜中文字幕| 亚洲国产精品久久久久久6| 欧美一级视频一区二区| 天天日天天做天天日天天做| 91‖亚洲‖国产熟女| 亚洲精品一线二线在线观看| 扒开让我视频在线观看| 999九九久久久精品| 中文字幕中文字幕 亚洲国产| 新97超碰在线观看| 欧美专区日韩专区国产专区| 国产一区二区在线欧美| 亚洲综合在线视频可播放| 国产精品系列在线观看一区二区| 国产福利小视频免费观看| 欧美成一区二区三区四区| 欧美交性又色又爽又黄麻豆| 老师啊太大了啊啊啊尻视频| 动漫黑丝美女的鸡巴| 91色九色porny| 中国黄色av一级片| 欧美在线一二三视频| 日韩人妻在线视频免费| 最新的中文字幕 亚洲| 人妻无码色噜噜狠狠狠狠色| av乱码一区二区三区| 999久久久久999| 亚洲精品高清自拍av| 日本高清撒尿pissing| 亚欧在线视频你懂的| 国产成人精品亚洲男人的天堂| 成年人该看的视频黄免费| 在线成人日韩av电影| 精品一区二区三区在线观看| 国产黄色高清资源在线免费观看 | 亚洲精品成人网久久久久久小说| 亚洲成人精品女人久久久| 亚洲男人在线天堂网| 精品一区二区三区在线观看| 少妇高潮一区二区三区| 91老熟女连续高潮对白| 黄色黄色黄片78在线| 天天干天天操天天扣| 日本少妇人妻xxxxx18| 无码国产精品一区二区高潮久久4| 中文字幕在线乱码一区二区| 中国产一级黄片免费视频播放| 在线观看的黄色免费网站| 日韩写真福利视频在线观看| 五月天中文字幕内射| 制丝袜业一区二区三区| 国产美女一区在线观看| 色花堂在线av中文字幕九九| 日本特级片中文字幕| 欧美偷拍亚洲一区二区| 内射久久久久综合网| 日本黄在免费看视频| 欧美另类z0z变态| 看一级特黄a大片日本片黑人| 91国内视频在线观看| 欧洲日韩亚洲一区二区三区 | 后入美女人妻高清在线| 日本韩国亚洲综合日韩欧美国产| 又色又爽又黄又刺激av网站| 自拍偷拍,中文字幕| 唐人色亚洲av嫩草| 喷水视频在线观看这里只有精品| 欧美偷拍亚洲一区二区| 9国产精品久久久久老师| 久久久麻豆精亚洲av麻花| 日韩人妻xxxxx| 日本免费午夜视频网站| 懂色av蜜桃a v| 亚洲高清视频在线不卡| 中文字幕av熟女人妻| okirakuhuhu在线观看| 一二三区在线观看视频| 日本少妇人妻xxxxx18| 天天日天天干天天舔天天射| 中文字幕一区二区三区蜜月| 天天摸天天亲天天舔天天操天天爽| 把腿张开让我插进去视频| 美女在线观看日本亚洲一区| 超碰97人人做人人爱| 狠狠躁狠狠爱网站视频| 色综合色综合色综合色| 在线观看国产网站资源| 欧美中国日韩久久精品| 欧美视频不卡一区四区| 久久艹在线观看视频| 11久久久久久久久久久| 国产久久久精品毛片| 国产福利在线视频一区| 91试看福利一分钟| 二区中出在线观看老师| 天天干夜夜操天天舔| 喷水视频在线观看这里只有精品 | 又大又湿又爽又紧A视频| 91试看福利一分钟| 在线免费观看视频一二区| 日噜噜噜夜夜噜噜噜天天噜噜噜| 亚洲熟色妇av日韩熟色妇在线| 天天射夜夜操狠狠干| 男生用鸡操女生视频动漫| 韩国爱爱视频中文字幕| 夫妻在线观看视频91| 日韩精品中文字幕福利| 久久久久久97三级| 99国产精品窥熟女精品| 一级a看免费观看网站| 黑人乱偷人妻中文字幕| 亚洲 中文 自拍 另类 欧美| 午夜精品一区二区三区更新| 80电影天堂网官网| 国产精品黄页网站视频| 色综合久久久久久久久中文| 激情国产小视频在线| 日本又色又爽又黄又粗| 福利视频一区二区三区筱慧| 一级黄片久久久久久久久| 插逼视频双插洞国产操逼插洞| 精品人妻每日一部精品| av乱码一区二区三区| 精品日产卡一卡二卡国色天香| 精品高潮呻吟久久av| 亚洲精品乱码久久久本| 免费岛国喷水视频在线观看| 日本一区美女福利视频| 欧美美女人体视频一区| 爱爱免费在线观看视频| 亚洲一级av大片免费观看| 天天躁日日躁狠狠躁av麻豆| 色综合久久五月色婷婷综合 | 精品区一区二区三区四区人妻 | 骚逼被大屌狂草视频免费看| 欧美成人综合色在线噜噜| 久久丁香花五月天色婷婷| asmr福利视频在线观看| 78色精品一区二区三区| 最新欧美一二三视频| 国产精品女邻居小骚货| 国产一区二区神马久久| 青青热久免费精品视频在线观看| 一区二区三区四区视频| 19一区二区三区在线播放| 岛国一区二区三区视频在线| 国产高清在线观看1区2区| 啊慢点鸡巴太大了啊舒服视频| 亚洲 欧美 自拍 偷拍 在线| 国产福利在线视频一区| 老鸭窝在线观看一区| 综合激情网激情五月五月婷婷| 激情图片日韩欧美人妻| 天堂女人av一区二区| 4个黑人操素人视频网站精品91| 欧美男人大鸡吧插女人视频| 啊慢点鸡巴太大了啊舒服视频| 91精品啪在线免费| 自拍偷拍亚洲另类色图| 亚洲av极品精品在线观看| 免费成人av中文字幕| 亚洲成人免费看电影| 伊人综合免费在线视频| 精品高潮呻吟久久av| 日韩av有码一区二区三区4| 欧美日本在线视频一区| 亚洲第17页国产精品| 最后99天全集在线观看| 日本少妇精品免费视频| 自拍偷拍vs一区二区三区| 97超碰人人搞人人| 男人在床上插女人视频| aiss午夜免费视频| 视频一区 二区 三区 综合| 一本一本久久a久久精品综合不卡| 亚洲 人妻 激情 中文| 在线可以看的视频你懂的| av在线播放国产不卡| 阴茎插到阴道里面的视频| 日韩欧美一级aa大片| 东游记中文字幕版哪里可以看到| 欧美一区二区三区高清不卡tv| 久久久久久9999久久久久| av视网站在线观看| 亚洲天堂精品久久久| 综合精品久久久久97| 亚洲中文字幕人妻一区| 动漫美女的小穴视频| 熟女在线视频一区二区三区| 一本久久精品一区二区| 中文字幕av熟女人妻| 日本乱人一区二区三区| 在线观看的a站 最新| 国产精品欧美日韩区二区 | 岛国青草视频在线观看| 欧美xxx成人在线| 中文字幕,亚洲人妻| 日本一二三区不卡无| 日本18禁久久久久久| 天天日天天干天天要| 极品丝袜一区二区三区| 中文字幕—97超碰网| 精品黑人巨大在线一区| 亚洲熟色妇av日韩熟色妇在线 | 红杏久久av人妻一区| 国产剧情演绎系列丝袜高跟| 97人妻色免费视频| 999热精品视频在线| 亚洲午夜福利中文乱码字幕| 国产精彩对白一区二区三区| 免费一级特黄特色大片在线观看| 色噜噜噜噜18禁止观看| 揄拍成人国产精品免费看视频| 91国语爽死我了不卡| 国产成人精品亚洲男人的天堂| 婷婷午夜国产精品久久久| 亚洲国产在线精品国偷产拍 | 超碰在线观看免费在线观看| av中文字幕国产在线观看| 欧美特色aaa大片| 97人妻色免费视频| 日韩成人综艺在线播放| 亚洲1069综合男同| 国产免费av一区二区凹凸四季| 97国产精品97久久| 97超碰免费在线视频| 无套猛戳丰满少妇人妻| 精品国产午夜视频一区二区| 好吊视频—区二区三区| 传媒在线播放国产精品一区 | 年轻的人妻被夫上司侵犯| 欧美熟妇一区二区三区仙踪林| av天堂中文字幕最新| 国产麻豆乱子伦午夜视频观看| 日韩欧美在线观看不卡一区二区| 中文字幕在线乱码一区二区| 男人的天堂在线黄色| 人妻av无码专区久久绿巨人| 视频一区二区三区高清在线| 人妻少妇av在线观看| 国产成人精品av网站| 天堂av在线最新版在线| 青青草精品在线视频观看| 在线观看操大逼视频| 午夜精品一区二区三区城中村| 狠狠鲁狠狠操天天晚上干干| 2020国产在线不卡视频| 久草极品美女视频在线观看| 91自产国产精品视频| 天天操夜夜操天天操天天操 | 亚洲综合色在线免费观看| 青娱乐在线免费视频盛宴| 久久精品久久精品亚洲人| 亚洲欧美国产麻豆综合| 国产亚洲成人免费在线观看| 精品国产高潮中文字幕| 老鸭窝日韩精品视频观看| 欧美成人综合视频一区二区| 亚洲国际青青操综合网站| 人妻少妇精品久久久久久| 自拍偷拍vs一区二区三区| 国产妇女自拍区在线观看| h国产小视频福利在线观看| 国产一区二区火爆视频| 传媒在线播放国产精品一区| av网址国产在线观看| 国产亚洲国产av网站在线| 18禁免费av网站| 伊人开心婷婷国产av| 九色porny九色9l自拍视频| 欧美aa一级一区三区四区| 大黑人性xxxxbbbb| 99热久久极品热亚洲| 国产变态另类在线观看| 青青草国内在线视频精选| 丝袜长腿第一页在线| 黑人变态深video特大巨大| 国产又粗又猛又爽又黄的视频美国| 天天干夜夜操啊啊啊| 欧美黑人与人妻精品| 91快播视频在线观看| 福利视频网久久91| 影音先锋女人av噜噜色| 少妇人妻真实精品视频| 亚洲人成精品久久久久久久| 国产久久久精品毛片| 另类av十亚洲av| 最新国产精品网址在线观看| 1区2区3区不卡视频| 亚洲欧美色一区二区| 日本少妇的秘密免费视频| 黄色无码鸡吧操逼视频| 国产av福利网址大全| 99精品视频在线观看免费播放| 不卡一区一区三区在线| 欧美日韩亚洲国产无线码| 亚洲综合乱码一区二区| 日本一道二三区视频久久 | 一区二区三区精品日本| 亚洲国产欧美一区二区三区…| 亚洲中文精品人人免费| av无限看熟女人妻另类av| 国产精品久久久久久久久福交| 精品久久久久久久久久久99| 一区二区三区四区视频| 蜜臀av久久久久久久| 女同互舔一区二区三区| 日本啪啪啪啪啪啪啪| 在线免费91激情四射 | 免费观看国产综合视频| 日韩人妻xxxxx| 人人妻人人爽人人添夜| 国产黄色高清资源在线免费观看| av久久精品北条麻妃av观看| 伊拉克及约旦宣布关闭领空| 日本一区美女福利视频| av中文字幕国产在线观看| av在线免费中文字幕| 欧美国品一二三产区区别| 日韩欧美在线观看不卡一区二区| 亚洲国产中文字幕啊啊啊不行了| 男人操女人的逼免费视频| 日本五十路熟新垣里子| 沙月文乃人妻侵犯中文字幕在线| 9l人妻人人爽人人爽| 精品首页在线观看视频| 免费啪啪啪在线观看视频| 亚洲粉嫩av一区二区三区| 亚洲成人激情视频免费观看了| 人妻凌辱欧美丰满熟妇| 日韩黄色片在线观看网站| 福利一二三在线视频观看| 欧美少妇性一区二区三区| 激情伦理欧美日韩中文字幕| 亚洲综合另类精品小说| 国产剧情演绎系列丝袜高跟| 国产精品sm调教视频| 国产污污污污网站在线| 成人乱码一区二区三区av| 日韩欧美国产精品91| 97超碰最新免费在线观看| 欧美xxx成人在线| 99精品国产aⅴ在线观看| 国产精品sm调教视频| 亚洲无码一区在线影院| 99久久99久国产黄毛片| 久久久久久cao我的性感人妻| 亚洲精品欧美日韩在线播放| 人妻在线精品录音叫床| 欧美成人精品欧美一级黄色| 风流唐伯虎电视剧在线观看| 国产精选一区在线播放| av在线资源中文字幕| 伊人日日日草夜夜草| 性感美女福利视频网站| 精品一区二区亚洲欧美| 久久久久久久亚洲午夜综合福利| 大陆胖女人与丈夫操b国语高清| 欧美精品 日韩国产| 亚洲第一黄色在线观看| 亚洲精品精品国产综合| 日本最新一二三区不卡在线 | 成人免费做爰高潮视频| 色哟哟在线网站入口| 国产黄网站在线观看播放| 伊人网中文字幕在线视频| 欧洲亚洲欧美日韩综合| 97年大学生大白天操逼| 成年午夜免费无码区| 中文字幕亚洲中文字幕| 特级无码毛片免费视频播放 | 欧美精品国产综合久久| yellow在线播放av啊啊啊 | 色哟哟在线网站入口| 欧美国产亚洲中英文字幕| 国产精品黄页网站视频| 日日操综合成人av| 在线视频精品你懂的| 综合国产成人在线观看| 中文字幕一区二 区二三区四区| 把腿张开让我插进去视频| 人妻无码中文字幕专区| 欧美精品久久久久久影院| 男人在床上插女人视频| 日本少妇精品免费视频| 色在线观看视频免费的| 亚洲人妻av毛片在线| 福利片区一区二体验区| 中文字幕一区二区三区人妻大片 | 亚洲综合在线视频可播放| 国产精品久久综合久久| 国产V亚洲V天堂无码欠欠| 青青草国内在线视频精选| 综合页自拍视频在线播放| 成人资源在线观看免费官网| 污污小视频91在线观看| 大骚逼91抽插出水视频| 中文字幕午夜免费福利视频| 欧美3p在线观看一区二区三区| 99热久久这里只有精品| 国产自拍在线观看成人| 日本成人一区二区不卡免费在线| av在线免费中文字幕| gay gay男男瑟瑟在线网站| 亚洲欧美激情中文字幕| 欧美日本在线观看一区二区| 51精品视频免费在线观看| 国产高潮无码喷水AV片在线观看| 国产精品久久久久国产三级试频| 亚洲最大免费在线观看| 亚洲一区自拍高清免费视频| 国产刺激激情美女网站| 久久精品36亚洲精品束缚| av手机在线免费观看日韩av| 女同互舔一区二区三区| 色婷婷久久久久swag精品| 精品久久久久久久久久久99| 日韩欧美亚洲熟女人妻| 亚洲蜜臀av一区二区三区九色| 国产精品3p和黑人大战| 动漫精品视频在线观看| 人妻凌辱欧美丰满熟妇| 中文字幕无码日韩专区免费| 中文字幕视频一区二区在线观看| 亚洲av无硬久久精品蜜桃| 成人免费做爰高潮视频| 久久免费看少妇高潮完整版| 青青草亚洲国产精品视频| 中文字幕在线免费第一页| av森泽佳奈在线观看| 很黄很污很色的午夜网站在线观看 | 99热这里只有国产精品6| 日本人妻欲求不满中文字幕| 免费福利av在线一区二区三区| 18禁网站一区二区三区四区| 成人区人妻精品一区二视频| 青青青青青操视频在线观看| 最新中文字幕乱码在线| japanese五十路熟女熟妇| 日韩熟女av天堂系列| 沈阳熟妇28厘米大战黑人| 国产午夜亚洲精品不卡在线观看 | av破解版在线观看| 日本高清成人一区二区三区| 亚洲欧美自拍另类图片| 农村胖女人操逼视频| 国产之丝袜脚在线一区二区三区| 99热久久这里只有精品8| 偷偷玩弄新婚人妻h视频| av乱码一区二区三区| 精品成人啪啪18免费蜜臀| 中国老熟女偷拍第一页| 91啪国自产中文字幕在线| 久久人人做人人妻人人玩精品vr| 青青草人人妻人人妻| 成人性黑人一级av| 青青青青青青青青青国产精品视频| 岛国毛片视频免费在线观看| 欧洲欧美日韩国产在线| 日本人妻欲求不满中文字幕| 护士小嫩嫩又紧又爽20p| v888av在线观看视频| 久久精品国产亚洲精品166m| 天天干天天操天天扣| 亚洲天天干 夜夜操| 97资源人妻免费在线视频| 又粗又硬又猛又爽又黄的| 日本免费一级黄色录像| 亚洲欧美一区二区三区爱爱动图| 老鸭窝在线观看一区| 嫩草aⅴ一区二区三区| 免费无码人妻日韩精品一区二区 | 99精品视频在线观看免费播放| 韩国男女黄色在线观看| 亚洲码av无色中文| 日本少妇人妻xxxxx18| 亚洲少妇人妻无码精品| 91麻豆精品传媒国产黄色片| 青青青青视频在线播放| 91人妻人人做人人爽在线| 国产高潮无码喷水AV片在线观看| 亚洲精品三级av在线免费观看| 看一级特黄a大片日本片黑人| 日韩不卡中文在线视频网站| 久久久久久久99精品| 东京热男人的av天堂| 毛茸茸的大外阴中国视频| 88成人免费av网站| 香蕉片在线观看av| 国产成人精品一区在线观看 | av亚洲中文天堂字幕网| 爱爱免费在线观看视频| 亚洲日本一区二区三区| 久久永久免费精品人妻专区 | 欧美一级视频一区二区| 人妻3p真实偷拍一二区| 青青青国产免费视频| 在线视频自拍第三页| gav成人免费播放| 国产性色生活片毛片春晓精品 | 福利视频网久久91| 欧美精品一区二区三区xxxx| 中国无遮挡白丝袜二区精品| 任你操任你干精品在线视频| 天天操,天天干,天天射| 日韩av熟妇在线观看| 日韩精品电影亚洲一区| 亚洲熟妇无码一区二区三区| 日本成人不卡一区二区| 亚洲免费视频欧洲免费视频| 国产精品三级三级三级| 在线免费91激情四射 | 亚洲 国产 成人 在线| 国产变态另类在线观看| 亚洲天天干 夜夜操| 超碰中文字幕免费观看| eeuss鲁片一区二区三区| 99热久久这里只有精品| 亚洲国产成人av在线一区| 精品美女在线观看视频在线观看| 狠狠鲁狠狠操天天晚上干干| 日本人妻少妇18—xx| 精品国产污污免费网站入口自| 国产美女一区在线观看| 欧美第一页在线免费观看视频| 性感美女高潮视频久久久| 最新国产精品拍在线观看| 1024久久国产精品| 日韩不卡中文在线视频网站| 国产日本精品久久久久久久| 青春草视频在线免费播放| 一区二区视频在线观看免费观看| 人妻丝袜av在线播放网址| 国产精品视频资源在线播放| 国产又粗又硬又猛的毛片视频 | 国产揄拍高清国内精品对白| 亚洲Av无码国产综合色区| 亚洲一区自拍高清免费视频| 男人的天堂在线黄色| 91国语爽死我了不卡| 一区二区三区毛片国产一区| 国产日韩欧美视频在线导航| 69精品视频一区二区在线观看| 日韩不卡中文在线视频网站| 性感美女福利视频网站| 亚洲综合在线视频可播放| 天天干天天操天天扣| 亚洲无码一区在线影院| 成人国产影院在线观看| av在线shipin| 中文字幕中文字幕人妻| 91成人在线观看免费视频| 日韩伦理短片在线观看| 新婚人妻聚会被中出| 中文字幕高清资源站| 国产麻豆剧果冻传媒app| 自拍偷拍日韩欧美亚洲| 天天操,天天干,天天射| 成人av久久精品一区二区| 日韩a级黄色小视频| 真实国产乱子伦一区二区| 99热99re在线播放| 亚洲少妇人妻无码精品| 亚洲成人激情视频免费观看了| 91精品国产91青青碰| 人妻凌辱欧美丰满熟妇| 亚洲一区二区三区久久受| 六月婷婷激情一区二区三区| 天天色天天操天天舔| 骚货自慰被发现爆操| 国产丰满熟女成人视频| 2020中文字幕在线播放| 97超碰最新免费在线观看| 啊啊好大好爽啊啊操我啊啊视频| 亚洲中文精品人人免费| 2021国产一区二区| 欧美 亚洲 另类综合| 亚洲中文精品字幕在线观看| 国产福利小视频二区| 午夜免费体验区在线观看| 免费在线黄色观看网站| 农村胖女人操逼视频| 国产性色生活片毛片春晓精品 | 日韩欧美中文国产在线| 年轻的人妻被夫上司侵犯| 97超碰最新免费在线观看| 欧美黑人与人妻精品| 成年人免费看在线视频| 日韩三级电影华丽的外出| 美女少妇亚洲精选av| 97年大学生大白天操逼| 色综合色综合色综合色| 国产午夜福利av导航| 天天干夜夜操啊啊啊| caoporn蜜桃视频| 美女福利视频网址导航| 青青草成人福利电影| 亚洲一区二区三区久久午夜 | 国产a级毛久久久久精品| 狠狠操操操操操操操操操| 成人高潮aa毛片免费| 人妻久久久精品69系列| 青青青视频自偷自拍38碰|