国产秋霞理论久久久电影-婷婷色九月综合激情丁香-欧美在线观看乱妇视频-精品国avA久久久久久久-国产乱码精品一区二区三区亚洲人-欧美熟妇一区二区三区蜜桃视频

從案例到底層原理,徹底理解volatile可見性和禁止指令重排

共 15015字,需瀏覽 31分鐘

 ·

2021-04-14 07:24

公眾號關(guān)注 “GitHub今日熱榜
設(shè)為 “星標(biāo)”,帶你挖掘更多開發(fā)神器!






一. volatile保證可見性


public class TestMain {
 
    private static boolean flag = false;
    //private volatile static boolean flag = false;
 
    public static void main(String[] args) throws InterruptedException {
        new Thread(() -> {
            flag = true;
            System.out.println("=======循環(huán)之前=======");
            while (flag) {
 
            }
            System.out.println("=======循環(huán)之后=======");
        }).start();
 
        Thread.sleep(2000);
 
        new Thread(() -> {
            System.out.println("修改flag之前...");
            System.out.println(flag); // true
 
            flag = false;
            System.out.println("修改flag之后...");
            System.out.println(flag); // false 上面的線程沒有跳出循環(huán)
        }).start();
 
    }
 
}


在這里,我們通過一個最簡單的例子,來引入可見性。


在運(yùn)行程序之前,我們先來分析一下上述代碼的邏輯,推測一下結(jié)果。第1個線程啟動后,將flag置為true,然后會陷入死循環(huán)。稍后,第2個線程啟動后,將flag置為false。按理來說,此時第1個線程應(yīng)該會跳出死循環(huán)才對。但運(yùn)行結(jié)果卻不是這樣!flag是兩個線程的共享變量,但是第2個線程將flag置為false之后,并沒有被第1個線程所感知(不可見)。


如何解決這個問題?只需要在用 volatile 來修飾flag,保證flag多個線程之間可見即可。


二. Java內(nèi)存模型(JMM)


為了更容易理解可見性,有必要簡單引入一下JMM(Java Memory Model),對內(nèi)存模型有大概的抽象了解。


1. JMM(Java Memory Model)


Java 內(nèi)存模型,是 Java 虛擬機(jī)規(guī)范中所定義的一種內(nèi)存模型,是一種抽象的概念,并不真實(shí)存在!它描述的是一組規(guī)則或規(guī)范,通過這組規(guī)范定義了程序中各個變量(包括實(shí)例字段,靜態(tài)字段和構(gòu)成數(shù)組對象的元素)的訪問方式。它屏蔽掉了底層不同計算機(jī)硬件架構(gòu)下內(nèi)存的區(qū)別。也就是說,JMM 是 JVM 中定義的一種并發(fā)編程的底層模型機(jī)制。


2. JMM 的抽象示意圖



JMM 規(guī)定:


  • 所有的共享變量都存儲于主內(nèi)存。這里所說的變量指的是實(shí)例變量和類變量,不包含局部變量,因?yàn)榫植孔兞渴蔷€程私有的,因此不存在競爭問題。

  • 每一個線程還存在自己的工作內(nèi)存,線程的工作內(nèi)存,保留了被線程使用的變量的工作副本。

  • 線程對變量的所有的操作(讀,?。┒急仨氃诠ぷ鲀?nèi)存中完成,而不能直接讀寫主內(nèi)存中的變量。

  • 不同線程之間也不能直接訪問對方工作內(nèi)存中的變量,線程間變量的值的傳遞需要通過主內(nèi)存中轉(zhuǎn)來完成。


由于緩存的存在,就可能會出現(xiàn)以下兩種情況而導(dǎo)致緩存不一致:


  1. 線程對共享變量的修改沒有即時更新到主內(nèi)存;

  2. 線程沒能夠即時將共享變量的最新值同步到工作內(nèi)存中,從而使得線程在使用共享變量的值時,該值并不是最新的;


3. 數(shù)據(jù)同步的八大原子操作


以上關(guān)于主內(nèi)存與工作內(nèi)存之間的具體交互協(xié)議,即一個變量如何從主內(nèi)存拷貝到工作內(nèi)存、如何從工作內(nèi)存同步到主內(nèi)存之間的實(shí)現(xiàn)細(xì)節(jié),Java內(nèi)存模型定義了以下八種操作來完成。


簡單了解一下即可,方便我們畫圖來解釋上述的第一個例子。


  • lock (鎖定):作用于主內(nèi)存的變量,把一個變量標(biāo)記為一條線程獨(dú)占狀態(tài)

  • unlock (解鎖):作用于主內(nèi)存的變量,把一個處于鎖定狀態(tài)的變量釋放出來,釋放后的變量才可以被其他線程鎖定

  • read (讀取):作用于主內(nèi)存的變量,把一個變量值從主內(nèi)存?zhèn)鬏數(shù)骄€程的工作內(nèi)存中,以便隨后的load動作使用

  • load (載入):作用于工作內(nèi)存的變量,它把read操作從主內(nèi)存中得到的變量值放入工作內(nèi)存的變量副本中

  • use (使用):作用于工作內(nèi)存的變量,把工作內(nèi)存中的一個變量值傳遞給執(zhí)行引擎

  • assign (賦值):作用于工作內(nèi)存的變量,它把一個從執(zhí)行引擎接收到的值賦給工作內(nèi)存的變量

  • store (存儲):作用于工作內(nèi)存的變量,把工作內(nèi)存中的一個變量的值傳送到主內(nèi)存中,以便隨后的write的操作

  • write (寫入):作用于工作內(nèi)存的變量,它把store操作從工作內(nèi)存中的一個變量的值傳送到主內(nèi)存的變量中



4. 流程圖解釋例1



如果對聲明了volatile的變量進(jìn)行寫操作,JVM就立即會向處理器發(fā)送一條Lock前綴(硬件級別)的指令,立即將這個變量所在緩存行的數(shù)據(jù)寫回到系統(tǒng)內(nèi)存。但是,就算寫回到內(nèi)存,如果其他處理器緩存的值還是舊的,再執(zhí)行計算操作就會有問題。所以,在多處理器下,為了保證各個處理器的緩存是一致的,就會實(shí)現(xiàn)緩存一致性協(xié)議。每個處理器通過嗅探在總線上傳播的數(shù)據(jù)來檢查自己緩存的值是不是過期了(總線嗅探機(jī)制,這是實(shí)現(xiàn)緩存一致性的常見機(jī)制)。  當(dāng)處理器發(fā)現(xiàn)自己緩存行對應(yīng)的內(nèi)存地址被修改,就會將當(dāng)前處理器的緩存行設(shè)置成無效狀態(tài)。當(dāng)處理器對這個數(shù)據(jù)進(jìn)行修改操作的時候,發(fā)現(xiàn)緩存無效,會重新從系統(tǒng)內(nèi)存中重新讀取并更新到緩存。


