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

最新評論

日本熟妇一区二区x x| 91大神福利视频网| 极品丝袜一区二区三区| 亚洲福利精品福利精品福利| 好了av中文字幕在线| 亚洲 欧美 自拍 偷拍 在线| 日本性感美女视频网站| 无码中文字幕波多野不卡| 日本少妇人妻xxxxxhd| gay gay男男瑟瑟在线网站| 孕妇奶水仑乱A级毛片免费看| 中文字幕 亚洲av| 日本av在线一区二区三区| 激情人妻校园春色亚洲欧美| 久久这里只有精品热视频| 久久久久久性虐视频| 久久久精品精品视频视频| 99av国产精品欲麻豆| 9l人妻人人爽人人爽| 人妻丝袜诱惑我操她视频| 91麻豆精品久久久久| japanese日本熟妇另类| 春色激情网欧美成人| 成人免费做爰高潮视频| 亚洲乱码中文字幕在线| 最新国产亚洲精品中文在线| 欧美精品一二三视频| 人妻爱爱 中文字幕| 国产1区,2区,3区| 国产超码片内射在线| 天天日天天鲁天天操| 亚洲一区久久免费视频| 国产欧美日韩在线观看不卡| 成人国产激情自拍三区| 男女之间激情网午夜在线| 午夜av一区二区三区| 无码精品一区二区三区人| 中文字幕日韩人妻在线三区| 天天草天天色天天干| 国产午夜亚洲精品麻豆| 大学生A级毛片免费视频| 亚洲区美熟妇久久久久| 精品国产在线手机在线| 国产实拍勾搭女技师av在线| 1000小视频在线| 国产白嫩美女一区二区| av网站色偷偷婷婷网男人的天堂| 人妻自拍视频中国大陆| 国产精彩对白一区二区三区| 天天操夜夜骑日日摸| 欧美亚洲中文字幕一区二区三区| 日本a级视频老女人| 三级av中文字幕在线观看| 大胆亚洲av日韩av| 国产精品久久久久久久精品视频| 日本午夜久久女同精女女| 精品日产卡一卡二卡国色天香| 亚洲精品在线资源站| 日韩在线中文字幕色| 国产精品系列在线观看一区二区| 亚洲综合图片20p| 五十路息与子猛烈交尾视频 | 9国产精品久久久久老师| 成人福利视频免费在线| 成人免费做爰高潮视频| 国产日韩欧美视频在线导航| 性欧美激情久久久久久久| 中文字幕综合一区二区| 欧美偷拍自拍色图片| 日韩加勒比东京热二区| 日韩精品电影亚洲一区| 亚洲无码一区在线影院| 免费黄页网站4188| 超碰在线中文字幕一区二区| 91精品综合久久久久3d动漫| 麻豆精品成人免费视频| 天天操,天天干,天天射| 亚洲天堂第一页中文字幕| 一区二区在线观看少妇| 亚洲国产在线精品国偷产拍| 欧美日韩在线精品一区二区三| 男人天堂色男人av| av日韩在线免费播放| 中文字幕日韩无敌亚洲精品| 97香蕉碰碰人妻国产樱花| 国产精品黄片免费在线观看| 精品一区二区三四区| 99精品视频在线观看婷婷| 黄色无码鸡吧操逼视频| av视屏免费在线播放| 孕妇奶水仑乱A级毛片免费看| 毛茸茸的大外阴中国视频| tube69日本少妇| av大全在线播放免费| 精品国产在线手机在线| 男生用鸡操女生视频动漫| wwwxxx一级黄色片| 国产精品国产三级麻豆| 亚洲av无码成人精品区辽| 人妻熟女在线一区二区| 日本欧美视频在线观看三区| 亚洲一区二区三区精品乱码| 青青青青草手机在线视频免费看| 欧美视频不卡一区四区| 久草视频 久草视频2| 亚洲天堂第一页中文字幕| 岛国免费大片在线观看| 亚洲欧美激情中文字幕| 五月天色婷婷在线观看视频免费| 成人国产小视频在线观看| 午夜青青草原网在线观看| 欧美精品黑人性xxxx| 国产熟妇一区二区三区av| 亚洲激情av一区二区| 免费一级黄色av网站| sspd152中文字幕在线| 免费男阳茎伸入女阳道视频| 亚洲欧美激情中文字幕| 无码国产精品一区二区高潮久久4| 三级av中文字幕在线观看| 男人的天堂在线黄色| 好吊视频—区二区三区| 最新激情中文字幕视频| 男人的天堂在线黄色| 青青尤物在线观看视频网站| 91大神福利视频网| 四川乱子伦视频国产vip| 久久久久久久亚洲午夜综合福利 | 国产精品系列在线观看一区二区 | 亚洲天堂有码中文字幕视频| 77久久久久国产精产品| 青草亚洲视频在线观看| sspd152中文字幕在线| 国产一区av澳门在线观看| 黄色男人的天堂视频| 插逼视频双插洞国产操逼插洞| 蜜臀成人av在线播放| 色av色婷婷人妻久久久精品高清| 一级黄片大鸡巴插入美女| 美女视频福利免费看| 久碰精品少妇中文字幕av| 欧美综合婷婷欧美综合| 天天色天天操天天舔| 特级欧美插插插插插bbbbb| 国产综合高清在线观看| 人人妻人人爱人人草| 精产国品久久一二三产区区别| 美女吃鸡巴操逼高潮视频| 中文字幕人妻一区二区视频| 中文字幕一区二区自拍| 亚洲成人av一区在线| 日本五十路熟新垣里子| 超碰97人人做人人爱| 中文字幕av第1页中文字幕| 青春草视频在线免费播放| 国产精品三级三级三级| 曰本无码人妻丰满熟妇啪啪| 国产性生活中老年人视频网站| 黄色男人的天堂视频| 精品国产在线手机在线| 亚洲福利天堂久久久久久| 黄片大全在线观看观看| 精品一区二区三区三区88| 国产成人精品福利短视频| 成人乱码一区二区三区av| 久久久久久性虐视频| 男人的天堂av日韩亚洲| 久久久久久cao我的性感人妻 | 日韩精品中文字幕在线| 国产97视频在线精品| free性日本少妇| 久久一区二区三区人妻欧美| 欧美亚洲一二三区蜜臀| 日本又色又爽又黄又粗| 日韩影片一区二区三区不卡免费| 亚洲 欧美 自拍 偷拍 在线| 1000小视频在线| 亚洲老熟妇日本老妇| 中文字幕在线乱码一区二区| 亚洲精品高清自拍av | 国产不卡av在线免费| 天天干天天爱天天色| 亚洲成人免费看电影| 久久久麻豆精亚洲av麻花| 久久综合老鸭窝色综合久久| 日本美女性生活一级片| 女同互舔一区二区三区| 五月色婷婷综合开心网4438| 蜜桃精品久久久一区二区| jiuse91九色视频| 亚洲图片偷拍自拍区| 久久精品美女免费视频| 亚洲精品ww久久久久久| 91免费福利网91麻豆国产精品| 一区二区熟女人妻视频| 2022国产综合在线干| 亚洲高清一区二区三区视频在线| 久久这里只有精品热视频| 国产在线观看免费人成短视频| 黄页网视频在线免费观看| jiujiure精品视频在线| 国产又大又黄免费观看| 日韩欧美国产一区不卡| 鸡巴操逼一级黄色气| 97瑟瑟超碰在线香蕉| av在线观看网址av| 黄色录像鸡巴插进去| 夜夜嗨av蜜臀av| 天天干狠狠干天天操| 亚洲免费福利一区二区三区| 午夜福利资源综合激情午夜福利资 | 日韩国产乱码中文字幕| 天天操夜夜骑日日摸| 久久精品亚洲国产av香蕉| 国产高清在线观看1区2区| 天天干天天操天天玩天天射| 国产成人精品亚洲男人的天堂| 成人区人妻精品一区二视频| 国产福利小视频大全| 夜夜骑夜夜操夜夜奸| 亚洲国产40页第21页| av网址在线播放大全| 亚洲综合一区二区精品久久| 亚洲一区二区人妻av| 硬鸡巴动态操女人逼视频| 欧美天堂av无线av欧美| 亚洲免费国产在线日韩| 18禁美女黄网站色大片下载| 国产三级片久久久久久久| 欧美激情电影免费在线| 天天射夜夜操狠狠干| 亚洲精品午夜aaa久久| 午夜精品福利一区二区三区p| 亚欧在线视频你懂的| 国产在线拍揄自揄视频网站| 91av精品视频在线| 国产又色又刺激在线视频 | 亚洲图片偷拍自拍区| 精品黑人巨大在线一区| 国产在线自在拍91国语自产精品| 天天摸天天亲天天舔天天操天天爽| 久草视频 久草视频2| 中文字幕在线欧美精品| 1000小视频在线| 2022天天干天天操| 99精品国产aⅴ在线观看| 播放日本一区二区三区电影| 一区二区三区蜜臀在线| 伊人综合免费在线视频| 91she九色精品国产| 午夜激情久久不卡一区二区 | 精品乱子伦一区二区三区免费播| 三级等保密码要求条款| 国产精品国产三级国产精东| 熟女人妻在线观看视频| 欧美精产国品一二三区| 大鸡八强奸视频在线观看| 亚洲欧美国产麻豆综合| 日本后入视频在线观看| 中文字幕之无码色多多| 天天操天天插天天色| 91久久精品色伊人6882| 国产品国产三级国产普通话三级| 国产在线一区二区三区麻酥酥| 天美传媒mv视频在线观看| 成人影片高清在线观看| 亚洲一区av中文字幕在线观看| 欲乱人妻少妇在线视频裸| 成人国产影院在线观看| 啊用力插好舒服视频| 人人超碰国字幕观看97| 免费费一级特黄真人片 | 天天日天天干天天爱| 日本少妇人妻xxxxxhd| 亚洲欧美日韩视频免费观看| 在线观看的a站 最新| 中文字幕国产专区欧美激情| 国产午夜亚洲精品不卡在线观看| 欧美精品免费aaaaaa| 人妻少妇中文有码精品| 婷婷午夜国产精品久久久| 欧美天堂av无线av欧美| 国产精品一区二区三区蜜臀av| 大胆亚洲av日韩av| 欧美黑人与人妻精品| 国产精品自拍视频大全| 偷拍自拍 中文字幕| 日本av在线一区二区三区| 91国内视频在线观看| 亚洲人妻av毛片在线| 国产成人小视频在线观看无遮挡| 午夜精彩视频免费一区| 五十路熟女人妻一区二| 一区二区三区久久久91| 全国亚洲男人的天堂| 国产熟妇一区二区三区av| 亚洲精品国偷自产在线观看蜜桃| 蜜臀av久久久久久久| 亚洲高清国产拍青青草原| 九一传媒制片厂视频在线免费观看| 一区二区三区四区视频在线播放| 国产一级精品综合av| 亚洲在线免费h观看网站| 最新91九色国产在线观看| 色秀欧美视频第一页| 精品成人午夜免费看| 精内国产乱码久久久久久| 人人妻人人爱人人草| 2025年人妻中文字幕乱码在线| 把腿张开让我插进去视频| 国产性生活中老年人视频网站| 久精品人妻一区二区三区| 清纯美女在线观看国产| 18禁美女无遮挡免费| 色婷婷久久久久swag精品| 天天操天天操天天碰| 国产精品自拍视频大全| 色爱av一区二区三区| 人妻少妇亚洲一区二区| 国产精品自拍在线视频| 国产福利小视频免费观看| 午夜福利人人妻人人澡人人爽| 又黄又刺激的午夜小视频| 欧洲精品第一页欧洲精品亚洲| 国产揄拍高清国内精品对白| 天天想要天天操天天干| 好吊操视频这里只有精品| 亚洲av琪琪男人的天堂| 99av国产精品欲麻豆| 欧美日本国产自视大全| 免费大片在线观看视频网站| 精品一区二区三区午夜| 欧美一区二区三区啪啪同性| 老鸭窝日韩精品视频观看| 白白操白白色在线免费视频| 在线视频这里只有精品自拍| 999九九久久久精品| 国产污污污污网站在线| 婷婷六月天中文字幕| 四川五十路熟女av| 4个黑人操素人视频网站精品91| 成人蜜桃美臀九一一区二区三区 | 在线国产中文字幕视频| 日本熟女50视频免费| 自拍偷拍日韩欧美一区二区| 丰满少妇人妻xxxxx| 亚洲欧美一区二区三区电影| 黄色录像鸡巴插进去| 青草亚洲视频在线观看| 2020久久躁狠狠躁夜夜躁 | 只有精品亚洲视频在线观看| 又色又爽又黄的美女裸体| 操的小逼流水的文章| 亚洲精品乱码久久久本| 操的小逼流水的文章| 青青青爽视频在线播放| 国产在线91观看免费观看| 大鸡吧插入女阴道黄色片 | 久久久制服丝袜中文字幕| 亚洲激情,偷拍视频| 国产中文字幕四区在线观看| 国产熟妇人妻ⅹxxxx麻豆| 日本特级片中文字幕| 久草视频中文字幕在线观看| 五十路人妻熟女av一区二区| 亚洲精品成人网久久久久久小说| 粉嫩小穴流水视频在线观看| 亚欧在线视频你懂的| 欧美视频不卡一区四区| 少妇人妻二三区视频| 毛片av在线免费看| 丁香花免费在线观看中文字幕| 成人动漫大肉棒插进去视频| 亚洲一区二区三区精品乱码| 亚洲av日韩精品久久久| 老师啊太大了啊啊啊尻视频| 丁香花免费在线观看中文字幕| 中文字幕日韩91人妻在线| 国产精品探花熟女在线观看| 欧美成一区二区三区四区| 蜜桃久久久久久久人妻| 97精品成人一区二区三区 | 任你操视频免费在线观看| 国产chinesehd精品麻豆| 亚洲精品中文字幕下载| 成人av天堂丝袜在线观看| 在线观看国产免费麻豆| 91天堂天天日天天操| 久久综合老鸭窝色综合久久| 在线亚洲天堂色播av电影| 亚洲日产av一区二区在线| 加勒比视频在线免费观看| 一级黄片大鸡巴插入美女| 人人妻人人爽人人添夜| japanese日本熟妇另类| 亚洲一级av无码一级久久精品| 亚洲成人av在线一区二区| 成年午夜免费无码区| 日韩精品激情在线观看| 男人的天堂av日韩亚洲| 黄色视频在线观看高清无码 | 精品国产污污免费网站入口自| 蜜桃精品久久久一区二区| 天天操夜夜骑日日摸| 视频 国产 精品 熟女 | 亚洲视频在线视频看视频在线| 精品一区二区亚洲欧美| 欧美精产国品一二三产品区别大吗| 亚洲综合另类精品小说| 99精品免费观看视频| 夏目彩春在线中文字幕| 国产精品国产三级国产精东| 青青青国产免费视频| 亚洲1卡2卡三卡4卡在线观看| 婷婷激情四射在线观看视频| 日韩欧美制服诱惑一区在线| 亚洲一区av中文字幕在线观看| 免费在线播放a级片| 人妻少妇亚洲精品中文字幕| 高潮视频在线快速观看国家快速| 40道精品招牌菜特色| 成人网18免费视频版国产| 欧美精产国品一二三产品区别大吗| 亚洲成高清a人片在线观看| 人妻少妇精品久久久久久| 99精品视频在线观看婷婷| 美洲精品一二三产区区别| 欧美香蕉人妻精品一区二区| 福利一二三在线视频观看| 最新国产精品网址在线观看| 天堂av狠狠操蜜桃| 春色激情网欧美成人| 岛国黄色大片在线观看| 91香蕉成人app下载| 大胆亚洲av日韩av| 动色av一区二区三区| 精品视频一区二区三区四区五区 | 熟女人妻三十路四十路人妻斩| 人人超碰国字幕观看97| 红杏久久av人妻一区| 欧美80老妇人性视频| 黄色录像鸡巴插进去| 青青青aaaa免费| av天堂中文字幕最新| 岛国av高清在线成人在线| 97精品成人一区二区三区 | 在线观看免费岛国av| 亚洲av人人澡人人爽人人爱| 欧美区一区二区三视频| 大鸡吧插逼逼视频免费看| 在线免费观看国产精品黄色| 五十路熟女av天堂| 91国产在线视频免费观看| 护士小嫩嫩又紧又爽20p| 国产一区二区视频观看| 亚洲av自拍天堂网| 91高清成人在线视频| 2021天天色天天干| 午夜青青草原网在线观看| 亚洲 人妻 激情 中文| 国产乱子伦精品视频潮优女| 人人妻人人澡欧美91精品| 日本少妇的秘密免费视频| 蜜桃视频17c在线一区二区| 果冻传媒av一区二区三区| 日本一区二区三区免费小视频| 人人妻人人爽人人澡人人精品| 午夜福利人人妻人人澡人人爽| 日本最新一二三区不卡在线 | 国产黄色大片在线免费播放| 亚洲一区二区三区偷拍女厕91| 中文字幕在线一区精品| 亚洲精品国偷自产在线观看蜜桃| 中文字幕一区二 区二三区四区| 91一区精品在线观看| 三级等保密码要求条款| 国产av福利网址大全| 国产午夜激情福利小视频在线| 这里只有精品双飞在线播放| 日韩欧美在线观看不卡一区二区| 干逼又爽又黄又免费的视频| 91九色国产porny蝌蚪| 亚洲欧美在线视频第一页| 91精品免费久久久久久| 亚洲熟女综合色一区二区三区四区| 97色视频在线观看| 亚洲国产欧美一区二区三区久久| 久久久久久久久久久久久97| 欧美日韩v中文在线| 午夜激情久久不卡一区二区| 在线免费观看99视频| aiss午夜免费视频| 视频二区在线视频观看| 午夜精品一区二区三区4| 欧美黄片精彩在线免费观看| 成年人的在线免费视频| 岛国免费大片在线观看 | 57pao国产一区二区| 日韩北条麻妃一区在线| 亚洲色偷偷综合亚洲AV伊人| 中文字幕网站你懂的| 红杏久久av人妻一区| 91色网站免费在线观看| 97超碰人人搞人人| 亚洲少妇人妻无码精品| 精品国产在线手机在线| 日本一区美女福利视频| 日本免费午夜视频网站| 国产夫妻视频在线观看免费| 欧美亚洲中文字幕一区二区三区| 人妻丝袜精品中文字幕| 久草视频在线看免费| 91九色国产熟女一区二区| 国产亚洲欧美另类在线观看| 美女张开腿让男生操在线看| av久久精品北条麻妃av观看| 日日操综合成人av| 中国产一级黄片免费视频播放| 亚洲人一区二区中文字幕| 91人妻人人做人人爽在线| 日本在线不卡免费视频| 888欧美视频在线| 日本中文字幕一二区视频| 亚洲精品三级av在线免费观看| 91亚洲手机在线视频播放| 2018最新中文字幕在线观看| 在线免费观看日本片| 一区二区三区麻豆福利视频| 青青草亚洲国产精品视频| 91九色国产熟女一区二区| 天天操天天插天天色| 午夜美女少妇福利视频| 伊人开心婷婷国产av| 日韩欧美中文国产在线| 亚洲一区二区三区久久受| 成年人啪啪视频在线观看| 极品粉嫩小泬白浆20p主播| 一区二区三区在线视频福利| 日韩成人综艺在线播放| 99热这里只有国产精品6| 91传媒一区二区三区| 国产精品国产三级麻豆| 91精品综合久久久久3d动漫| 国内自拍第一页在线观看| 国产97在线视频观看| av在线免费中文字幕| 在线视频免费观看网| 国产janese在线播放| 亚洲高清国产拍青青草原| 黑人变态深video特大巨大| 亚洲欧美激情国产综合久久久| 日本五十路熟新垣里子| 久久久久久国产精品| 日本熟妇色熟妇在线观看| 一级黄色av在线观看| 成人网18免费视频版国产| 久久一区二区三区人妻欧美| 国产精品一区二区三区蜜臀av| 欧美区一区二区三视频| 亚洲国产40页第21页| 天天干天天操天天爽天天摸| 婷婷五月亚洲综合在线| 二区中出在线观看老师| 99热色原网这里只有精品| 宅男噜噜噜666免费观看| 久久丁香花五月天色婷婷| 亚洲精品无码久久久久不卡 | 日本又色又爽又黄又粗| 色综合久久久久久久久中文| 国内资源最丰富的网站| 年轻的人妻被夫上司侵犯| 在线播放 日韩 av| jul—619中文字幕在线| 亚洲精品国偷自产在线观看蜜桃| 在线观看黄色成年人网站| 91人妻精品久久久久久久网站| 人妻少妇中文有码精品| 久久久久久9999久久久久| 日韩国产乱码中文字幕| 国产自拍黄片在线观看| 青青伊人一精品视频| 视频一区 二区 三区 综合| 91九色porny蝌蚪国产成人| 蜜桃精品久久久一区二区| 亚洲午夜精品小视频| 黄色三级网站免费下载| 日本免费视频午夜福利视频| 经典av尤物一区二区| 日本午夜爽爽爽爽爽视频在线观看 | 亚洲麻豆一区二区三区| 伊人开心婷婷国产av| huangse网站在线观看| 午夜频道成人在线91| 国产九色91在线观看精品| av日韩在线观看大全| 天天干天天啪天天舔| 亚洲日本一区二区久久久精品| 亚洲国产精品免费在线观看| 91天堂天天日天天操| 久久久久久99国产精品| 亚洲av日韩精品久久久| 制丝袜业一区二区三区| 激情伦理欧美日韩中文字幕| 亚洲 自拍 色综合图| 欧美特色aaa大片| 在线观看视频网站麻豆| 操操网操操伊剧情片中文字幕网| 丝袜肉丝一区二区三区四区在线| 午夜蜜桃一区二区三区| 久久精品美女免费视频| 国产精品视频资源在线播放| 亚洲av日韩精品久久久| 视频在线亚洲一区二区| 成人免费毛片aaaa| 最新国产精品拍在线观看| 久精品人妻一区二区三区| 久草视频在线看免费| 国产精品伦理片一区二区| 中国熟女一区二区性xx| 丝袜美腿欧美另类 中文字幕| 国产97视频在线精品| 亚洲国产精品美女在线观看| 91一区精品在线观看| 午夜毛片不卡免费观看视频| 岛国毛片视频免费在线观看| 日韩精品中文字幕福利| 大香蕉大香蕉在线看| 亚洲人妻国产精品综合| 日韩亚洲高清在线观看| 天天日天天干天天插舔舔| 特大黑人巨大xxxx| 午夜大尺度无码福利视频| 中文字幕在线第一页成人| 亚洲在线免费h观看网站| 欧美女同性恋免费a| 精品一区二区亚洲欧美| 亚洲精品乱码久久久本| 中文字幕欧美日韩射射一| 五十路熟女人妻一区二| 欧美精品一区二区三区xxxx| 亚洲伊人av天堂有码在线| 国产综合高清在线观看| 9久在线视频只有精品| 女生被男生插的视频网站| 狍和女人的王色毛片| 69精品视频一区二区在线观看| 大香蕉玖玖一区2区| 97少妇精品在线观看| 亚洲在线一区二区欧美| 亚洲少妇高潮免费观看| 在线免费观看靠比视频的网站| 91综合久久亚洲综合| 久草视频在线看免费| 国产九色91在线观看精品| 激情啪啪啪啪一区二区三区| 青青伊人一精品视频| 一级黄片大鸡巴插入美女 | 蜜桃视频入口久久久| av在线观看网址av| 东京干手机福利视频| 福利视频一区二区三区筱慧| 男人的天堂一区二区在线观看| 日本阿v视频在线免费观看| 亚洲视频乱码在线观看| 在线视频国产欧美日韩| 91人妻精品久久久久久久网站 | 91精品国产麻豆国产| 天天干天天操天天爽天天摸| 欧美精品激情在线最新观看视频| 色综合天天综合网国产成人| 欧美久久一区二区伊人| 精品一线二线三线日本| 大鸡吧插逼逼视频免费看 | 欧美偷拍自拍色图片| 年轻的人妻被夫上司侵犯| 国产又粗又硬又大视频| 亚洲欧美激情国产综合久久久| 国产中文精品在线观看| 国产97视频在线精品| 亚洲精品国偷自产在线观看蜜桃| 人妻av无码专区久久绿巨人 | 欧美地区一二三专区| 99热久久这里只有精品8| 91色网站免费在线观看| 国产高清精品极品美女| 激情人妻校园春色亚洲欧美 | 久久久久久久久久久久久97| 成人av亚洲一区二区| 亚洲激情唯美亚洲激情图片| 在线视频精品你懂的| 大香蕉日本伊人中文在线| 粗大的内捧猛烈进出爽大牛汉子| 亚洲伊人色一综合网| 国产日本欧美亚洲精品视| 北条麻妃肉色丝袜视频| 日韩影片一区二区三区不卡免费| 五十路丰满人妻熟妇| 精品av久久久久久久| 黄色视频在线观看高清无码| 初美沙希中文字幕在线| 亚洲av日韩精品久久久久久hd| 亚洲天堂成人在线观看视频网站| 日本少妇高清视频xxxxx| 天天操天天弄天天射| 黄网十四区丁香社区激情五月天| 国产一区二区火爆视频| 边摸边做超爽毛片18禁色戒| 亚洲精品 日韩电影| 最近中文2019年在线看| 天天色天天操天天透| 中国熟女@视频91| 999九九久久久精品| 美女av色播在线播放| 国产chinesehd精品麻豆| 毛茸茸的大外阴中国视频| 99热这里只有国产精品6| 亚洲激情,偷拍视频| 亚洲伊人久久精品影院一美女洗澡| 久久精品国产亚洲精品166m| 国产女孩喷水在线观看| 久久久久久久精品老熟妇| 欲满人妻中文字幕在线| 色天天天天射天天舔| 欧洲亚洲欧美日韩综合| 日韩精品中文字幕播放| 97超碰免费在线视频| 99国内小视频在现欢看| 国产日韩欧美美利坚蜜臀懂色| 中文字幕日韩精品就在这里| 亚洲专区激情在线观看视频| 国产中文精品在线观看| 青青草亚洲国产精品视频| 天天干天天搞天天摸| 蜜桃专区一区二区在线观看| 天堂av狠狠操蜜桃| 伊拉克及约旦宣布关闭领空| 一色桃子人妻一区二区三区| 国产欧美精品一区二区高清| 视频一区二区三区高清在线| 国产精品污污污久久| 超碰公开大香蕉97| 亚洲1区2区3区精华液| 中英文字幕av一区| 一区二区免费高清黄色视频| 精品国产成人亚洲午夜| 成人网18免费视频版国产| 亚洲中文精品字幕在线观看| 78色精品一区二区三区| 日韩av有码中文字幕| 成人动漫大肉棒插进去视频| 啊慢点鸡巴太大了啊舒服视频| 粉嫩av蜜乳av蜜臀| 午夜频道成人在线91| 久久久久久久久久久免费女人| 精品欧美一区二区vr在线观看 | 国产一区二区火爆视频| 任你操任你干精品在线视频| 亚洲熟色妇av日韩熟色妇在线| 亚洲高清免费在线观看视频| 中文字幕熟女人妻久久久| 欧美精品免费aaaaaa| 亚洲福利精品福利精品福利| 青青青青青手机视频| 午夜久久久久久久99| 91精品国产麻豆国产| 视频一区二区在线免费播放| 亚洲av成人网在线观看| 色呦呦视频在线观看视频| 亚洲高清视频在线不卡| 亚洲中文精品人人免费| 任你操任你干精品在线视频| 精品91高清在线观看 | 中文字幕 亚洲av| 亚洲国产精品免费在线观看| 都市家庭人妻激情自拍视频| 超碰在线中文字幕一区二区| 欧美亚洲一二三区蜜臀| 亚洲国产第一页在线观看| 一区二区三区久久久91| 自拍偷拍一区二区三区图片 | 2022国产综合在线干| 日韩欧美国产一区ab| 久久精品美女免费视频| 亚洲精品国品乱码久久久久| 国产片免费观看在线观看| 性感美女高潮视频久久久| 这里有精品成人国产99| 欧美日韩精品永久免费网址| 日韩av有码一区二区三区4 | 手机看片福利盒子日韩在线播放| 亚洲一区二区激情在线| 欧美激情电影免费在线| 青青青青青青青青青国产精品视频| 中文字幕欧美日韩射射一| 美味人妻2在线播放| 国产福利小视频二区| 亚洲精品 日韩电影| 99热99这里精品6国产| 欧美精品伦理三区四区| 日本真人性生活视频免费看| 女蜜桃臀紧身瑜伽裤| 亚洲av色香蕉一区二区三区| 国产精品黄页网站视频| 亚洲综合一区二区精品久久| 亚洲最大黄了色网站| 国产麻豆国语对白露脸剧情| 香蕉片在线观看av| 欧美黄片精彩在线免费观看| 真实国模和老外性视频| 亚洲高清免费在线观看视频| 亚洲美女自偷自拍11页| 91试看福利一分钟| 日韩av熟妇在线观看| 性感美女高潮视频久久久| 喷水视频在线观看这里只有精品| 二区中出在线观看老师| 黄色成年网站午夜在线观看| 人妻久久无码中文成人| 日韩二区视频一线天婷婷五| 精品久久久久久久久久中文蒉| 激情五月婷婷免费视频| 欧美激情精品在线观看| 久久久久久9999久久久久| 欧美怡红院视频在线观看| 国产成人一区二区三区电影网站 | 久久精品国产999| 精品一区二区亚洲欧美| 51国产成人精品视频| 日韩亚洲高清在线观看| 一区二区三区的久久的蜜桃的视频| 欧美精品亚洲精品日韩在线| 大骚逼91抽插出水视频| 国产精品熟女久久久久浪潮| 99精品国产aⅴ在线观看 | 97国产在线观看高清| 后入美女人妻高清在线| 精品视频国产在线观看| 亚洲视频在线观看高清| 性感美女诱惑福利视频| 国产一区二区在线欧美| 2022天天干天天操| 中国黄色av一级片| 夜女神免费福利视频| 日韩中文字幕精品淫| 欧美一区二区三区在线资源| 熟女妇女老妇一二三区| 男人的天堂在线黄色| 欧美成人综合色在线噜噜| 91啪国自产中文字幕在线| 免费在线看的黄网站| 在线观看视频 你懂的| 久久久久久久亚洲午夜综合福利| 18禁美女羞羞免费网站| 精品美女久久久久久| 亚洲精品在线资源站| 青青操免费日综合视频观看| 免费一级特黄特色大片在线观看| 人妻3p真实偷拍一二区| 亚洲一区自拍高清免费视频| 午夜在线观看岛国av,com| 九色精品视频在线播放| 国产精品一区二区久久久av| 国产成人午夜精品福利| 97超碰人人搞人人| 日韩精品中文字幕福利| 国产极品精品免费视频| 国产V亚洲V天堂无码欠欠| 视频久久久久久久人妻| 大尺度激情四射网站| 国产福利在线视频一区| 中文乱理伦片在线观看| 亚洲综合一区成人在线| 中文字日产幕乱六区蜜桃| 视频一区二区综合精品| 婷婷综合亚洲爱久久| 亚洲av无码成人精品区辽| 久久这里只有精彩视频免费| 福利在线视频网址导航| 中文字幕网站你懂的| 欧美精产国品一二三区| 三上悠亚和黑人665番号| 一区二区三区久久中文字幕| 另类av十亚洲av| 熟女在线视频一区二区三区| 80电影天堂网官网| 自拍 日韩 欧美激情| 精品一区二区三区三区88| 熟女妇女老妇一二三区| 国产亚洲精品欧洲在线观看| 婷婷色国产黑丝少妇勾搭AV | 国产高清精品一区二区三区| 亚洲精品精品国产综合| 欧洲欧美日韩国产在线| 亚洲色偷偷综合亚洲AV伊人| 日韩午夜福利精品试看| 99久久中文字幕一本人| 久久久久久9999久久久久| 无码精品一区二区三区人| 同居了嫂子在线播高清中文| 韩国女主播精品视频网站| 日本裸体熟妇区二区欧美| japanese日本熟妇另类| 国内自拍第一页在线观看| 色偷偷伊人大杳蕉综合网| 清纯美女在线观看国产| 都市激情校园春色狠狠| 亚洲第17页国产精品| 在线免费观看黄页视频| 秋霞午夜av福利经典影视| 成人30分钟免费视频| 亚洲视频在线观看高清| 天天日天天天天天天天天天天 | 综合页自拍视频在线播放| 亚洲成人国产av在线| 久久美欧人妻少妇一区二区三区| 久久h视频在线观看| 2021国产一区二区| 中文字幕高清在线免费播放| 亚洲一区二区三区在线高清| 日本美女性生活一级片| 日日摸夜夜添夜夜添毛片性色av| 日韩a级黄色小视频| 亚洲天堂成人在线观看视频网站| 亚洲一区二区三区uij| 欧美少妇性一区二区三区| 2o22av在线视频| 蜜臀av久久久久久久| 黄色成人在线中文字幕| 在线观看免费岛国av| 沙月文乃人妻侵犯中文字幕在线| 97成人免费在线观看网站| 粉嫩av蜜乳av蜜臀| 性欧美日本大妈母与子| 亚洲男人让女人爽的视频| 国产大学生援交正在播放| 在线观看国产网站资源| 丝袜肉丝一区二区三区四区在线 | 第一福利视频在线观看| 日本少妇高清视频xxxxx| 男人的天堂av日韩亚洲| 亚洲一区二区三区uij| 国产精品中文av在线播放| 不戴胸罩引我诱的隔壁的人妻| 青青青青草手机在线视频免费看| 中文字幕一区二区自拍| 5528327男人天堂| 中文字幕一区二区三区蜜月| 国产精品视频一区在线播放| 精彩视频99免费在线| 国产激情av网站在线观看| 午夜精品福利91av| 欧美乱妇无乱码一区二区| 扒开腿挺进肉嫩小18禁视频| 国产午夜男女爽爽爽爽爽视频| 精品久久久久久久久久久99| 国产chinesehd精品麻豆| 日韩av大胆在线观看| 精品久久久久久久久久久a√国产| 国产欧美精品免费观看视频| 97青青青手机在线视频| 亚洲av黄色在线网站| 午夜精品久久久久麻豆影视| 天天日夜夜操天天摸| 欧美在线偷拍视频免费看| 视频二区在线视频观看| 国产精品国产三级麻豆| 美女吃鸡巴操逼高潮视频| 国内资源最丰富的网站| av男人天堂狠狠干| 一区二区三区激情在线| 亚洲av人人澡人人爽人人爱| 91在线视频在线精品3| 免费在线观看污污视频网站| 97人人妻人人澡人人爽人人精品| 亚洲av自拍偷拍综合| 天天想要天天操天天干| 免费黄页网站4188| 熟女妇女老妇一二三区| 中文字幕在线一区精品| 极品性荡少妇一区二区色欲| 色婷婷精品大在线观看| 日本五十路熟新垣里子| 欧美男人大鸡吧插女人视频| 激情色图一区二区三区| 日日日日日日日日夜夜夜夜夜夜| 青娱乐极品视频青青草| 亚洲 欧美 精品 激情 偷拍| 亚洲另类伦春色综合小| 亚洲精品欧美日韩在线播放| 2017亚洲男人天堂| 亚洲 中文 自拍 另类 欧美| 国产97视频在线精品| 亚洲一区二区三区精品乱码| 丰满的继坶3中文在线观看| 天天插天天色天天日| 99热这里只有国产精品6| 熟女少妇激情五十路| 国产又粗又猛又爽又黄的视频在线| 欧美女同性恋免费a| www天堂在线久久| 高清一区二区欧美系列| 99热国产精品666| 狠狠躁狠狠爱网站视频| 午夜精品一区二区三区更新| 深夜男人福利在线观看| 后入美女人妻高清在线| 91亚洲精品干熟女蜜桃频道| 欧美一区二区中文字幕电影| 51国产偷自视频在线播放| 免费观看理论片完整版| 大鸡巴插入美女黑黑的阴毛| 亚洲精品欧美日韩在线播放| 国内资源最丰富的网站| 2022国产精品视频| 天天干天天操天天爽天天摸| 免费在线黄色观看网站| 888亚洲欧美国产va在线播放| 亚洲1区2区3区精华液| 国产精品中文av在线播放| 日韩av免费观看一区| 国产妇女自拍区在线观看| 91在线视频在线精品3| 久草电影免费在线观看| 老司机在线精品福利视频| 亚洲精品色在线观看视频| 成人免费毛片aaaa| 亚洲精品福利网站图片| 免费在线看的黄网站| 亚洲码av无色中文| 91精品国产高清自在线看香蕉网| 精品一区二区三区在线观看| 经典亚洲伊人第一页| 国产在线拍揄自揄视频网站| 日韩写真福利视频在线观看| 国产又色又刺激在线视频| 中文字幕中文字幕 亚洲国产| 99精品国产免费久久| 北条麻妃高跟丝袜啪啪| 国产普通话插插视频| 天天色天天爱天天爽| 丁香花免费在线观看中文字幕| 特一级特级黄色网片| 日本少妇高清视频xxxxx | 亚洲午夜伦理视频在线| 动漫美女的小穴视频| 天天日天天舔天天射进去| 激情色图一区二区三区| 亚洲免费成人a v| 亚洲推理片免费看网站| 青青青艹视频在线观看| 青青青视频手机在线观看| 国产日本欧美亚洲精品视| 在线不卡成人黄色精品| 中文字幕在线免费第一页| 天天日天天干天天搡| 2022天天干天天操| 成人性黑人一级av| 91超碰青青中文字幕| 超级碰碰在线视频免费观看| 午夜精品在线视频一区| 免费在线看的黄片视频| 丝袜肉丝一区二区三区四区在线看| 午夜福利资源综合激情午夜福利资| 天堂av在线最新版在线| 不卡一区一区三区在线| jiujiure精品视频在线| 中文字幕在线永久免费播放| 一区二区熟女人妻视频| av手机免费在线观看高潮| 真实国模和老外性视频| 欧洲亚洲欧美日韩综合| 看一级特黄a大片日本片黑人| 午夜美女少妇福利视频| 一区二区三区欧美日韩高清播放| 国产福利在线视频一区| 国产在线自在拍91国语自产精品| 亚洲老熟妇日本老妇| 丰满少妇人妻xxxxx| 欧美久久久久久三级网| 亚洲国产精品久久久久蜜桃| 黄色成年网站午夜在线观看| av在线观看网址av| 直接能看的国产av| av大全在线播放免费| 欧美另类一区二区视频| 国产乱弄免费视频观看| 亚洲一区二区三区久久受| 成人av久久精品一区二区| 国产亚洲视频在线观看| 狠狠的往里顶撞h百合| 亚洲日产av一区二区在线| 91人妻精品久久久久久久网站 | 岛国青草视频在线观看| 偷拍3456eee| 色婷婷综合激情五月免费观看| 一区二区在线观看少妇| 国产精品国色综合久久| 国产福利小视频二区| 在线观看成人国产电影| 99精品视频在线观看免费播放| 亚洲欧美久久久久久久久| 欧美成人综合色在线噜噜| 影音先锋女人av噜噜色| 国产伊人免费在线播放| 一区二区视频视频视频| 亚洲1区2区3区精华液| 日本脱亚入欧是指什么| 美洲精品一二三产区区别| 黄色视频在线观看高清无码| 中文字幕日韩无敌亚洲精品| 五十路息与子猛烈交尾视频| 国产午夜亚洲精品麻豆| 一区二区三区欧美日韩高清播放| 中文字幕高清资源站| 一级黄片大鸡巴插入美女| 97a片免费在线观看| 老司机你懂得福利视频| 日本一二三区不卡无| 青青青青视频在线播放| 中文字幕人妻一区二区视频| 人妻熟女在线一区二区| 亚洲av无硬久久精品蜜桃| 又色又爽又黄又刺激av网站| 日韩精品啪啪视频一道免费| 国产清纯美女al在线| 在线观看黄色成年人网站| 中国熟女一区二区性xx| 在线播放一区二区三区Av无码| 婷婷久久久久深爱网| 综合色区亚洲熟妇shxstz| 日本黄色三级高清视频| 毛片av在线免费看| 久久久久久久精品老熟妇| 天天射夜夜操综合网| 欧美一区二区三区高清不卡tv| 国产一区二区火爆视频| 香港一级特黄大片在线播放| 国产成人精品一区在线观看| 亚洲精品无码久久久久不卡| 亚洲成人激情视频免费观看了 | 亚洲va天堂va国产va久| 日韩av免费观看一区| 六月婷婷激情一区二区三区| 直接能看的国产av| 99热国产精品666| 精品国产乱码一区二区三区乱| 亚洲自拍偷拍综合色| 色97视频在线播放| 极品粉嫩小泬白浆20p主播| 老司机免费视频网站在线看| 在线网站你懂得老司机| 国产日本精品久久久久久久| 人妻丝袜榨强中文字幕| 欧美激情电影免费在线| 熟女妇女老妇一二三区| av破解版在线观看| 亚洲欧美激情人妻偷拍| 丝袜肉丝一区二区三区四区在线| 1024久久国产精品| 热久久只有这里有精品| 国产麻豆乱子伦午夜视频观看| 自拍偷拍 国产资源| 亚洲午夜电影之麻豆| 欧美一区二区三区在线资源| 大学生A级毛片免费视频| 午夜dv内射一区区| 国产欧美日韩第三页| 97超碰最新免费在线观看| 五十路息与子猛烈交尾视频| 果冻传媒av一区二区三区| 一区二区三区在线视频福利| 国产精品久久久久国产三级试频 | 自拍偷区二区三区麻豆| 欧美精产国品一二三产品价格| 欧美精品 日韩国产| 伊人成人在线综合网| 成人激情文学网人妻| 99精品免费观看视频| 天天躁日日躁狠狠躁躁欧美av| 午夜久久香蕉电影网| 国产午夜福利av导航| 欧美视频不卡一区四区| 1000部国产精品成人观看视频| 密臀av一区在线观看| 亚洲av一妻不如妾| 日韩熟女系列一区二区三区| 中文字幕亚洲中文字幕| 9色在线视频免费观看| 久久亚洲天堂中文对白| 欧美日韩亚洲国产无线码| 人妻另类专区欧美制服| 久久美欧人妻少妇一区二区三区| 国产av福利网址大全| 在线观看av观看av| 激情图片日韩欧美人妻| 成人在线欧美日韩国产| 久久亚洲天堂中文对白| 免费一级黄色av网站| 黑人大几巴狂插日本少妇| 精品国产亚洲av一淫| 在线视频这里只有精品自拍| 伊人综合aⅴ在线网| 骚逼被大屌狂草视频免费看| 免费一级特黄特色大片在线观看| 播放日本一区二区三区电影| 日本黄在免费看视频| 欧美黄片精彩在线免费观看| 国产福利小视频大全| 精品国产高潮中文字幕| 欧美精品中文字幕久久二区| 国产黑丝高跟鞋视频在线播放| 日本少妇人妻xxxxx18| 久草视频在线免播放| 免费看国产又粗又猛又爽又黄视频 | 最新97国产在线视频| 精品欧美一区二区vr在线观看| 成人影片高清在线观看 | 久久h视频在线观看| 欧美亚洲牲夜夜综合久久| 四川五十路熟女av| 黑人进入丰满少妇视频| 91九色porny国产蝌蚪视频| 啊慢点鸡巴太大了啊舒服视频| 精品一区二区三区三区88| 青青草成人福利电影| 国产大鸡巴大鸡巴操小骚逼小骚逼| 99国产精品窥熟女精品| 欧美一区二区三区乱码在线播放| 亚洲成人熟妇一区二区三区| 一区二区三区综合视频| 亚洲图片偷拍自拍区| 一区二区麻豆传媒黄片| 午夜福利资源综合激情午夜福利资| 91国语爽死我了不卡| 美日韩在线视频免费看| 日本少妇在线视频大香蕉在线观看| 91试看福利一分钟| 97资源人妻免费在线视频| 9l人妻人人爽人人爽| 国产伊人免费在线播放| 国产三级影院在线观看| 91国内视频在线观看| heyzo蜜桃熟女人妻| 亚洲伊人色一综合网| 这里只有精品双飞在线播放| 国产欧美日韩第三页| 91人妻精品久久久久久久网站| 人人妻人人爽人人添夜| av网址国产在线观看| 啪啪啪18禁一区二区三区| 亚洲变态另类色图天堂网| 亚洲高清国产一区二区三区| 97人妻人人澡爽人人精品| 天干天天天色天天日天天射| 男人天堂最新地址av| 美洲精品一二三产区区别| 少妇人妻久久久久视频黄片| 国产女孩喷水在线观看| 日韩一个色综合导航| 天天日天天透天天操| 夜夜骑夜夜操夜夜奸| 丝袜美腿视频诱惑亚洲无| 丰满的继坶3中文在线观看| 日韩成人免费电影二区| 直接能看的国产av| 国产亚洲四十路五十路| 狠狠躁狠狠爱网站视频| 久草视频中文字幕在线观看| 亚洲欧美久久久久久久久| 综合国产成人在线观看| 激情色图一区二区三区| 精品老妇女久久9g国产| 香蕉aⅴ一区二区三区| 国产成人自拍视频播放| 日韩精品中文字幕播放| 自拍偷拍亚洲另类色图| 福利午夜视频在线合集| 2018最新中文字幕在线观看| 77久久久久国产精产品| 中国无遮挡白丝袜二区精品| 福利视频网久久91| 好吊操视频这里只有精品| 亚洲 中文 自拍 另类 欧美| 亚洲一区二区人妻av| 成人福利视频免费在线| 人人超碰国字幕观看97| 国产1区,2区,3区| 超碰在线中文字幕一区二区| 无码精品一区二区三区人| 婷婷色国产黑丝少妇勾搭AV| 在线观看日韩激情视频| 成年人啪啪视频在线观看| 男人天堂最新地址av| 久久h视频在线观看| 岛国黄色大片在线观看| 亚洲av日韩精品久久久久久hd| 91大神福利视频网| 免费看国产av网站| 久久久精品999精品日本| 日韩激情文学在线视频| 人人在线视频一区二区| 特级欧美插插插插插bbbbb| 抽查舔水白紧大视频| nagger可以指黑人吗| 日本午夜久久女同精女女| 麻豆性色视频在线观看| 97超碰最新免费在线观看| 国产白袜脚足J棉袜在线观看| av高潮迭起在线观看| 黄色在线观看免费观看在线| 久久这里有免费精品| 国产极品美女久久久久久| 99视频精品全部15| AV天堂一区二区免费试看| 亚洲国产第一页在线观看| 欧美乱妇无乱码一区二区| 久精品人妻一区二区三区| 亚洲精品ww久久久久久| 天天夜天天日天天日| 成人av天堂丝袜在线观看| 97少妇精品在线观看| 国产精品视频资源在线播放| 三上悠亚和黑人665番号| 亚洲成人免费看电影| 91色老99久久九九爱精品| 日韩精品啪啪视频一道免费| 天天日天天干天天爱| 人妻少妇精品久久久久久| 懂色av蜜桃a v| 天天日天天干天天要| 国产福利小视频大全| 久久久久久久精品成人热| 国产麻豆剧果冻传媒app| 香蕉片在线观看av| 视频 国产 精品 熟女 | 亚洲欧美另类自拍偷拍色图| 91精品免费久久久久久| 欧美成人综合视频一区二区| 可以免费看的www视频你懂的| 亚洲国产精品久久久久久6| 青青尤物在线观看视频网站| 久久99久久99精品影院| 天天干天天日天天谢综合156| 久久久极品久久蜜桃| 巨乳人妻日下部加奈被邻居中出| 77久久久久国产精产品| 人人人妻人人澡人人| 国产日本欧美亚洲精品视| 天天干天天日天天谢综合156| 午夜精品在线视频一区| 成人免费公开视频无毒| 国产美女精品福利在线| 国产变态另类在线观看| 成人网18免费视频版国产| 日本美女成人在线视频| 青草久久视频在线观看| 国产熟妇一区二区三区av| 在线观看的黄色免费网站| 国产精品sm调教视频| 玖玖一区二区在线观看| 黄色av网站免费在线| 女生被男生插的视频网站| 亚洲国产欧美一区二区丝袜黑人| 人妻丝袜榨强中文字幕| 沈阳熟妇28厘米大战黑人| 国产又色又刺激在线视频| 亚洲1区2区3区精华液| 男人插女人视频网站| 亚洲高清视频在线不卡| 一本一本久久a久久精品综合不卡| 亚洲国产40页第21页| 国产中文字幕四区在线观看| 超黄超污网站在线观看| 免费一级特黄特色大片在线观看| 日本免费视频午夜福利视频| 在线播放国产黄色av| 欧美日韩人妻久久精品高清国产 | 欧美激情精品在线观看| 日韩美av高清在线| 中文字幕人妻av在线观看| 国产精品人妻66p| 国产熟妇乱妇熟色T区| 精品高跟鞋丝袜一区二区| 亚洲成人线上免费视频观看| av男人天堂狠狠干| 一区二区熟女人妻视频| 999热精品视频在线| 大鸡吧插逼逼视频免费看| 亚洲另类伦春色综合小| 激情伦理欧美日韩中文字幕| rct470中文字幕在线| 久久久久久久久久久久久97| 欧美亚洲偷拍自拍色图| 欧美亚洲一二三区蜜臀| 亚洲的电影一区二区三区| 人妻久久无码中文成人| 国产精品自拍在线视频| 在线网站你懂得老司机| 日本精品一区二区三区在线视频。| 国产精品系列在线观看一区二区| 日日爽天天干夜夜操| 日日夜夜精品一二三| 视频二区在线视频观看| 欧美 亚洲 另类综合| 欧美3p在线观看一区二区三区| 不卡一区一区三区在线| 伊人网中文字幕在线视频| 欧美黑人性暴力猛交喷水| 欧美怡红院视频在线观看| 一区二区三区麻豆福利视频| 中文字幕av熟女人妻| 在线观看一区二区三级| 天天操天天弄天天射| 日韩精品二区一区久久| 天天夜天天日天天日| 成年人黄色片免费网站| 最新黄色av网站在线观看| 久久久久久九九99精品| 久久久久五月天丁香社区 | 国产麻豆国语对白露脸剧情| 老司机福利精品视频在线| 天天色天天操天天透| 天天日天天日天天擦| 色97视频在线播放| 国产亚洲精品品视频在线| 91国产在线视频免费观看| 最新中文字幕免费视频| 日本少妇的秘密免费视频| 亚洲av一妻不如妾| 最新欧美一二三视频| 亚洲欧美色一区二区| 天天艹天天干天天操| 美女大bxxxx内射| 日本性感美女视频网站| 日韩三级黄色片网站| 一色桃子久久精品亚洲 | 精品国产在线手机在线| 啪啪啪啪啪啪啪免费视频| 日韩无码国产精品强奸乱伦| 制丝袜业一区二区三区| 4个黑人操素人视频网站精品91| 国产福利小视频二区| 手机看片福利盒子日韩在线播放| 欲乱人妻少妇在线视频裸| 香港一级特黄大片在线播放| 99热99re在线播放| 蜜桃专区一区二区在线观看| 99re久久这里都是精品视频| 男人的网址你懂的亚洲欧洲av| 欧美在线精品一区二区三区视频 | 黄色av网站免费在线| 青草久久视频在线观看| 精品一区二区三区午夜| 亚洲成人精品女人久久久| 成年女人免费播放视频| 青青青aaaa免费| 国产卡一卡二卡三乱码手机| 四川五十路熟女av| 欧美在线偷拍视频免费看| 男生舔女生逼逼视频| 亚洲国产中文字幕啊啊啊不行了| 大香蕉伊人中文字幕| 国产精品福利小视频a| 亚洲高清一区二区三区视频在线| 91九色porny国产蝌蚪视频| 天天日天天干天天插舔舔| 成人性黑人一级av| 色噜噜噜噜18禁止观看| 自拍偷拍亚洲另类色图| 国产女人被做到高潮免费视频| 亚洲熟妇久久无码精品| 日韩欧美一级aa大片| 中文字幕一区二区三区人妻大片| 高清成人av一区三区| 欧美日本在线视频一区| 任我爽精品视频在线播放| 欧美偷拍亚洲一区二区| 极品粉嫩小泬白浆20p主播| 最新国产精品拍在线观看| 在线免费91激情四射 | 揄拍成人国产精品免费看视频| 在线观看的黄色免费网站| 可以在线观看的av中文字幕| 国产日韩欧美美利坚蜜臀懂色| 9国产精品久久久久老师| 国产精品黄大片在线播放| 熟女俱乐部一二三区| 国产刺激激情美女网站| 久草福利电影在线观看| 国产精品视频资源在线播放| 密臀av一区在线观看| 国产大鸡巴大鸡巴操小骚逼小骚逼| 亚洲精品乱码久久久本| 在线免费观看国产精品黄色| 日韩北条麻妃一区在线| 热久久只有这里有精品| 婷婷午夜国产精品久久久| 精品一区二区三区在线观看| 91试看福利一分钟| 中国产一级黄片免费视频播放| 护士特殊服务久久久久久久| 日韩美女综合中文字幕pp| 一区二区三区精品日本| 深田咏美亚洲一区二区| 国产丰满熟女成人视频| 天天躁日日躁狠狠躁躁欧美av| 欧美aa一级一区三区四区| 精品久久久久久久久久久久人妻| 日韩视频一区二区免费观看| 欧美viboss性丰满| 天天干夜夜操啊啊啊| 不卡精品视频在线观看| 激情小视频国产在线| 偷拍自拍福利视频在线观看| 黑人3p华裔熟女普通话| 77久久久久国产精产品| 不卡一不卡二不卡三| 亚洲黄色av网站免费播放| 在线国产中文字幕视频| 久久这里只有精彩视频免费| 精品国产高潮中文字幕| 91九色porny蝌蚪国产成人| 亚洲 中文 自拍 无码| 青青伊人一精品视频| av日韩在线免费播放| 日本人妻少妇18—xx| 麻豆精品成人免费视频| 国产三级精品三级在线不卡| 日韩特级黄片高清在线看| 日本在线不卡免费视频| 天美传媒mv视频在线观看| av在线免费观看亚洲天堂| 色呦呦视频在线观看视频| 热99re69精品8在线播放| 欧美偷拍亚洲一区二区| 青青青青青青青青青国产精品视频| 国产亚洲天堂天天一区| 亚洲蜜臀av一区二区三区九色| 熟女人妻三十路四十路人妻斩| 免费在线黄色观看网站| 自拍偷拍亚洲精品第2页| 亚洲公开视频在线观看| 人妻在线精品录音叫床| 中文字幕在线永久免费播放| 91小伙伴中女熟女高潮| av黄色成人在线观看| 欧美成人综合色在线噜噜| 日韩欧美亚洲熟女人妻| 93精品视频在线观看| 中国产一级黄片免费视频播放| 夜夜嗨av蜜臀av| 国产熟妇一区二区三区av| 国产亚洲成人免费在线观看| 国产熟妇一区二区三区av| 国产黄色片蝌蚪九色91| 国产精品成人xxxx| 天天日天天日天天射天天干| 欧美亚洲免费视频观看| 大陆av手机在线观看| 国产精品亚洲在线观看| 国产美女一区在线观看| 91人妻精品一区二区在线看| 欧美精品一区二区三区xxxx| 亚洲成人av在线一区二区| 青青草成人福利电影| 亚洲综合色在线免费观看| 亚洲熟女女同志女同| 天天艹天天干天天操| 亚洲一级 片内射视正片| 2021天天色天天干| 91麻豆精品秘密入口在线观看| 操日韩美女视频在线免费看| 一级黄色片夫妻性生活| 家庭女教师中文字幕在线播放| 日本真人性生活视频免费看| 中文字幕亚洲久久久| 亚洲va欧美va人人爽3p| 水蜜桃一区二区三区在线观看视频| 97年大学生大白天操逼| 午夜毛片不卡免费观看视频| 欧美久久一区二区伊人| 2o22av在线视频| 天天摸天天日天天操| 欧美色婷婷综合在线| 亚洲精品福利网站图片| 啊啊好慢点插舔我逼啊啊啊视频| 亚洲精品ww久久久久久| 天天色天天操天天舔| 亚洲一级av无码一级久久精品| 超碰97免费人妻麻豆| 日本免费视频午夜福利视频| 视频二区在线视频观看 | 亚洲欧美清纯唯美另类 | 欧美专区日韩专区国产专区| 人妻少妇中文有码精品| 国产精品视频资源在线播放| 97瑟瑟超碰在线香蕉| 国产美女午夜福利久久| 午夜免费体验区在线观看| 国产午夜亚洲精品麻豆| 一区二区三区日本伦理| 亚洲在线观看中文字幕av| 换爱交换乱高清大片| 国产高清97在线观看视频| 亚洲国产成人无码麻豆艾秋| 国产极品美女久久久久久| 精品欧美一区二区vr在线观看 | 亚欧在线视频你懂的| 骚货自慰被发现爆操| 狍和女人的王色毛片| av日韩在线观看大全| 午夜的视频在线观看| 激情五月婷婷免费视频| 国产女人露脸高潮对白视频| 国产又色又刺激在线视频| 大香蕉大香蕉在线有码 av| 好吊操视频这里只有精品| www天堂在线久久| 好男人视频在线免费观看网站| 激情五月婷婷免费视频| 中文字幕av第1页中文字幕| 91中文字幕最新合集| 国产精品成久久久久三级蜜臀av| 四川五十路熟女av| 国产福利小视频免费观看| 成年人午夜黄片视频资源| 337p日本大胆欧美人| 欧美一级视频一区二区| 五十路在线观看完整版| 超级碰碰在线视频免费观看| 天天插天天狠天天操| 成人福利视频免费在线| 视频一区 二区 三区 综合| 超级碰碰在线视频免费观看| 区一区二区三国产中文字幕| 含骚鸡巴玩逼逼视频| 日韩美女综合中文字幕pp| 天天干天天日天天谢综合156| 2018最新中文字幕在线观看| 亚洲免费视频欧洲免费视频| 99久久久无码国产精品性出奶水| 日本丰满熟妇BBXBBXHD| 国产性感美女福利视频| av手机免费在线观看高潮| 国产精品自拍在线视频| 日韩剧情片电影在线收看| 午夜91一区二区三区| 中文字幕人妻被公上司喝醉在线| 91九色porny蝌蚪国产成人| 亚洲av日韩精品久久久久久hd| 午夜大尺度无码福利视频| 91 亚洲视频在线观看| av天堂中文免费在线| 日辽宁老肥女在线观看视频| 高潮视频在线快速观看国家快速| 日本一道二三区视频久久| okirakuhuhu在线观看| 中文字幕一区二区三区人妻大片| 3D动漫精品啪啪一区二区下载| 亚洲国产最大av综合| 天天日天天日天天擦| 蜜桃专区一区二区在线观看| 日本黄色特一级视频| 白嫩白嫩美女极品国产在线观看| 欧美在线一二三视频| 插逼视频双插洞国产操逼插洞| 大鸡巴后入爆操大屁股美女 | 大白屁股精品视频国产| 91人妻精品一区二区在线看| 最新日韩av传媒在线| 亚洲综合乱码一区二区| 涩涩的视频在线观看视频| 午夜av一区二区三区| 亚洲在线一区二区欧美| 午夜精品福利一区二区三区p| 91免费福利网91麻豆国产精品| 久久热久久视频在线观看| 免费大片在线观看视频网站| 欧美一级色视频美日韩| 中文亚洲欧美日韩无线码| 中文字幕在线永久免费播放| 天天摸天天日天天操| 十八禁在线观看地址免费| 激情人妻校园春色亚洲欧美 | 日本一二三区不卡无| 大陆精品一区二区三区久久| 亚洲成人免费看电影| 大屁股熟女一区二区三区| 日本熟妇色熟妇在线观看| 夜色撩人久久7777| 成人av电影免费版| 老鸭窝在线观看一区| 中文字幕亚洲久久久| 天天日天天鲁天天操| 东京干手机福利视频| 亚洲成人av在线一区二区| 欧美老妇精品另类不卡片| xxx日本hd高清| 青青在线视频性感少妇和隔壁黑丝 | 国产一区成人在线观看视频 | 亚洲精品无码色午夜福利理论片| 欧美专区日韩专区国产专区| 91九色porny国产在线| 国产使劲操在线播放| 亚洲国产精品黑丝美女| 啪啪啪操人视频在线播放| 91精品国产综合久久久蜜| 国产免费av一区二区凹凸四季| 伊人精品福利综合导航| 成人综合亚洲欧美一区| 亚洲av日韩av网站| 男人天堂色男人av| 在线播放国产黄色av| 黑人借宿ntr人妻的沦陷2| 97香蕉碰碰人妻国产樱花| 极品丝袜一区二区三区| www骚国产精品视频| 欧美男同性恋69视频| 在线不卡成人黄色精品| 馒头大胆亚洲一区二区| 午夜精品一区二区三区福利视频| 中文字幕人妻三级在线观看| 久久久久91精品推荐99| 国产午夜无码福利在线看| 欧美一级色视频美日韩| 久久综合老鸭窝色综合久久| 欧美3p在线观看一区二区三区| 亚洲欧美激情国产综合久久久| 91精品国产麻豆国产| 久久精品国产999| av新中文天堂在线网址| 特大黑人巨大xxxx| 中文字幕乱码av资源| 社区自拍揄拍尻屁你懂的| 91国偷自产一区二区三区精品| 男女啪啪啪啪啪的网站| 成人av中文字幕一区| 91综合久久亚洲综合| 成人影片高清在线观看| 人人在线视频一区二区| 麻豆性色视频在线观看| 2020av天堂网在线观看| 黄色片黄色片wyaa| 国产精品亚洲а∨天堂免| 亚洲欧美成人综合在线观看| 九色精品视频在线播放| 久久精品国产999| 久久这里只有精彩视频免费| 国产白袜脚足J棉袜在线观看| 91中文字幕免费在线观看| 亚洲图库另类图片区| 国产亚洲天堂天天一区| 成人H精品动漫在线无码播放| 在线观看欧美黄片一区二区三区| 精品国产乱码一区二区三区乱| 蜜臀av久久久久蜜臀av麻豆| 亚洲成人国产av在线| 国产刺激激情美女网站| 欧美亚洲免费视频观看| 日韩欧美亚洲熟女人妻| jiuse91九色视频| 深夜男人福利在线观看| 女蜜桃臀紧身瑜伽裤| 国产美女精品福利在线| 日韩黄色片在线观看网站| 大鸡吧插入女阴道黄色片| 亚洲午夜伦理视频在线| 91国语爽死我了不卡| 又色又爽又黄又刺激av网站| 亚洲av成人网在线观看| 亚洲av男人的天堂你懂的| 成人性爱在线看四区| 区一区二区三国产中文字幕| 日本一二三中文字幕| 欧美日韩人妻久久精品高清国产 | 国产一区二区视频观看| 日本午夜福利免费视频| 粉嫩av懂色av蜜臀av| av一区二区三区人妻| 午夜免费体验区在线观看| 91亚洲手机在线视频播放| 中文字幕一区的人妻欧美日韩| 啊啊好大好爽啊啊操我啊啊视频 | 亚洲成人熟妇一区二区三区 | 国产麻豆精品人妻av| 国产激情av网站在线观看| 亚洲免费在线视频网站| 亚洲图片欧美校园春色| 欧美va亚洲va天堂va| av天堂资源最新版在线看| 91人妻精品一区二区在线看| 日韩中文字幕精品淫| 人妻无码中文字幕专区| 国产一区二区欧美三区| 中文字幕最新久久久| 日本人竟这样玩学生妹| 亚洲天堂第一页中文字幕| 人妻丝袜榨强中文字幕| 直接能看的国产av| 青青草人人妻人人妻| av中文字幕网址在线| 久久久人妻一区二区| 又大又湿又爽又紧A视频| 天堂av狠狠操蜜桃| 欧美日韩高清午夜蜜桃大香蕉| 少妇人妻100系列| 欧美亚洲免费视频观看| 把腿张开让我插进去视频| 亚洲综合在线观看免费| 久久农村老妇乱69系列| 18禁精品网站久久| 中文字幕第1页av一天堂网| 国产va在线观看精品| 国产1区,2区,3区| 日韩三级电影华丽的外出| 老司机在线精品福利视频| 欧美色婷婷综合在线| 阿v天堂2014 一区亚洲| 日韩a级黄色小视频| 综合精品久久久久97| 欧美亚洲自偷自拍 在线| av亚洲中文天堂字幕网| 91天堂天天日天天操| 日韩av免费观看一区| 国产精品系列在线观看一区二区| 久久一区二区三区人妻欧美| 欧美香蕉人妻精品一区二区| 超级av免费观看一区二区三区| 97精品人妻一区二区三区精品| 在线观看一区二区三级| 午夜成午夜成年片在线观看 | 只有精品亚洲视频在线观看| 日本午夜爽爽爽爽爽视频在线观看 | 欧美怡红院视频在线观看| 操的小逼流水的文章| 好了av中文字幕在线| 亚洲无线观看国产高清在线| 色综合久久五月色婷婷综合| 亚洲 欧美 精品 激情 偷拍| 亚洲综合另类精品小说| 国产高清女主播在线| 精品久久久久久久久久中文蒉| 日本免费午夜视频网站| 欧美亚洲免费视频观看| tube69日本少妇| 在线免费观看亚洲精品电影 | 亚洲精品三级av在线免费观看| 亚洲成人国产综合一区| 在线观看国产免费麻豆| 亚洲精品无码色午夜福利理论片| 日本高清撒尿pissing| 亚洲丝袜老师诱惑在线观看| 日韩a级黄色小视频| 亚洲另类伦春色综合小| 午夜免费体验区在线观看| 日韩美女福利视频网| 免费看高清av的网站| 亚洲成人线上免费视频观看| 91www一区二区三区| 97精品人妻一区二区三区精品| 97精品成人一区二区三区| 亚洲激情av一区二区| 欧美成人一二三在线网| 国产一区二区三免费视频| 亚洲福利精品福利精品福利| 天天日天天做天天日天天做| 插逼视频双插洞国产操逼插洞| 日韩激情文学在线视频| 97精品人妻一区二区三区精品 | 亚洲免费福利一区二区三区| 欧美专区日韩专区国产专区| 成年人午夜黄片视频资源| 日本乱人一区二区三区| 亚洲天天干 夜夜操| 亚洲国产免费av一区二区三区| 天天日天天玩天天摸| 美女 午夜 在线视频| 天天插天天色天天日| 一区二区三区另类在线| 丰满少妇人妻xxxxx| 一级A一级a爰片免费免会员| a v欧美一区=区三区| 人妻熟女中文字幕aⅴ在线| 91小伙伴中女熟女高潮| 亚洲国产最大av综合| 国产精品日韩欧美一区二区| 一区二区麻豆传媒黄片| 中文字幕一区的人妻欧美日韩| 人人爱人人妻人人澡39| 亚洲美女美妇久久字幕组| 91chinese在线视频| 日本女人一级免费片| 91福利在线视频免费观看| 亚洲日产av一区二区在线| 亚洲欧美另类手机在线| 欧美特色aaa大片| 91天堂精品一区二区| 亚洲国产欧美一区二区三区久久| 成年人午夜黄片视频资源| 久久综合老鸭窝色综合久久| 天天色天天爱天天爽| 美女大bxxxx内射| 国产1区,2区,3区| 又黄又刺激的午夜小视频| 日韩剧情片电影在线收看| 亚洲精品中文字幕下载| 老司机免费福利视频网| 日韩人妻丝袜中文字幕| 无码精品一区二区三区人| 天天射夜夜操综合网| nagger可以指黑人吗| 成熟丰满熟妇高潮xx×xx| 精品老妇女久久9g国产| 含骚鸡巴玩逼逼视频| v888av在线观看视频| 小穴多水久久精品免费看| 国产精品黄色的av| 国内资源最丰富的网站| 婷婷久久久久深爱网| 伊人情人综合成人久久网小说 | 国产黄色高清资源在线免费观看| 天天色天天舔天天射天天爽| 国产欧美精品不卡在线| 韩国三级aaaaa高清视频| 熟女人妻三十路四十路人妻斩| 亚洲 中文 自拍 无码| 日本福利午夜电影在线观看| av视网站在线观看| 欧美日韩国产一区二区三区三州| 亚洲无线观看国产高清在线| 大香蕉大香蕉在线有码 av| 伊人开心婷婷国产av| 国产激情av网站在线观看| 欧美一级视频一区二区| 天堂av狠狠操蜜桃| 日本丰满熟妇BBXBBXHD| 摧残蹂躏av一二三区| 亚洲区欧美区另类最新章节| 成人高潮aa毛片免费| 黄色黄色黄片78在线| 日本女人一级免费片| 亚洲中文字幕人妻一区| 秋霞午夜av福利经典影视| 黄页网视频在线免费观看| 在线观看视频网站麻豆| 91精品国产黑色丝袜| 亚洲av无女神免非久久| 青青草视频手机免费在线观看| 国产精品日韩欧美一区二区| 欧美一级色视频美日韩| lutube在线成人免费看| 国产亚洲精品欧洲在线观看| 人妻少妇av在线观看| 欧美久久一区二区伊人| 久久机热/这里只有| 99人妻视频免费在线| 99国内小视频在现欢看| 日本少妇精品免费视频| 国产精品黄片免费在线观看| 人妻少妇亚洲一区二区| 成人高潮aa毛片免费| 国产精品人妻一区二区三区网站| 婷婷久久一区二区字幕网址你懂得 | 热99re69精品8在线播放| 久久久噜噜噜久久熟女av| 伊人综合免费在线视频| 毛片一级完整版免费| 国产成人自拍视频播放 | 成人精品在线观看视频| 中文字幕—97超碰网| 绝色少妇高潮3在线观看| 五十路熟女av天堂| 天天草天天色天天干| 精彩视频99免费在线| 2019av在线视频| 亚洲精品在线资源站| 97精品成人一区二区三区| 欧美亚洲免费视频观看| ka0ri在线视频| 日韩在线视频观看有码在线| 91老熟女连续高潮对白| 视频 国产 精品 熟女 | 2020中文字幕在线播放| 福利在线视频网址导航| 一级黄片大鸡巴插入美女| 国产精品一二三不卡带免费视频| 午夜激情精品福利视频| 3344免费偷拍视频| 亚洲国产最大av综合| 欧美一区二区三区啪啪同性| 国产精品自偷自拍啪啪啪| 第一福利视频在线观看| 成人av在线资源网站| 91国内精品自线在拍白富美| 在线播放一区二区三区Av无码| 888欧美视频在线| 亚洲蜜臀av一区二区三区九色 | 久久久极品久久蜜桃| 特黄老太婆aa毛毛片| 中字幕人妻熟女人妻a62v网 | 熟女视频一区,二区,三区| 极品粉嫩小泬白浆20p主播| 亚洲一区二区三区uij| 激情人妻校园春色亚洲欧美 | 黄色av网站免费在线| 一区二区免费高清黄色视频| 天天干天天操天天插天天日| aiss午夜免费视频| 亚洲激情av一区二区| 中文字幕+中文字幕| 青青青激情在线观看视频| 老司机在线精品福利视频| 国产卡一卡二卡三乱码手机| 十八禁在线观看地址免费| 亚洲av日韩av网站| 五十路在线观看完整版| 成人av久久精品一区二区| 国产精品手机在线看片| 男人的天堂一区二区在线观看| 边摸边做超爽毛片18禁色戒| 国产男女视频在线播放| 日本少妇人妻xxxxx18| 91国产资源在线视频| 又大又湿又爽又紧A视频| 欧美一区二区三区高清不卡tv| 欧美 亚洲 另类综合| 欧美 亚洲 另类综合| 97少妇精品在线观看| 女警官打开双腿沦为性奴| 日本真人性生活视频免费看| 日本午夜久久女同精女女| 亚洲女人的天堂av| 新婚人妻聚会被中出| 中文字幕一区二区三区蜜月| 国产精品视频资源在线播放| 2021久久免费视频| 欧美视频中文一区二区三区| 欧美在线一二三视频| 亚洲国产在线精品国偷产拍| 91精品资源免费观看| 色天天天天射天天舔| 青草久久视频在线观看| 日本真人性生活视频免费看| 天天日天天操天天摸天天舔| 成人免费公开视频无毒| 神马午夜在线观看视频| 亚洲免费国产在线日韩| 中文字幕第一页国产在线| 18禁美女无遮挡免费| 性感美女高潮视频久久久| 日本一二三中文字幕| 日韩成人免费电影二区| 亚洲中文字幕乱码区| 视频啪啪啪免费观看| 老鸭窝日韩精品视频观看| 熟女妇女老妇一二三区| 中文字幕日韩无敌亚洲精品| 欧美亚洲少妇福利视频| 欧美成人综合色在线噜噜| chinese国产盗摄一区二区| 亚洲成人免费看电影| 欧美3p在线观看一区二区三区| 99re国产在线精品| 国产熟妇一区二区三区av | 青青青艹视频在线观看| 欧美偷拍自拍色图片| 中文字幕网站你懂的| 久久热这里这里只有精品| 日韩欧美国产一区不卡| 蜜桃视频17c在线一区二区| 精品久久久久久高潮| 18禁美女无遮挡免费| 天堂中文字幕翔田av| 成年午夜影片国产片| 日日日日日日日日夜夜夜夜夜夜| 日韩美女综合中文字幕pp| 香蕉av影视在线观看| 绝顶痉挛大潮喷高潮无码| 免费男阳茎伸入女阳道视频| 亚洲成人激情视频免费观看了| 中文字幕av熟女人妻| 自拍偷拍,中文字幕| av一本二本在线观看| 99亚洲美女一区二区三区| 日韩欧美制服诱惑一区在线| 亚洲一区二区激情在线| 日韩欧美一级精品在线观看| 国产欧美精品免费观看视频| 人妻少妇一区二区三区蜜桃| 97超碰国语国产97超碰| 黄色大片男人操女人逼| 黄色的网站在线免费看| 在线免费观看亚洲精品电影| 国产密臀av一区二区三| 日本av在线一区二区三区| 九色精品视频在线播放| 一级黄片久久久久久久久| 在线观看国产网站资源| 黑人巨大的吊bdsm| 18禁网站一区二区三区四区| 中国视频一区二区三区| 亚洲成人av一区久久| 91中文字幕最新合集| av亚洲中文天堂字幕网| 欧美一级色视频美日韩| 国产视频一区在线观看| 成年人黄视频在线观看| 天堂av在线播放免费| 国产在线拍揄自揄视频网站| 中文字幕一区二区三区人妻大片 | 成人免费做爰高潮视频| 天天干夜夜操天天舔| 亚洲av午夜免费观看| 欧美成人小视频在线免费看| 欧美日韩不卡一区不区二区| 综合激情网激情五月五月婷婷| 亚洲一区二区三区偷拍女厕91| 日本中文字幕一二区视频| 黄色大片男人操女人逼| 天天日天天鲁天天操| 韩国三级aaaaa高清视频 | 天天日天天玩天天摸| 久草视频在线免播放| 亚洲av成人网在线观看| 日韩精品二区一区久久| 国产福利小视频免费观看| 午夜精品一区二区三区福利视频| gav成人免费播放| 久久国产精品精品美女| 天堂av在线最新版在线| 亚洲中文字幕人妻一区| 中文字幕一区二 区二三区四区| 精品91自产拍在线观看一区| 国产三级影院在线观看| 久久香蕉国产免费天天| 欧美少妇性一区二区三区| 亚洲高清一区二区三区视频在线| 国产日韩一区二区在线看| 狠狠操操操操操操操操操| 人妻丰满熟妇综合网| 日本精品一区二区三区在线视频。| 亚洲午夜精品小视频| 亚洲另类图片蜜臀av| 中文字幕日韩无敌亚洲精品| 天天色天天操天天透| 亚洲熟妇久久无码精品| 人妻3p真实偷拍一二区| 自拍偷拍 国产资源| 蜜桃久久久久久久人妻| 女警官打开双腿沦为性奴| 最新国产精品拍在线观看| 欧亚日韩一区二区三区观看视频| 国产卡一卡二卡三乱码手机| 欲满人妻中文字幕在线| 午夜在线观看一区视频| 国产麻豆乱子伦午夜视频观看| 欧美老妇精品另类不卡片| 亚洲av黄色在线网站| 久久久久久97三级| 福利视频广场一区二区| 亚洲欧美另类手机在线| 夜女神免费福利视频| 强行扒开双腿猛烈进入免费版| 亚洲免费国产在线日韩| 在线视频国产欧美日韩| 国产精品人妻一区二区三区网站 | 中文字幕人妻熟女在线电影| 蜜桃久久久久久久人妻| 天天日天天干天天插舔舔| 欧美色婷婷综合在线| 天天插天天狠天天操| 97青青青手机在线视频| 精品91高清在线观看| 国产精品久久久久网| 黄色av网站免费在线| 粉嫩av蜜乳av蜜臀| 在线新三级黄伊人网| 黄片三级三级三级在线观看| 在线国产中文字幕视频| 黄色在线观看免费观看在线| 91九色国产熟女一区二区| 夜夜骑夜夜操夜夜奸| 美女视频福利免费看| 天天操天天弄天天射| 午夜毛片不卡免费观看视频| 黄色成年网站午夜在线观看| 国产乱弄免费视频观看| 婷婷五月亚洲综合在线| 亚洲伊人久久精品影院一美女洗澡| 大香蕉伊人国产在线| 98精产国品一二三产区区别| 青青青激情在线观看视频| 五十路老熟女码av| 天天日天天做天天日天天做| 91社福利《在线观看| 伊人开心婷婷国产av| av森泽佳奈在线观看 | 人妻熟女在线一区二区 | 人妻丝袜榨强中文字幕| 日韩欧美亚洲熟女人妻| 57pao国产一区二区| 天天日天天玩天天摸| 日本高清撒尿pissing| 久久久久久久久久性潮| 极品丝袜一区二区三区| 沈阳熟妇28厘米大战黑人| 中文字幕在线一区精品| 国产亚洲欧美45p| 久久久久久国产精品| 亚洲少妇人妻无码精品| 国产黄色大片在线免费播放| 日韩在线视频观看有码在线| 国产精品黄色的av| 日本高清撒尿pissing| 超级av免费观看一区二区三区| 国产在线自在拍91国语自产精品 | 色哟哟国产精品入口| 新婚人妻聚会被中出| 国产精品福利小视频a| 欧美成人猛片aaaaaaa| 人人爱人人妻人人澡39| 91大屁股国产一区二区| 风流唐伯虎电视剧在线观看| 日韩人妻在线视频免费| 人人人妻人人澡人人| 欲满人妻中文字幕在线| 亚洲视频在线观看高清| 国产视频一区在线观看| 日韩不卡中文在线视频网站| 经典亚洲伊人第一页| 日本在线一区二区不卡视频| 搡老妇人老女人老熟女| 亚洲码av无色中文| 日韩不卡中文在线视频网站| 欧美日本在线观看一区二区| 成熟丰满熟妇高潮xx×xx| 天天干天天搞天天摸| 久久久久久97三级| 一区二区三区四区视频| av中文字幕网址在线| 春色激情网欧美成人| 欧美专区日韩专区国产专区| 亚洲美女高潮喷浆视频| 91人妻精品一区二区在线看| 精品一区二区三区在线观看| 成人影片高清在线观看| av中文字幕电影在线看| 亚洲一区二区三区av网站| 亚洲日产av一区二区在线| 一区二区视频在线观看免费观看| 91av精品视频在线| 人妻丝袜诱惑我操她视频| 午夜免费观看精品视频| 天天日天天做天天日天天做| 免费手机黄页网址大全| 日韩伦理短片在线观看| 亚洲日产av一区二区在线| 中文字幕 码 在线视频| 亚洲伊人久久精品影院一美女洗澡| 午夜激情久久不卡一区二区| 婷婷色中文亚洲网68| 婷婷五月亚洲综合在线| 在线观看免费岛国av| 亚洲一区二区三区精品视频在线| 最新中文字幕乱码在线| 国产女人叫床高潮大片视频| 久久麻豆亚洲精品av| 中文字幕,亚洲人妻| 新97超碰在线观看| 欧美80老妇人性视频| 天天操天天污天天射| 午夜精品一区二区三区福利视频| 天堂av在线最新版在线| 中文字幕在线观看极品视频| 人人妻人人爽人人添夜| 亚洲欧洲一区二区在线观看| 都市激情校园春色狠狠| 99精品免费久久久久久久久a| 动漫精品视频在线观看| 午夜大尺度无码福利视频| 桃色视频在线观看一区二区| 中英文字幕av一区| 青青草原网站在线观看 | 小穴多水久久精品免费看| 动漫黑丝美女的鸡巴| 青青青国产免费视频| 欧美一区二区三区四区性视频| avjpm亚洲伊人久久| 午夜婷婷在线观看视频| 鸡巴操逼一级黄色气| 最新黄色av网站在线观看| 女同性ⅹxx女同hd| 最新中文字幕乱码在线| 日韩一个色综合导航| 激情小视频国产在线| 综合精品久久久久97| 3D动漫精品啪啪一区二区下载| 超碰中文字幕免费观看| 日本女大学生的黄色小视频| 88成人免费av网站| 内射久久久久综合网| 老司机福利精品视频在线| 亚洲第一黄色在线观看| 中文字幕在线一区精品| 人妻久久无码中文成人| 欧美日韩国产一区二区三区三州| 亚国产成人精品久久久| 国产日韩欧美美利坚蜜臀懂色| 一区二区三区精品日本| 亚洲蜜臀av一区二区三区九色| 97超碰国语国产97超碰| 日韩美女精品视频在线观看网站| 超污视频在线观看污污污| 精品人妻每日一部精品| 国产美女精品福利在线| 天天干天天操天天摸天天射| 在线观看视频 你懂的| 影音先锋女人av噜噜色| 久久久超爽一二三av| 青青青视频手机在线观看| 天天日天天干天天要| 一区二区三区精品日本| 日韩a级黄色小视频| 精品91自产拍在线观看一区| 亚洲国产最大av综合| 最新中文字幕乱码在线| 国产高清精品一区二区三区| 欧美精品资源在线观看| 日本在线不卡免费视频| 亚洲欧美激情中文字幕| 在线观看视频污一区| 9久在线视频只有精品| 最新日韩av传媒在线| 国产一区av澳门在线观看| aiss午夜免费视频| 女生自摸在线观看一区二区三区 | 亚洲码av无色中文| 91亚洲精品干熟女蜜桃频道| 日韩北条麻妃一区在线| 日本女人一级免费片| 久草视频中文字幕在线观看| 成人综合亚洲欧美一区| 白白操白白色在线免费视频| 久久久久五月天丁香社区| 久久精品国产23696| 999九九久久久精品| 色婷婷六月亚洲综合香蕉| 夜女神免费福利视频| 亚洲综合在线视频可播放| 五月精品丁香久久久久福利社| 天天操夜夜操天天操天天操| 日本免费一级黄色录像| 色哟哟在线网站入口| 亚洲av在线观看尤物| 亚洲av无乱一区二区三区性色| 亚洲一级 片内射视正片| 四川乱子伦视频国产vip| 免费一级特黄特色大片在线观看| 一区二区三区四区视频| 日本18禁久久久久久| 中文字幕最新久久久| 欧洲亚洲欧美日韩综合| 国产又色又刺激在线视频| 国产三级影院在线观看| 国产成人自拍视频在线免费观看| 深夜男人福利在线观看| 97超碰最新免费在线观看| 东京热男人的av天堂| 丝袜国产专区在线观看| 91综合久久亚洲综合| 亚洲精品精品国产综合| 亚洲 清纯 国产com| 超鹏97历史在线观看| 激情五月婷婷免费视频| 国产密臀av一区二区三| 偷拍自拍 中文字幕| 亚洲福利精品视频在线免费观看| 少妇ww搡性bbb91| 19一区二区三区在线播放| 欧美成人综合视频一区二区| 日韩激情文学在线视频| 亚洲午夜电影之麻豆| 亚洲在线免费h观看网站| 91亚洲精品干熟女蜜桃频道 | 日韩成人性色生活片| 天天操天天爽天天干| 大香蕉伊人中文字幕| 中文字幕综合一区二区| 中文字幕高清资源站| 又大又湿又爽又紧A视频| 免费大片在线观看视频网站| 国产高潮无码喷水AV片在线观看| 亚洲伊人av天堂有码在线| 国产一区自拍黄视频免费观看| 天天日天天摸天天爱| 啪啪啪啪啪啪啪啪av| 人妻少妇精品久久久久久 | 久久久久久久一区二区三| 国产一区二区火爆视频| 日韩av有码一区二区三区4| 亚洲欧美国产综合777| 偷拍美女一区二区三区| 青青操免费日综合视频观看| 中文字幕国产专区欧美激情| jiuse91九色视频| 欧美日韩人妻久久精品高清国产| 国产欧美日韩在线观看不卡| 亚洲高清一区二区三区视频在线| 都市家庭人妻激情自拍视频| 51国产成人精品视频| 超污视频在线观看污污污 | 亚洲国产成人av在线一区| 极品粉嫩小泬白浆20p主播| 日本熟妇喷水xxx| 国产免费高清视频视频| 国产妇女自拍区在线观看| 在线观看欧美黄片一区二区三区| 岛国av高清在线成人在线| 一区二区三区日本伦理| 国产精品黄大片在线播放| 伊人开心婷婷国产av| 日韩欧美亚洲熟女人妻| 非洲黑人一级特黄片| 美女大bxxxx内射| 91人妻精品一区二区久久| 亚洲日产av一区二区在线| 激情啪啪啪啪一区二区三区 | 日本少妇人妻xxxxxhd| 做爰视频毛片下载蜜桃视频1|