除了volatile,加鎖也能保證變量的內(nèi)存可見性。因?yàn)楫?dāng)一個線程進(jìn)入 synchronized 代碼塊后,線程獲取到鎖,會清空本地內(nèi)存,然后從主內(nèi)存中拷貝共享變量的最新值到本地內(nèi)存作為副本,執(zhí)行代碼,又將修改后的副本值刷新到主內(nèi)存中,最后線程釋放鎖。除了 synchronized 外,其它鎖也能保證變量的內(nèi)存可見性。


二. volatile無法保證原子性


public class TestMain1 {
 
    public volatile static int i = 0;
 
    public static void main(String[] args) throws InterruptedException {
        CountDownLatch latch = new CountDownLatch(10);
 
        for (int k = 0; k < 10; k++) { // 10個線程
            new Thread(() -> {
                for (int j = 0; j < 100000; j++) { // 10萬
// synchronized (TestMain1.class) {
                        i++;
// }
                }
                latch.countDown();
            }).start(); // 新建線程,并開始執(zhí)行
        }
 
        latch.await(); // 阻塞,直到10個線程全部運(yùn)行完成
        System.out.println(i);
    }
 
}


通過上述例子,可以證明volatile并不保證原子性!


上述代碼中,開啟了10個線程,每個線程對 i 自增 10 0000(10萬)。如果不出現(xiàn)線程安全問題,那么最后的結(jié)果應(yīng)該是 10 * 10 0000 = 100 萬。但運(yùn)行結(jié)果總是不足100萬,并具有隨機(jī)性。說明了,代碼中出現(xiàn)了線程不安全的問題。


在并發(fā)場景下,變量 i 的任何改變都會立即被其他線程所感知,但是如果存在多條線程同時執(zhí)行i++,仍然會出現(xiàn)線程安全問題。畢竟i++的操作,并不是原子操作。該操作是先讀取 i 的值,將 i 加1,然后將新值寫回主內(nèi)存。如果第2個線程在第1個線程 讀取舊值 和 寫回新值 期間讀取 i 的值,那么第2個線程就會與第1個線程一起看到同一個值,并執(zhí)行相同值的加1操作。因此對于 i++ 這個非原子操作必須使用synchronized修飾,以便保證線程安全,需要注意的是一旦使用synchronized修飾方法后,由于synchronized本身也具備與volatile相同的特性,即可見性,因此在這種情況下就完全可以省去volatile修飾變量。


三. volatile禁止指令重排(保證有序性)


1. 通過例子窺探指令重排


我們先通過一個代碼例子,來證明一下在底層,是有可能發(fā)現(xiàn)指令重排的。


注:程序執(zhí)行可能要花個十分鐘左右才能出結(jié)果,因?yàn)橛?00萬次循環(huán),而每次循環(huán)都要創(chuàng)建線程(這是一個比較費(fèi)時的操作)


public class TestMain3 {
 
    static int x = 0, y = 0;
    static int a = 0, b = 0;
 
    public static void main(String[] args) throws InterruptedException {
        Set<String> resultSet = new HashSet<>();
 
        for (int i = 0; i < 1000000; i++) { // 100萬
 
            x = 0; y = 0;
            a = 0; b = 0;
 
            Thread t1 = new Thread(() -> {
                a = y; // 1
                x = 1; // 2
            });
 
            Thread t2 = new Thread(() -> {
                b = x; // 3
                y = 1; // 4
            });
 
            t1.start();
            t2.start();
 
            t1.join();
            t2.join();
 
            resultSet.add(String.format("a=%d,b=%d", a, b));
        }
 
        System.out.println(resultSet);
    }
 
}


分析以下上述代碼。對于每一次循環(huán),a和b可能的值如下:


a=0,b=0:此時代碼的執(zhí)行順序可能是這樣,① a=y,② b=x,③ x=1,④ y=1


a=0,b=1:此時代碼的執(zhí)行順序可能是這樣,① a=y,② x=1,③ b=x,④ y=1


a=1,b=0:此時代碼的執(zhí)行順序可能是這樣,① b=x,② y=1,③ a=y,④ x=1


a=1,b=1:從代碼上來看,是不可能出現(xiàn)的。因?yàn)閺拇a上來看,代碼1 先于 代碼2,代碼3 先于 代碼4。這兩個先后次序,是我們從代碼中可以直觀看出來的。上面3種情況,代碼的執(zhí)行順序都蘊(yùn)含了這兩種先后次序!a為1,說明y必然為1(代碼4必然執(zhí)行了),由于我們認(rèn)為 “代碼3 先于 代碼4”,所以代碼3必然已經(jīng)提前執(zhí)行完了,那么b應(yīng)該為0,不可能為1。


所以我們?nèi)绻J(rèn)為 “代碼1 先于 代碼2,代碼3 先于 代碼4”,那么就不可能會出現(xiàn) a=1,b=1 的情況。但是程序運(yùn)行結(jié)果卻出現(xiàn)了這種情況,說明了底層發(fā)生了指令重排!



2. 指令重排


Java語言規(guī)范規(guī)定JVM線程內(nèi)部維持順序化語義。即只要程序的最終結(jié)果與它順序化情況的結(jié)果相等,那么指令的執(zhí)行順序可以與代碼順序不一致,此過程叫指令的重排序。指令重排序的意義是什么?JVM能根據(jù)處理器特性(CPU多級緩存系統(tǒng)、多核處理器等)適當(dāng)?shù)膶C(jī)器指令進(jìn)行重排序,使機(jī)器指令能更符合CPU的執(zhí)行特性,最大限度的發(fā)揮機(jī)器性能。


從 Java 源代碼到最終執(zhí)行的指令序列,會分別經(jīng)歷下面3種重排序:



int a = 0;
// 線程 A
a = 1; // 1
flag = true; // 2
 
// 線程 B
if (flag) { // 3
  int i = a; // 4
}


單看上面的程序好像沒有問題,最后 i 的值是 1。但是為了提高性能,編譯器和處理器常常會在不改變數(shù)據(jù)依賴的情況下對指令做重排序。假設(shè)線程 A 在執(zhí)行時被重排序成先執(zhí)行代碼 2,再執(zhí)行代碼 1;而線程 B 在線程 A 執(zhí)行完代碼 2 后,讀取了 flag 變量。由于條件判斷為真,線程 B 將讀取變量 a。此時,變量 a 還根本沒有被線程 A 寫入,那么 i 最后的值是 0,導(dǎo)致執(zhí)行結(jié)果不正確。那么如何程序執(zhí)行結(jié)果正確呢?這里仍然可以使用 volatile 關(guān)鍵字。


這個例子中, 使用 volatile 不僅保證了變量的內(nèi)存可見性,還禁止了指令的重排序,即保證了 volatile 修飾的變量編譯后的順序與程序的執(zhí)行順序一樣。那么使用 volatile 修飾 flag 變量后,在線程 A 中,保證了代碼 1 的執(zhí)行順序一定在代碼 2 之前。


3. as-if-serial語義


不管怎么重排序,單線程下程序的執(zhí)行結(jié)果不能被改變。編譯器、runtime和處理器都必須遵守as-if-serial語義。為了遵守as-if-serial語義,編譯器和處理器不會對存在數(shù)據(jù)依賴關(guān)系的操作做重排序,因?yàn)檫@種重排序會改變執(zhí)行結(jié)果。如果操作之間不存在數(shù)據(jù)依賴關(guān)系,這些操作就可能被編譯器和處理器重排序。


4. happens-before原則


只靠sychronized和volatile關(guān)鍵字來保證原子性、可見性以及有序性,那么編寫并發(fā)程序可能會顯得十分麻煩。幸運(yùn)的是,從JDK 5開始,Java使用新的JSR-133內(nèi)存模型,提供了happens-before 原則來輔助保證程序執(zhí)行的原子性、可見性以及有序性的問題,它是判斷數(shù)據(jù)是否存在競爭、線程是否安全的依據(jù),happens-before 原則內(nèi)容如下:


  1. 程序順序原則:即在一個線程內(nèi)必須保證語義串行性,也就是說按照代碼順序執(zhí)行。

  2. 鎖規(guī)則:解鎖(unlock)操作必然發(fā)生在后續(xù)的同一個鎖的加鎖(lock)之前,也就是說,如果對于一個鎖解鎖后,再加鎖,那么加鎖的動作必須在解鎖動作之后(同一個鎖)。

  3. volatile規(guī)則:volatile變量的寫,先發(fā)生于讀,這保證了volatile變量的可見性,簡單的理解就是,volatile變量在每次被線程訪問時,都強(qiáng)迫從主內(nèi)存中讀該變量的值,而當(dāng)該變量發(fā)生變化時,又會強(qiáng)迫將最新的值刷新到主內(nèi)存,任何時刻,不同的線程總是能夠看到該變量的最新值。

  4. 線程啟動規(guī)則:線程的start()方法先于它的每一個動作,即如果線程A在執(zhí)行線程B的start方法之前修改了共享變量的值,那么當(dāng)線程B執(zhí)行start方法時,線程A對共享變量的修改對線程B可見

  5. 傳遞性:A先于B ,B先于C 那么A必然先于C

  6. 線程終止規(guī)則:線程的所有操作先于線程的終結(jié),Thread.join()方法的作用是等待當(dāng)前執(zhí)行的線程終止。假設(shè)在線程B終止之前,修改了共享變量,線程A從線程B的join方法成功返回后,線程B對共享變量的修改將對線程A可見。

  7. 線程中斷規(guī)則:對線程 interrupt()方法的調(diào)用先行發(fā)生于被中斷線程的代碼檢測到中斷事件的發(fā)生,可以通過Thread.interrupted()方法檢測線程是否中斷。

  8. 對象終結(jié)規(guī)則:對象的構(gòu)造函數(shù)執(zhí)行,結(jié)束先于finalize()方法


5. 內(nèi)存屏障


volatile關(guān)鍵字另一個作用就是禁止指令重排優(yōu)化,從而避免多線程環(huán)境下程序出現(xiàn)亂序執(zhí)行的現(xiàn)象,關(guān)于指令重排優(yōu)化前面已詳細(xì)分析過,這里主要簡單說明一下volatile是如何實(shí)現(xiàn)禁止指令重排優(yōu)化的。先了解一個概念,內(nèi)存屏障(Memory Barrier)。


內(nèi)存屏障,又稱內(nèi)存柵欄(Barrier),是一個CPU指令,它的作用有兩個:


  • 如果在指令間插入一條Memory Barrier則會告訴編譯器和CPU,不管什么指令都不能和這條Memory Barrier指令重排序,也就是說禁止在內(nèi)存屏障前后的指令執(zhí)行重排序優(yōu)化。

  • 強(qiáng)制刷出各種CPU的緩存數(shù)據(jù),因此任何CPU上的線程都能讀取到這些數(shù)據(jù)的最新版本


6. JMM提供的4種內(nèi)存屏障指令


由于硬件層面的內(nèi)存屏障的實(shí)現(xiàn),不同的硬件架構(gòu),對應(yīng)有不同的機(jī)器指令。JMM為了屏蔽了這種底層硬件平臺的差異,提供了四類內(nèi)存屏障指令,來為不同的硬件架構(gòu)生成相應(yīng)的內(nèi)存屏障的機(jī)器碼。



7. volatile的內(nèi)存語義及其實(shí)現(xiàn)


volatile關(guān)鍵字的內(nèi)存語義如下:


  • 【可見性】保證被volatile修飾的共享變量對所有線程總數(shù)可見的,也就是當(dāng)一個線程修改了一個被volatile修飾共享變量的值,新值總是可以被其他線程立即得知。

  • 【有序性】禁止指令重排序優(yōu)化。


Java編譯器會在生成指令系列時在適當(dāng)?shù)奈恢脮迦雰?nèi)存屏障指令來禁止特定類型的處理器重排序。為了實(shí)現(xiàn)volatile內(nèi)存語義,JMM針對編譯器制定的volatile重排序規(guī)則表



舉例來說,第二行最后一個單元格的意思是:在程序中,當(dāng)?shù)谝粋€操作為普通變量的讀或?qū)憰r,如果第二個操作為volatile寫,則編譯器不能重排序這兩個操作。


從上圖可以看出:


  • 當(dāng)?shù)诙€操作是volatile寫時,不管第一個操作是什么,都不能重排序。這個規(guī)則確保volatile寫之前的操作不會被編譯器重排序到volatile寫之后。

  • 當(dāng)?shù)谝粋€操作是volatile讀時,不管第二個操作是什么,都不能重排序。這個規(guī)則確保volatile讀之后的操作不會被編譯器重排序到volatile讀之前。

  • 當(dāng)?shù)谝粋€操作是volatile寫,第二個操作是volatile讀或?qū)憰r,不能重排序。


為了實(shí)現(xiàn)volatile的內(nèi)存語義,編譯器在生成字節(jié)碼時,會在指令序列中插入內(nèi)存屏障來禁止特定類型的處理器重排序。對于編譯器來說,發(fā)現(xiàn)一個最優(yōu)布置來最小化插入屏障的總數(shù)幾乎不可能。為此,JMM采取保守策略。下面是基于保守策略的JMM內(nèi)存屏障插入策略。


  • 在每個volatile寫操作的前面插入一個StoreStore屏障。禁止上面的普通寫和下面的volatile寫重排序。

  • 在每個volatile寫操作的后面插入一個StoreLoad屏障。防止上面的volatile寫與下面可能有的volatile讀/寫重排序。

  • 在每個volatile讀操作的后面插入一個LoadLoad屏障。禁止上面的volatile讀和下面所有的普通讀操作重排序。

  • 在每個volatile讀操作的后面插入一個LoadStore屏障。禁止上面的volatile讀和下面所有的普通寫操作重排序。


上述內(nèi)存屏障插入策略非常保守,但它可以保證在任意處理器平臺,任意的程序中都能得到正確的volatile內(nèi)存語義?!驹诶斫?種屏障指令的含義,應(yīng)該也容易理解為什么要這么插入。之后也會有例子來幫助理解】


下面是保守策略下,volatile寫插入內(nèi)存屏障后生成的指令序列示意圖



上圖中StoreStore屏障可以保證在volatile寫之前,其前面的所有普通寫操作已經(jīng)對任意處理器可見了。這是因?yàn)镾toreStore屏障將保障上面所有的普通寫在volatile寫之前刷新到主內(nèi)存。


這里比較有意思的是,volatile寫后面的StoreLoad屏障。此屏障的作用是避免volatile寫與 后面可能有的volatile讀/寫操作重排序。因?yàn)榫幾g器常常無法準(zhǔn)確判斷在一個volatile寫的后面 是否需要插入一個StoreLoad屏障(比如,一個volatile寫之后方法立即return)。為了保證能正確 實(shí)現(xiàn)volatile的內(nèi)存語義,JMM在采取了保守策略:在每個volatile寫的后面,或者在每個volatile 讀的前面插入一個StoreLoad屏障。從整體執(zhí)行效率的角度考慮,JMM最終選擇了在每個 volatile寫的后面插入一個StoreLoad屏障。因?yàn)関olatile寫-讀內(nèi)存語義的常見使用模式是:一個 寫線程寫volatile變量,多個讀線程讀同一個volatile變量。當(dāng)讀線程的數(shù)量大大超過寫線程時,選擇在volatile寫之后插入StoreLoad屏障將帶來可觀的執(zhí)行效率的提升。從這里可以看到JMM 在實(shí)現(xiàn)上的一個特點(diǎn):首先確保正確性,然后再去追求執(zhí)行效率。


下圖是在保守策略下,volatile讀插入內(nèi)存屏障后生成的指令序列示意圖



上圖中LoadLoad屏障用來禁止處理器把上面的volatile讀與下面的普通讀重排序。LoadStore屏障用來禁止處理器把上面的volatile讀與下面的普通寫重排序。


上述volatile寫和volatile讀的內(nèi)存屏障插入策略非常保守。在實(shí)際執(zhí)行時,只要不改變 volatile寫-讀的內(nèi)存語義,編譯器可以根據(jù)具體情況省略不必要的屏障。、


下面通過具體的示例代碼進(jìn)行說明。


class VolatileBarrierExample {
       int a;
       volatile int v1 = 1;
       volatile int v2 = 2;
       void readAndWrite() {
           int i = v1; // 第一個volatile讀
           int j = v2; // 第二個volatile讀
           a = i + j; // 普通寫
           v1 = i + 1; // 第一個volatile寫
          v2 = j * 2; // 第二個 volatile寫
       }
}


針對readAndWrite()方法,編譯器在生成字節(jié)碼時可以做如下的優(yōu)化。



注意,最后的StoreLoad屏障不能省略。因?yàn)榈诙€volatile寫之后,方法立即return。此時編 譯器可能無法準(zhǔn)確斷定后面是否會有volatile讀或?qū)?,為了安全起見,編譯器通常會在這里插 入一個StoreLoad屏障。


上面的優(yōu)化針對任意處理器平臺,由于不同的處理器有不同“松緊度”的處理器內(nèi)存模 型,內(nèi)存屏障的插入還可以根據(jù)具體的處理器內(nèi)存模型繼續(xù)優(yōu)化。以X86處理器為例,圖3-21 中除最后的StoreLoad屏障外,其他的屏障都會被省略。


前面保守策略下的volatile讀和寫,在X86處理器平臺可以優(yōu)化成如下圖所示。前文提到過,X86處理器僅會對寫-讀操作做重排序。X86不會對讀-讀、讀-寫和寫-寫操作 做重排序,因此在X86處理器中會省略掉這3種操作類型對應(yīng)的內(nèi)存屏障。在X86中,JMM僅需 在volatile寫后面插入一個StoreLoad屏障即可正確實(shí)現(xiàn)volatile寫-讀的內(nèi)存語義。這意味著在 X86處理器中,volatile寫的開銷比volatile讀的開銷會大很多(因?yàn)閳?zhí)行StoreLoad屏障開銷會比較大)。



四. 阿里巴巴Java開發(fā)手冊對餓漢式單例模式的規(guī)范


public class DoubleCheckLock {
    // 阿里巴巴Java開發(fā)手冊建議在該變量前加上volatile修飾
    private volatile static DoubleCheckLock instance;
 
    private DoubleCheckLock(){}
 
    public static DoubleCheckLock getInstance(){
        //第一次檢測
        if (instance==null){
            //同步
            synchronized (DoubleCheckLock.class){
                if (instance == null){
                    //多線程環(huán)境下可能會出現(xiàn)問題的地方
                    instance = new  DoubleCheckLock();
                }
            }
        }
        return instance;
    }
}





出處:https://blog.csdn.net/qq_43290318/article/details/115588218









關(guān)注GitHub今日熱榜,專注挖掘好用的開發(fā)工具,致力于分享優(yōu)質(zhì)高效的工具、資源、插件等,助力開發(fā)者成長!







點(diǎn)個在看 你最好看



瀏覽 44
點(diǎn)贊
評論
收藏
分享

手機(jī)掃一掃分享

分享
舉報
評論
圖片
表情
推薦
點(diǎn)贊
評論
收藏
分享

手機(jī)掃一掃分享

分享
舉報

感谢您访问我们的网站,您可能还对以下资源感兴趣:

国产秋霞理论久久久电影-婷婷色九月综合激情丁香-欧美在线观看乱妇视频-精品国avA久久久久久久-国产乱码精品一区二区三区亚洲人-欧美熟妇一区二区三区蜜桃视频 激情五月天av| 天堂网AV在线| 中文字幕免费av| 欧美高清久久| 日韩无码网站| 中文无码熟妇人妻AV在线| 337p西西人体大胆瓣开下部| 极品美鮑20p| 欧美性猛交XXXXⅩXX| 亚洲精品视频在线观看免费| 干欧美美女| 99精品视频免费观看| 激情性爱五月天| 澳门免费毛片| 中文字幕成人在线观看| 蜜桃视频com.www| 国产精品久久77777| 国产成人无码区免费视频| 日韩操比| 中文字幕亚洲日韩| 七十路の高齢熟妇无码| 无码99| 日韩成人高清| 亚洲免费成人电影| 91无码人妻精品一区二区三区四| 欧美福利电影| 麻豆精品国产| 国精品无码人妻一区二区三区免费| 中文字幕av在线观看| 操逼大香蕉| 国产日韩在线视频| 日本毛片在线观看| 日韩三级一区| 久久国产热视频| 免费看黄色AV| 高清无码视频免费看| 亚洲成人动漫在线| 日韩无码人妻系列| 青草成人在线视频| 人人操碰成人网| 免费v片| 麻豆国产91在线播放| 免费乱伦| 欧美性爱一区二区三区| 在线成人免费视频| 91九色在线| а√在线中文8| 熟妇熟女一区二区三区| 操美女视频网站| 操熟女视频| 99成人在线视频| 影音先锋久久久久AV综合网成人| 亚洲色婷婷久久精品AV蜜桃| 黄色福利网址| 成人色播播| 狼人社區91國產精品| 在线观看中文字幕| 国产福利视频在线| 国产操屄视频| 一本道无码在线观看| 豆花成人社区,视频| 无码精品人妻一区二区三刘亦菲| 亚洲AV男人天堂| 日韩午夜成人电影| 无码成人A片在线观看| 精品成人一区二区三区| 欧美成人免费电影| 老熟妇一区二区三区啪啪| 刘玥一区二区三区| 成人免费视频国产在线观看| 亚洲成人性爱视频| 成人小视频在线| 台湾无码片| 欧美日韩一区二区三区四区| 韩国成人无码| 亚洲欧美成人视频| 成人做爰黄A片免费| 亚洲AV人人夜夜澡人人| 色欲成人网| 日韩一级二级| www.婷婷五月天| 亚洲人免费视频| 最好看的MV中文字幕国语电影| 青娱乐偷窥成| 亲子伦一区二区三区观看方式| 成人做爰A片一区二区| 97大香蕉在线视频| 欧洲成人在线播放| 波多野结衣在线网站| 香蕉视频a| 人人干人人澡| 99re在线观看观看这里只有精品| 青草中文娱乐网在线| 91狠狠综| 久久久久久无码精品亚洲日韩麻豆| 午夜福利成人视频| 超碰免费99| 欧美日韩中文字幕| 91麻豆精品国产91久久久吃药 | 色四播播| 四虎精品一区二区| 亚洲深夜福利| 亚洲精品综合| 亚洲无码视频一区二区| 欧美日韩亚洲另类| 亚洲日韩精品中文字幕| 国产夫妻自拍AV| 婷婷五月免费视频| A片一级片| 国产成人午夜精品无码区久久麻豆 | 亚洲无码专区在线观看| 五月天婷婷网址| 五月丁香啪啪| 亚洲无码一本道| 国产午夜精品一区二区三区四区| 中文人妻| 99免费观看视频| 一级a一级a免费观看免免黄‘/| 欧美日韩在线免费观看| 一本一道伊人99久久综| 国产一级生活片| 91精品久久香蕉国产线看观看| 三级无码片| 国产伊人自拍| 777777视频| 天天免费视频| 国产一区在线观看视频| 国产成人秘一区二区三区东京热 | 91欧美性爱| 精产国品一区二区| 91综合视频| 亚洲综合成人网| 亚洲国产高清国产精品| 就要操| 日日碰日日摸| 日韩中文字幕在线人成网站| 狼友视频免费| av无码在线观看| 欧美一级特黄A片免费看| 国产色拍| 97精品人妻麻豆一区二区| 国产高清免费视频| 乖我硬了让老子cao你小视频| 一级a片免费| 亚洲国产成人在线| 五月天操逼网| 北京熟妇槡BBBB槡BBBB| 一级黄视频| 91白丝喷水自慰网站| 久草福利| 免费无码成人片在线播放| 黄色视频导航| 国产成人片在线观看| 综合成人在线| 无码一区二区三区免费| 国精产品一品二品国精| 艹逼在线观看| 中文字幕乱码在线| 汇聚全球淫荡熟女| 久久人人爱| а√在线中文8| 久视频在线观看| 韩国午夜福利视频| 九九99久久| 久久久亚洲熟妇熟女| 久久精品视频9| 成人黄色AV网站| 11孩岁女精品A片BBB| 91精品国产综合久久久蜜臀酒店| 免费操B| 成人H动漫精品一区二区无码| 69成人精品视频| 蜜桃av秘无码一区三区四| 欧美色图综合网| 熟女少妇一区二区三区| 日韩欧美黄色电影| 丝袜足交视频在线观看| 黄色日逼视频| 婷婷精品视频| 国产成人精| 亚久久| 久久综合在线| 国产一区二区波多野结衣| 国产伦精品一区二区三区妓女 | 波多野结衣无码一区| 亚洲国产精品成人va在线观看 | 躁BBB躁BBB添BBBBBB| 欧美精品一卡二卡| 午夜操逼逼| 好吊AV| 无码精品ThePorn| 日本爽妇网| 国产一级片电影| 丁香视频在线观看| 亚洲视频一区二区三区| 人人操人人操人人操| 无码人妻精品一区二区三区蜜臀百度 | а√天堂中文最新版8| 99精品视频在线| 中国老女人操逼| 狠狠一区| www.17c嫩嫩草色蜜桃网站| 无码99| 大香久久| 无码成人精品| 国产一级a一片成人AV| 丰满熟妇人妻无码视频| 91嫖妓站街按店老熟女| 激情婷婷丁香| 久久久久久无码精品亚洲日韩麻豆| 久久黄色视频免费看| 欧美91熟| AV性爱社区| 日本操逼在线播放| 国产亚洲AV| 久草天堂| 亚洲中文av| 黄色国产| 中文字幕视频在线观看| 国产无码网站| 国产精品秘久久久久久免费播放| 国产精品9| 天天艹逼| 91牛| 人人草人人干| 亚洲日韩精品中文字幕| 先锋AV资源| 日韩国产在线| 99re| 婷婷色色婷婷五月天| 国产黄色电影在线观看| 色男人天堂| 精品国产va久久久久久| 丝袜诱惑AV| 撸撸操在线视频观看只有精品| 麻豆免费版在线观看| 久久久精品影院| 97人妻碰碰中文无码久热丝袜| 北条麻妃一区二区三区在线观看| 中文字幕码精品视频网站| 五月天久久久久久| 西西444WWW无码视频软件| 亚洲影院第一页| 亚洲成人动漫在线| 中文字幕在线视频无码| 草b在线| 国产八区| 欧美久久大香蕉| 日韩爱爱免费视频| 免费看成人A片无码照片88hⅤ| 草逼视频网| 精品一区二区三区免费毛片| 97久久久| 欧美一区二区在线观看| 日韩精品欧美一区二区三区| 午夜操爽| 欧美裸体视频| 中文字幕国产在线观看| 3D动漫精品啪啪一区二区竹笋| 97人人人人人人| 91丨牛牛丨国产| 张柏芝BBw搡BBBB槡BBBBHDfree | aaa成人| 黄色无遮挡| 中文字幕免费在线播放| 国产中文字幕在线视频| 久操综合| 高清无码学生妹| 婷婷五月18永久免费视频| 台湾AV在线| www国产在线| 精品人伦一区二区三区| 再深点灬好爽灬轻点久久国产| 三级片91| 欧美成人黄色电影| 奇米四色秒播| 久草香蕉| 91精彩视频在线观看| 毛片操逼视频| 三级片91| 无码人妻一区二区三区免费九色| 国产人成视频免费观看| 免费观看黄片视频| 熟女在线视频| 日韩精品中文字幕无码| 日本A片在线观看| 国产人妻一区二区三区欧美毛片| 午夜无码久久| 国产高清无码一区| 成人无码区免费A片久久| 伊人久艹| 激情一一区二区三区| 九九成人免费视频| 国产又爽又黄免费网站在| 欧美日韩一区二区在线观看| 特级西西人体大胆无码| 91激情在线| 成人福利视频在线| 少妇推油呻吟白浆啪啪成人片 | 日韩精品成人专区无码| 超碰v| 久久精品999| 99久| 97爱爱| 国产高清精品在线| 人人操人人摸人人爽| 最新国产在线| 免费播放片色情A片| 欧美A片免费观看| 日韩欧美黄色电影| 黄色视频在线免费播放| 欧洲精品码一区二区三区免费看| 久操B网| 成人网站www污污污网站公司| 91精品大屁股白浆自慰久久久| 亚洲综合色网| 久久久精品999| 亚洲三级毛片| 激情综合婷婷| 五月丁香六月久久| 日本一级特黄大片AAAAA级 | 高清无码免费在线观看| 欧美国产日韩视频| 九九综合伊人7777777| 欧美国产日韩在线| 青青青在线| h视频在线观看网站| 亚洲午夜久久久久久久久红桃| 亚洲无码免费看| 91精品国产亚洲| 伊人大香蕉综合在线| 超碰久热| 撸撸综合网| 成人性爱在线播放| 亚洲AV成人无码精在线| 国产精品扒开腿| 国产高潮白浆喷| 亚洲成人视频网站| 欧美日逼视频| 国产免费av在线| 无码人妻一区二区三区免费n鬼沢| 四川美女网久草| 超碰青青青| 91av在线免费观看| 中国1级毛片| 日本内射在线播放| 伊人无码视频| 91成人免费在线观看| 99视频精品全部免费看| 日韩A片一级无码免费蜜桃| 精品国产香蕉| 欧美性爱视频在线观看| 午夜精品18码视频国产17c| a片在线观看视频| 亚洲人妻电影| 1024手机在线观看| 懂色av蜜臀av粉嫩av分享| 黄色视频在线观看18| 牛牛在线精品视频| 国产精品99久久久久的广告情况| 亚洲中文字幕无码爆乳av| 成人综合网站| 久草视频在线播放| 久久成人福利| 欧美色交| 欧美日韩性色无码免费| 先锋影音一区二区| 91欧美黑人| 97人人澡| 国产又黄又爽| 中文字幕人妻丝袜二区电影| 黄色高清无码| 二级黄色视频| 丁香九月婷婷| 欧美三级不卡| 色婷婷在线免费视频| 国产精品视频一区二区三区在线观看 | 影音先锋国产av| 人人爽人人爽| 日韩无码AV一区二区三区| 六月色| 俄罗斯老熟妇与子伦| 国产激情精品| 97超碰自拍| 污网站免费在线观看| 骚BBBB槡BBB槡BBB| 高清无码一区二区三区四区| 老太色HD色老太HD.| 色婷婷色五月| 午夜免费福利视频| 天天操人妻| 午夜免费福利视频| 一区二区色| 久久夜色视频网| 在线观看免费黄色| 日韩成人无| 精品久久电影| 99久久精品一区二区成人| 91免费在线看| 国产精品欧美激情| 久久艹大香蕉| 成年人激情网| 色婷婷丁香五月天| 偷拍久久久| 在线看片a| 天天日天天操天天摸天天干天日射天天插 | 国产成人无码毛片| 日韩高清无码一区二区三区| 444444在线观看免费高清电视剧木瓜一 | 日韩综合久久| 伊人大香蕉婷婷| 射久久| 韩国三级HD久久精品| 久久99综合| 西西WWW888大胆无码| 欧美卡一卡二| 精品人妻一区二区三区在线视频不卡 | 亚洲性爱专区| 操逼视频国产91| 久久精品视频一区| 伊人在线成人视频| 亚洲精品无码中文字幕| 97精产国品久久蜜桃臀| 婷婷五月丁香网| 国产三级精品三级在线观看| AV一区二区三区| 99er在线视频| 级婬片AAAAAAA免费| AAA免费视频| 宅男噜噜噜66一区二区| 国产操逼视频| 中文无码一区二区三区| 青青成人视频| 亚洲色图偷拍| 国产一级二级视频| 一区二区小视频| 日韩黄色小说| 日韩成人黄片| 爱逼爱操| 成人在线视频免费| 夜夜操天天日| 天天操夜夜操视频免费高清| 污视频免费在线观看| 一级a免一级a做片免费| 久久久久久亚洲精品| 一区二区三区无码在线| 青草一区| 天天天做夜夜夜夜爽无码| 大香焦久久| 91香蕉国产视频| 做爱网站在线观看| 伊人无码视频| 四个熟妇搡BBBB搡BBBB| 日本亚洲视频| 久久久三级片| 国产色色色色| 少妇人妻AV| 欧洲肥胖BBBBBBBBBB| 亚洲视频免费看| 亚洲性爱在线视频| 久久久久久免费一级A片| 国产三级片视频| 一道本无码一区| 欧美级黑寡妇毛片app| 日本色色网站免费| 做爱网| 中文字幕aV在线| 欧美XX888做受| 色呦呦一欧美| 人妻无码一区二区三区摄像头| 国产成人精品无码| 三级毛片网站| 国产在线观看免费视频今夜| 色xxxx| 国产美女AV| 最新亚洲中文字幕| 亚洲国产熟妇综合色专区| 一本色道久久综合亚洲精品久久 | 91AV一区二区三区| 黄色视频在线观看亚洲一区二区三区免费 | 秋霞网一区二区| 樱桃码一区二区三区| 欧美婷婷五月天| 美日韩一区二区三区| 人人摸人人操人人爱| 日本操B久久| 九九九精彩视频| 最近中文字幕在线| 无码成人在线| 操b视频免费| 翔田千里无码在线观看| 国产精品9| 亚洲天堂男人| 成人网站免费视频| 人人看人人插| 白嫩无码| 欧美午夜精品一区二区蜜桃| 亚洲成人在线免费观看| 欧美亚洲中文字幕| 天天夜夜操操| 丁香五月天激情网| 精品AV国产| 亚洲中文视频| 久草小视频| 翔田AV无码秘三区| 91社成人影院| 偷拍久久久| 天堂无码高清| 97资源视频| 欧美视频操逼| 中文字幕在线观看av| AV网站在线播放| 亚洲A网| 大炕上公让我高潮了六次| 国产在线拍揄自揄拍无码男男| 黄色视频免费观看| 久久国产黄色一级片| 日韩黄色毛片| 国产高清无码自拍| 天天日天天干天天干| 在线无码不卡| 无码人妻丰满熟妇区蜜桃| 欧美日韩婷婷| 国产AV二区| 午夜免费福利视频| 第四色网站| 韩国中文字幕HD久久精品| 精品乱伦| 日韩人妻精品中文字幕| 国产一区二区在线视频| 日韩视频无码| 69国产| 91久久香蕉囯产熟女线看蜜桃| 青青视频网| 蜜桃操逼| 久久精品视频一区| 狠狠干综合网| 久久免费成人| 亚洲无码操逼视频| 蜜桃Av| 国产午夜91人妻| 亚洲免费网站| 亚洲成人自拍| 国产福利视频在线观看| 操B在线| 国产熟妇| 亚洲国产成人精品女人| 中文字幕在线一区| 91狠狠综合久久| 欧美性爱小说| 91久久欧美极品XXXXⅩ| 91精品福利| 蜜桃精品视频| 欧美一级在线| 日韩在线视频免费观看| 一级AA片| 伊人黄色| 91乱伦| 加勒比DVD手机在线播放观看视频 日韩精品一区二区三区四区蜜桃视频 | 精品人妻无码一区二区三区 | 亚洲AV无码成人精品区天堂小说 | 国产高清在线免费观看AV片| 日本少妇激情视频| 亚洲99热| 亚洲成人视频一区二区| 久久久精品在线| 91色色色色| 亚洲色图自拍| 免费黄片在线| 日本做爱视频| 久久午夜一级A片| 日本一区二区三区免费观看| 影音先锋av资源网站| 91性爱网| 国产精品V| 精品婷婷| 国产精品一二三区| 色婷婷久久| 2025最新国产精品每日更新| 婷婷激情丁香五月天| 操美女嫩逼| 女人18片毛片60分钟翻译| 中国毛片视频| 无码免费在线观看视频| 一区二区三区网站| 能看的AV网站| 人人肏| 插菊综合网| 天天做天天干| 开心色色五月天| 国产激情123区| 日韩无码乱码| 日本视频免费| 国产乱码一区二区三区的区别| 日本少妇BBW| 自拍偷拍成人视频| 蜜桃精品视频| 男女日日批黄色三级| 超碰a片| 少婦揉BBBB揉BBBB揉| 蜜臀久久久99久久久久久久| 欧美亚洲日韩一区二区三区| 国产毛片基地| 夜夜国自一区| 亚洲天堂av在线观看| 嫩BBB搡BBBB搡BBBB| 国产xxxx视频| 日韩人妻av| 亚洲天堂男人| 欧美a在线| 中文字幕在线观看a| 大鸡巴伊人| 天堂在线观看av| jizz国产精品| 国产av天堂| 国产曰韩欧美综合另类在线| 日韩最新高清无码| AⅤ在线观看| 在线观看日韩AV| 久久草在线观看| 国产熟女一区二区视频网站 | 国产精品久久AV电影| 大鸡巴操B视频| AV大片在线观看| 做爰视频毛片蜜桃| 久久爆乳一区二区三区| 在线综合国产欧美| 亚洲午夜久久| 婷婷丁香一区二区三区| 欧美国产日韩在线| 西西掰穴| 久草大香蕉在线| 探花在线综合| 一道本一区| 阿宾MD0165麻豆沈娜娜| 国产3p露脸普通话对白| 亚洲在线第一页| 99热中文| 日本三级片在线动| 久草视频在线免费播放| 大香蕉三级| 国产成人精品一区二区三区在线 | 免费乱伦| 中文字幕在线观看a| 天堂a在线8| 成人做爰100片免费观看视频| 在线午夜福利| 亚洲天堂无码| 99热官方网站| 天堂а√在线中文在线新版| 亚洲天堂在线免费观看| 西西444WWW无码视频软件| 人妻无码久久精品| 亚洲AV男人天堂| 国产精品怡红院有限公司| 操逼123首页| 黄色毛片电影| 亚洲AV在线人妻| 中文字幕精品一级A片| 国产精品无码天天爽视频| 在线观看中文字幕| 伊人久久AV| 五月天开心网| BBWBBw嫩| 淫香淫色天天影视| 国产理论电影在线观看| 加勒比在线视频| 欧美日韩在线视频免费| 国产色情在线| 四虎在线视频观看96| 在线观看视频无码| 在线观看高清无码视频| 亚洲无码你懂的| 人人操人人操人人操人人| 蝌蚪窝视频在线观看| 人妻少妇精品视频一区二区三区| 密臀av在线| 国产三级视频| 国产精品资源在线观看| 人人妻人人澡人人爽人人爽| 国产免费视频| 亚洲AV无码成人精品区www | 国产无码一区二区| 黄色一级大片在线免费看产| 自拍偷拍欧美| 久久久国产一区二区三区| 蜜桃操逼| 欧美色网| 亚洲日韩国产成人精品久久| 日韩AV小说| 婷婷视频导航| 日韩大香蕉在线| 国产欧美一区二区人妻喷水| 日本一级黄色A片| 嫩BBB槡BBBB槡BBB| 精品视频免费在线观看| 玖玖国产| 免费AV网站在线| 欧美日韩在线视频播放| 国产一区二区久久| 久久色资源| а√天堂中文最新版8| 午夜69成人做爱视频网站| 一区二区精品| 亚洲人成电影网| 91传媒在线观看| 五月天婷婷无码| 无码人妻一区二区三区| 18禁网站在线播放| 女人一级A片色黄情免费| 无码三级在线播放| 97自拍视频| 国产精品操逼网站| 国产高清无码一区二区三区| 91国视频| 亚洲精品无码电影| 刘玥精品A片在线观看| 一区二区三区无码免费| 五月天无码av| 伊人影院在线视频| 亚洲人做受| 奇米狠狠色| 无码天天| 狠狠一区| 十八无码成人免费网站| 強姧伦一区二区三区在线播放| 欧美高清一区二区| 草逼网站| 欧美群交videotv群交| www.黄片| 99热最新国产| 操比一区| 97日韩| 日韩av一级| 国产欧美综合视频| 亚洲成人AV| 欧美色图第一页| 韩国三级HD久久精品| 玩弄大乳乳妾高潮乳喷视频| 激情无码一区二区| 亚洲色情在线播放| 在线午夜福利| 国产欧美日韩一区| 91精品久久久久久久| 亚洲午夜精品成人毛片| 成人免费视频性爱| 国产亚洲日韩在线| 苍井空一区二区三区四区| 中文字幕乱码人妻二区三区| 黄色一级视频在线观看| 中文字幕精品人妻在线| 久久在线精品| 乱伦乱伦乱伦中文字幕| 国产丨熟女丨国产熟女视频| 老鸭窝成人视频| 麻豆天美传媒AV果冻传媒| 黑巨茎大战欧美白妞小说| 国产精品一区二区AV日韩在线| 欧美黄色免费看| 97AV视频| 国产51视频| 91小宝寻花一区二区三区三级| 国产aaaaaa| AV无码精品| 中文在线字幕免费观看电视剧大全| 亚洲婷婷AV| 伊人久久福利视频| 亚洲无码精品一区二区| 日韩一级在线免费观看| 国产激情无码| 中文字幕av一区二区| 免费在线a视频| 18禁黄网站| 3p绿帽黑人看自己老婆| 久久先锋| 国产成人精品八戒| 99精品久久久久久无码| 五月天福利影院| 久草蜜臀| 五月激情六月丁香| 免费在线观看视频黄| 亚洲精品鲁一鲁一区二区三区| 成人A片一级| 色碰碰| 在线a视频免费观看| 91欧美黑人| 成人激情五月天| 麻豆精品秘国产| 无码日逼视频| 91人人澡人人爽人人看| 黄片小视频在线观看| 影音先锋AV无码| 少妇人妻偷人精品无码视频新浪| 日韩一级在线播放| 国产毛片一区| 日韩AV成人无码久久电影| 国产精品久久777777| 2019天天干| www.操操操| 丰满人妻一区二区三区精品高清| 先锋影音资源站| 免费无码毛片| 日韩三级久久| 日韩porn| 国产欧美精品在线观看| 动漫3d啪啪成人h动漫| 91久久爱| 日本熟妇无码一区二区| 久久无码影院| 久久中文网| 18毛片| wwwAV在线观看| 中文字幕一区二区三区人妻电影| 奇米影视色偷偷| 久久伊| 大荫蒂hd大荫蒂视频| 成人精品秘免费波多野结衣| 国产午夜成人视频| 色四播播| 狠狠躁日日躁夜夜躁A片无码视频 强伦轩一区二区三区四区播放方式 | 兔子先生和優奈玩游戲脫衣服,運氣報表優奈輸到脫精光 | 第一福利视频| 亚洲激情自拍| 东北骚妇大战黑人视频| 五月天毛片| 黄色片免费| 国产欧美精品一区二区| 亚洲欧美日韩色图| 五月天三级片| 国产a片免费观看| 亚洲人成777| 丝袜人妻被操视频| 女人天堂AV| 亚洲综合免费观看高清完整版 | 97综合视频| 日韩黄色激情| 丁香婷婷久久久综合精品国产 | 免费看A片视频| 亚洲福利天堂| 38D蜜桃臀| 人妻少妇视频| 亚洲精品资源| 欧洲操逼视频| 精品欧美乱码久久久久久| 国产不卡在线视频| 超碰蜜桃| 日韩少妇AV| 欧美爱爱视屏| 欧美久草蜜桃视频| 亚洲精品一区无码A片丁香花| 五月婷婷综合网| 日本精品视频在线观看| 中文字幕在线有码| 亚洲V国产v欧美v久久久久久| 国产一级片网站| 69成人天堂无码免费| 久久视频免费在线观看| 国产精品中文字幕在线观看| 人人av在线| V天堂在线视频| 色婷操逼| 中文字幕日韩无码电影| 精品乱子伦一区二区三区,亚洲国产成| 日韩精品第一页| 人人操人人摸人人爱| 久久久久久久久久国产| www.a片| 乱伦激情| 99做爱| 欧日韩在线| 91在线永久| 亚欧一区二区| 自拍偷拍视频网| 亚洲日韩精品无码| 日韩黄色电影视频| 九九五月天| 狠狠插网站| 日本黄色视频大全| 欧美黄色免费在线观看| 色综合色综合色综合| 国产精品无码无套在线照片| 国产日韩欧美91| 撸一撸免费视频| 熟女高潮| 特级西西西88大胆无码| 日本黄色高清视频| 日韩中文字幕av在线| 国产亚洲成人综合| 一级特黄色片| 在线观看内射视频| 人人澡超碰碰| 91无码高清| 美女自慰网站免费| 成人大香蕉网| 日韩操逼网站| 又紧又嫩又爽无遮挡免费| 欧美香蕉| 日韩色情片| 日逼视频免费看| 一本色道久久综合亚洲精东小说|