久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

您的位置:首頁技術文章
文章詳情頁

深入理解Java 線程池

瀏覽:85日期:2022-08-28 15:15:16

線程的使用在java中占有極其重要的地位,在jdk1.4極其之前的jdk版本中,關于線程池的使用是極其簡陋的。在jdk1.5之后這一情況有了很大的改觀。Jdk1.5之后加入了java.util.concurrent包,這個包中主要介紹java中線程以及線程池的使用。為我們在開發中處理線程的問題提供了非常大的幫助。

線程池的作用:

線程池作用就是限制系統中執行線程的數量。 根據系統的環境情況,可以自動或手動設置線程數量,達到運行的最佳效果;少了浪費了系統資源,多了造成系統擁擠效率不高。用線程池控制線程數量,其他線程排隊等候。一個任務執行完畢,再從隊列的中取最前面的任務開始執行。若隊列中沒有等待進程,線程池的這一資源處于等待。當一個新任務需要運行時,如果線程池中有等待的工作線程,就可以開始運行了;否則進入等待隊列。

為什么要用線程池:

1.減少了創建和銷毀線程的次數,每個工作線程都可以被重復利用,可執行多個任務。

2.可以根據系統的承受能力,調整線程池中工作線線程的數目,防止因為消耗過多的內存,而把服務器累趴下(每個線程需要大約1MB內存,線程開的越多,消耗的內存也就越大,最后死機)。

Java里面線程池的頂級接口是Executor,但是嚴格意義上講Executor并不是一個線程池,而只是一個執行線程的工具。真正的線程池接口是ExecutorService。

比較重要的幾個類:

ExecutorService 真正的線程池接口。 ScheduledExecutorService 能和Timer/TimerTask類似,解決那些需要任務重復執行的問題。 ThreadPoolExecutor ExecutorService的默認實現。 ScheduledThreadPoolExecutor 繼承ThreadPoolExecutor的ScheduledExecutorService接口實現,周期性任務調度的類實現。

要配置一個線程池是比較復雜的,尤其是對于線程池的原理不是很清楚的情況下,很有可能配置的線程池不是較優的,因此在Executors類里面提供了一些靜態工廠,生成一些常用的線程池。

1. newSingleThreadExecutor

創建一個單線程的線程池。這個線程池只有一個線程在工作,也就是相當于單線程串行執行所有任務。如果這個唯一的線程因為異常結束,那么會有一個新的線程來替代它。此線程池保證所有任務的執行順序按照任務的提交順序執行。

2.newFixedThreadPool

創建固定大小的線程池。每次提交一個任務就創建一個線程,直到線程達到線程池的最大大小。線程池的大小一旦達到最大值就會保持不變,如果某個線程因為執行異常而結束,那么線程池會補充一個新線程。

3. newCachedThreadPool

創建一個可緩存的線程池。如果線程池的大小超過了處理任務所需要的線程,

那么就會回收部分空閑(60秒不執行任務)的線程,當任務數增加時,此線程池又可以智能的添加新線程來處理任務。此線程池不會對線程池大小做限制,線程池大小完全依賴于操作系統(或者說JVM)能夠創建的最大線程大小。

4.newScheduledThreadPool

創建一個大小無限的線程池。此線程池支持定時以及周期性執行任務的需求。

實例

1:newSingleThreadExecutor

MyThread.java

public class MyThread extends Thread { @Override public void run() { System.out.println(Thread.currentThread().getName() + '正在執行。。。'); } }

TestSingleThreadExecutor.java

public class TestSingleThreadExecutor { public static void main(String[] args) { //創建一個可重用固定線程數的線程池 ExecutorService pool = Executors. newSingleThreadExecutor(); //創建實現了Runnable接口對象,Thread對象當然也實現了Runnable接口 Thread t1 = new MyThread(); Thread t2 = new MyThread(); Thread t3 = new MyThread(); Thread t4 = new MyThread(); Thread t5 = new MyThread(); //將線程放入池中進行執行 pool.execute(t1); pool.execute(t2); pool.execute(t3); pool.execute(t4); pool.execute(t5); //關閉線程池 pool.shutdown(); } }

輸出結果:

pool-1-thread-1正在執行。。。

pool-1-thread-1正在執行。。。

pool-1-thread-1正在執行。。。

pool-1-thread-1正在執行。。。

pool-1-thread-1正在執行。。。

2: newFixedThreadPool

public class TestFixedThreadPool { publicstaticvoid main(String[] args) { //創建一個可重用固定線程數的線程池 ExecutorService pool = Executors.newFixedThreadPool(2); //創建實現了Runnable接口對象,Thread對象當然也實現了Runnable接口 Thread t1 = new MyThread(); Thread t2 = new MyThread(); Thread t3 = new MyThread(); Thread t4 = new MyThread(); Thread t5 = new MyThread(); //將線程放入池中進行執行 pool.execute(t1); pool.execute(t2); pool.execute(t3); pool.execute(t4); pool.execute(t5); //關閉線程池 pool.shutdown(); } }

輸出結果

pool-1-thread-1正在執行。。。

pool-1-thread-2正在執行。。。

pool-1-thread-1正在執行。。。

pool-1-thread-2正在執行。。。

pool-1-thread-1正在執行。。。

3: newCachedThreadPool

TestCachedThreadPool.java

publicclass TestCachedThreadPool { publicstaticvoid main(String[] args) { //創建一個可重用固定線程數的線程池 ExecutorService pool = Executors.newCachedThreadPool(); //創建實現了Runnable接口對象,Thread對象當然也實現了Runnable接口 Thread t1 = new MyThread(); Thread t2 = new MyThread(); Thread t3 = new MyThread(); Thread t4 = new MyThread(); Thread t5 = new MyThread(); //將線程放入池中進行執行 pool.execute(t1); pool.execute(t2); pool.execute(t3); pool.execute(t4); pool.execute(t5); //關閉線程池 pool.shutdown(); }}

輸出結果:

pool-1-thread-2正在執行。。。

pool-1-thread-4正在執行。。。

pool-1-thread-3正在執行。。。

pool-1-thread-1正在執行。。。

pool-1-thread-5正在執行。。。

4 newScheduledThreadPool

TestScheduledThreadPoolExecutor.java

publicclass TestScheduledThreadPoolExecutor { publicstaticvoid main(String[] args) { ScheduledThreadPoolExecutor exec = new ScheduledThreadPoolExecutor(1); exec.scheduleAtFixedRate(new Runnable() {//每隔一段時間就觸發異常 @Override publicvoid run() { //throw new RuntimeException(); System.out.println('================'); } }, 1000, 5000, TimeUnit.MILLISECONDS); exec.scheduleAtFixedRate(new Runnable() {//每隔一段時間打印系統時間,證明兩者是互不影響的 @Override publicvoid run() { System.out.println(System.nanoTime()); } }, 1000, 2000, TimeUnit.MILLISECONDS); }}

輸出結果

================

8384644549516

8386643829034

8388643830710

================

8390643851383

8392643879319

8400643939383

三:ThreadPoolExecutor詳解

ThreadPoolExecutor的完整構造方法的簽名是:ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue<Runnable> workQueue, ThreadFactory threadFactory, RejectedExecutionHandler handler) .

corePoolSize - 池中所保存的線程數,包括空閑線程。 maximumPoolSize-池中允許的最大線程數。 keepAliveTime - 當線程數大于核心時,此為終止前多余的空閑線程等待新任務的最長時間。 unit - keepAliveTime 參數的時間單位。 workQueue - 執行前用于保持任務的隊列。此隊列僅保持由 execute方法提交的 Runnable任務。 threadFactory - 執行程序創建新線程時使用的工廠。 handler - 由于超出線程范圍和隊列容量而使執行被阻塞時所使用的處理程序。 ThreadPoolExecutor是Executors類的底層實現。

在JDK幫助文檔中,有如此一段話:

“強烈建議程序員使用較為方便的Executors工廠方法Executors.newCachedThreadPool()(無界線程池,可以進行自動線程回收)、Executors.newFixedThreadPool(int)(固定大小線程池)Executors.newSingleThreadExecutor()(單個后臺線程)

它們均為大多數使用場景預定義了設置。”

下面介紹一下幾個類的源碼:

ExecutorService newFixedThreadPool (int nThreads):固定大小線程池。

可以看到,corePoolSize和maximumPoolSize的大小是一樣的(實際上,后面會介紹,如果使用無界queue的話maximumPoolSize參數是沒有意義的),keepAliveTime和unit的設值表名什么?-就是該實現不想keep alive!最后的BlockingQueue選擇了LinkedBlockingQueue,該queue有一個特點,他是無界的。

public static ExecutorService newFixedThreadPool(int nThreads) {return new ThreadPoolExecutor(nThreads, nThreads, 0L, TimeUnit.MILLISECONDS, new LinkedBlockingQueue<Runnable>()); }

ExecutorService newSingleThreadExecutor():單線程

public static ExecutorService newSingleThreadExecutor() { return new FinalizableDelegatedExecutorService (new ThreadPoolExecutor(1, 1, 0L, TimeUnit.MILLISECONDS, new LinkedBlockingQueue<Runnable>())); }

ExecutorService newCachedThreadPool():無界線程池,可以進行自動線程回收

這個實現就有意思了。首先是無界的線程池,所以我們可以發現maximumPoolSize為big big。其次BlockingQueue的選擇上使用SynchronousQueue。可能對于該BlockingQueue有些陌生,簡單說:該QUEUE中,每個插入操作必須等待另一個線程的對應移除操作。

public static ExecutorService newCachedThreadPool() { return new ThreadPoolExecutor(0, Integer.MAX_VALUE, 60L, TimeUnit.SECONDS,new SynchronousQueue<Runnable>()); }

先從BlockingQueue<Runnable> workQueue這個入參開始說起。在JDK中,其實已經說得很清楚了,一共有三種類型的queue。

所有BlockingQueue 都可用于傳輸和保持提交的任務。可以使用此隊列與池大小進行交互:

如果運行的線程少于 corePoolSize,則 Executor始終首選添加新的線程,而不進行排隊。(如果當前運行的線程小于corePoolSize,則任務根本不會存放,添加到queue中,而是直接抄家伙(thread)開始運行)

如果運行的線程等于或多于 corePoolSize,則 Executor始終首選將請求加入隊列,而不添加新的線程。

如果無法將請求加入隊列,則創建新的線程,除非創建此線程超出 maximumPoolSize,在這種情況下,任務將被拒絕。

queue上的三種類型。

排隊有三種通用策略:

直接提交。工作隊列的默認選項是 SynchronousQueue,它將任務直接提交給線程而不保持它們。在此,如果不存在可用于立即運行任務的線程,則試圖把任務加入隊列將失敗,因此會構造一個新的線程。此策略可以避免在處理可能具有內部依賴性的請求集時出現鎖。直接提交通常要求無界maximumPoolSizes 以避免拒絕新提交的任務。當命令以超過隊列所能處理的平均數連續到達時,此策略允許無界線程具有增長的可能性。 無界隊列。使用無界隊列(例如,不具有預定義容量的 LinkedBlockingQueue)將導致在所有 corePoolSize 線程都忙時新任務在隊列中等待。這樣,創建的線程就不會超過 corePoolSize。(因此,maximumPoolSize的值也就無效了。)當每個任務完全獨立于其他任務,即任務執行互不影響時,適合于使用無界隊列;例如,在 Web頁服務器中。這種排隊可用于處理瞬態突發請求,當命令以超過隊列所能處理的平均數連續到達時,此策略允許無界線程具有增長的可能性。 有界隊列。當使用有限的 maximumPoolSizes時,有界隊列(如 ArrayBlockingQueue)有助于防止資源耗盡,但是可能較難調整和控制。隊列大小和最大池大小可能需要相互折衷:使用大型隊列和小型池可以最大限度地降低 CPU 使用率、操作系統資源和上下文切換開銷,但是可能導致人工降低吞吐量。如果任務頻繁阻塞(例如,如果它們是 I/O邊界),則系統可能為超過您許可的更多線程安排時間。使用小型隊列通常要求較大的池大小,CPU使用率較高,但是可能遇到不可接受的調度開銷,這樣也會降低吞吐量。

BlockingQueue的選擇。

例子一:使用直接提交策略,也即SynchronousQueue。

首先SynchronousQueue是無界的,也就是說他存數任務的能力是沒有限制的,但是由于該Queue本身的特性,在某次添加元素后必須等待其他線程取走后才能繼續添加。在這里不是核心線程便是新創建的線程,但是我們試想一樣下,下面的場景。

我們使用一下參數構造ThreadPoolExecutor:

new ThreadPoolExecutor( 2, 3, 30, TimeUnit.SECONDS, new SynchronousQueue<Runnable>(), new RecorderThreadFactory('CookieRecorderPool'), new ThreadPoolExecutor.CallerRunsPolicy());

當核心線程已經有2個正在運行.

此時繼續來了一個任務(A),根據前面介紹的“如果運行的線程等于或多于 corePoolSize,則 Executor始終首選將請求加入隊列,而不添加新的線程。”,所以A被添加到queue中。 又來了一個任務(B),且核心2個線程還沒有忙完,OK,接下來首先嘗試1中描述,但是由于使用的SynchronousQueue,所以一定無法加入進去。 此時便滿足了上面提到的“如果無法將請求加入隊列,則創建新的線程,除非創建此線程超出maximumPoolSize,在這種情況下,任務將被拒絕。”,所以必然會新建一個線程來運行這個任務。 暫時還可以,但是如果這三個任務都還沒完成,連續來了兩個任務,第一個添加入queue中,后一個呢?queue中無法插入,而線程數達到了maximumPoolSize,所以只好執行異常策略了。

所以在使用SynchronousQueue通常要求maximumPoolSize是無界的,這樣就可以避免上述情況發生(如果希望限制就直接使用有界隊列)。對于使用SynchronousQueue的作用jdk中寫的很清楚:此策略可以避免在處理可能具有內部依賴性的請求集時出現鎖。

什么意思?如果你的任務A1,A2有內部關聯,A1需要先運行,那么先提交A1,再提交A2,當使用SynchronousQueue我們可以保證,A1必定先被執行,在A1么有被執行前,A2不可能添加入queue中。

例子二:使用無界隊列策略,即LinkedBlockingQueue

這個就拿newFixedThreadPool來說,根據前文提到的規則:

如果運行的線程少于 corePoolSize,則 Executor 始終首選添加新的線程,而不進行排隊。那么當任務繼續增加,會發生什么呢?

如果運行的線程等于或多于 corePoolSize,則 Executor 始終首選將請求加入隊列,而不添加新的線程。OK,此時任務變加入隊列之中了,那什么時候才會添加新線程呢?

如果無法將請求加入隊列,則創建新的線程,除非創建此線程超出 maximumPoolSize,在這種情況下,任務將被拒絕。這里就很有意思了,可能會出現無法加入隊列嗎?不像SynchronousQueue那樣有其自身的特點,對于無界隊列來說,總是可以加入的(資源耗盡,當然另當別論)。換句說,永遠也不會觸發產生新的線程!corePoolSize大小的線程數會一直運行,忙完當前的,就從隊列中拿任務開始運行。所以要防止任務瘋長,比如任務運行的實行比較長,而添加任務的速度遠遠超過處理任務的時間,而且還不斷增加,不一會兒就爆了。

例子三:有界隊列,使用ArrayBlockingQueue。

這個是最為復雜的使用,所以JDK不推薦使用也有些道理。與上面的相比,最大的特點便是可以防止資源耗盡的情況發生。

舉例來說,請看如下構造方法:

new ThreadPoolExecutor( 2, 4, 30, TimeUnit.SECONDS, new ArrayBlockingQueue<Runnable>(2), new RecorderThreadFactory('CookieRecorderPool'), new ThreadPoolExecutor.CallerRunsPolicy());

假設,所有的任務都永遠無法執行完。

對于首先來的A,B來說直接運行,接下來,如果來了C,D,他們會被放到queue中,如果接下來再來E,F,則增加線程運行E,F。但是如果再來任務,隊列無法再接受了,線程數也到達最大的限制了,所以就會使用拒絕策略來處理。

keepAliveTime

jdk中的解釋是:當線程數大于核心時,此為終止前多余的空閑線程等待新任務的最長時間。

有點拗口,其實這個不難理解,在使用了“池”的應用中,大多都有類似的參數需要配置。比如數據庫連接池,DBCP中的maxIdle,minIdle參數。

什么意思?接著上面的解釋,后來向老板派來的工人始終是“借來的”,俗話說“有借就有還”,但這里的問題就是什么時候還了,如果借來的工人剛完成一個任務就還回去,后來發現任務還有,那豈不是又要去借?這一來一往,老板肯定頭也大死了。

合理的策略:既然借了,那就多借一會兒。直到“某一段”時間后,發現再也用不到這些工人時,便可以還回去了。這里的某一段時間便是keepAliveTime的含義,TimeUnit為keepAliveTime值的度量。

RejectedExecutionHandler

另一種情況便是,即使向老板借了工人,但是任務還是繼續過來,還是忙不過來,這時整個隊伍只好拒絕接受了。

RejectedExecutionHandler接口提供了對于拒絕任務的處理的自定方法的機會。在ThreadPoolExecutor中已經默認包含了4中策略,因為源碼非常簡單,這里直接貼出來。

CallerRunsPolicy

線程調用運行該任務的 execute 本身。此策略提供簡單的反饋控制機制,能夠減緩新任務的提交速度。

public void rejectedExecution(Runnable r, ThreadPoolExecutor e) { if (!e.isShutdown()) {r.run(); } }

這個策略顯然不想放棄執行任務。但是由于池中已經沒有任何資源了,那么就直接使用調用該execute的線程本身來執行。

AbortPolicy

處理程序遭到拒絕將拋出運行時RejectedExecutionException

public void rejectedExecution(Runnable r, ThreadPoolExecutor e) { throw new RejectedExecutionException(); }

這種策略直接拋出異常,丟棄任務。

DiscardPolicy:

不能執行的任務將被刪除

public void rejectedExecution(Runnable r, ThreadPoolExecutor e) { }

這種策略和AbortPolicy幾乎一樣,也是丟棄任務,只不過他不拋出異常。

DiscardOldestPolicy:

如果執行程序尚未關閉,則位于工作隊列頭部的任務將被刪除,然后重試執行程序(如果再次失敗,則重復此過程)

public void rejectedExecution(Runnable r, ThreadPoolExecutor e) { if (!e.isShutdown()) {e.getQueue().poll();e.execute(r); } }

該策略就稍微復雜一些,在pool沒有關閉的前提下首先丟掉緩存在隊列中的最早的任務,然后重新嘗試運行該任務。這個策略需要適當小心。

設想:如果其他線程都還在運行,那么新來任務踢掉舊任務,緩存在queue中,再來一個任務又會踢掉queue中最老任務。

總結:

keepAliveTime和maximumPoolSize及BlockingQueue的類型均有關系。如果BlockingQueue是無界的,那么永遠不會觸發maximumPoolSize,自然keepAliveTime也就沒有了意義。

反之,如果核心數較小,有界BlockingQueue數值又較小,同時keepAliveTime又設的很小,如果任務頻繁,那么系統就會頻繁的申請回收線程。

return new ThreadPoolExecutor(nThreads, nThreads,public static ExecutorService newFixedThreadPool(int nThreads) { 0L, TimeUnit.MILLISECONDS, new LinkedBlockingQueue<Runnable>()); }

以上就是深入理解Java 線程池的詳細內容,更多關于Java 線程池的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
主站蜘蛛池模板: 日日干天天操 | 亚洲国产成人av | 国产亚洲成av人片在线观看桃 | 成人午夜影院 | 九九精品视频在线观看 | 亚洲欧美高清 | 91久久精品国产91久久 | 国产毛片毛片 | 涩涩视频网站在线观看 | 日韩精品一区二区三区视频播放 | 国产精品久久久 | 欧美综合一区二区 | 国产欧美日韩精品在线 | 成人av免费观看 | 亚洲激情 欧美 | 中文字幕亚洲欧美日韩在线不卡 | 日韩免费激情视频 | 亚洲精品福利 | 婷婷色5月| www.欧美亚洲 | 亚洲啊v | 中文字幕在线资源 | h片在线看 | 国产精品久久久久久久天堂 | 欧美精品久久久 | 国产精品久久久久久无遮挡 | 成人午夜精品一区二区三区 | 日本特黄特色aaa大片免费 | 久久精品色欧美aⅴ一区二区 | 亚洲美女av在线 | 日韩有码一区 | 亚洲三区在线观看 | 久久国产精品首页 | 国产精品一区久久久久 | 一区二区精品视频在线观看 | 国产黄色在线播放 | 国产毛片aaa | 久久久精 | 人人干人人看 | 久久婷婷视频 | 亚洲欧美激情视频 | 免费成人毛片 | 成年人视频在线观看免费 | 欧美日韩在线成人 | 国产精品一区一区 | 欧美黄色一区 | 日韩欧美在线一区二区 | 欧美日韩中文字幕在线播放 | 一级片在线观看 | 国产www视频 | 色悠久久久| jlzzjlzz国产精品久久 | 蜜桃av人人夜夜澡人人爽 | 国产97久久 | 9久久精品 | 亚洲福利一区 | 国产成人看片 | 国产毛片毛片 | 国产精品久久久久久久7电影 | 一级毛片大全免费播放 | 天堂亚洲| 亚洲欧美精品一区二区 | 日韩精品一区在线 | 天天操天天干天天 | 久久2018| 国产一区二区av | 亚洲视频在线观看免费 | 色婷婷一二三 | 午夜寂寞福利视频 | 国产三级在线观看 | 三级网址日本 | 中文字幕 在线观看 | 后人极品翘臀美女在线播放 | 日韩视频在线观看中文字幕 | 天天干天天插 | 欧美a网站| 99精品欧美一区二区三区综合在线 | 日本黄色一级片视频 | 国产成人精品av | 国产1区2区精品 | 亚洲精品成人av | 五月婷婷激情网 | 亚洲毛片网站 | 国产精品成人久久久久 | 日韩综合网 | 久久精品久久久 | 国产成人高清 | 久久99国产精品久久99大师 | 成人精品久久久 | 日韩一区中文 | 成人亚洲免费 | 成人精品一区二区三区 | 久久91精品| 91麻豆产精品久久久 | 一区二区三区在线 | 欧 | 嫩草视频在线观看免费 | 91高清视频在线观看 | 久久99国产精品久久99大师 | 国产精品27页 | av免费网站 | 亚洲国产一区二区三区在线观看 | 久久久久9999国产精品 | 狠狠色丁香婷婷综合 | av一二三四 | 日韩欧美在线看 | 精品在线播放 | 老司机深夜福利在线观看 | 欧美成人黄色小说 | 在线观看的av | 午夜精品一区二区三区免费视频 | 日韩国产欧美在线观看 | 视频一区 中文字幕 | 久久99爱视频 | 欧美1区| 日日天天 | 在线观看黄| 超碰一区二区三区 | 成人精品一区二区三区中文字幕 | 国产精品日产欧美久久久久 | 国产高清一区 | 欧美在线观看视频 | 久久久夜夜夜 | 91av亚洲| 日韩免费高清视频 | 日韩三级电影在线免费观看 | 一区二区三区在线观看国产 | 欧美成人福利 | av资源首页 | 青草久操| 久久中文字幕一区 | 久久9色| 国产精品九九九 | 91久久精品国产 | 欧美一区二区伦理片 | 欧美日韩国产一区二区三区 | 日韩综合在线 | 操到爽 | 激情一区 | 成人综合社区 | 91精品国产一区二区三区蜜臀 | а天堂中文最新一区二区三区 | 夜夜草av | 中文字幕第56页 | 亚洲国产精品一区二区第一页 | 国产成人av网站 | 狠狠干美女 | 午夜视频在线观看免费视频 | 国产99热 | 亚洲成人精品区 | 精品久久中文 | 美女操网站 | 国产午夜精品一区二区 | 999精品视频 | 人人草视频在线观看 | 天天干天天插天天 | 国产精品视频导航 | 亚洲国产精品成人 | 精品视频一区二区三区四区 | 欧美一区二区三区免费观看视频 | 日韩特级 | 欧美亚洲在线 | 国产在线精品一区 | 久久精品亚洲精品 | 日韩精品一区二区三区中文在线 | 成人久久久精品乱码一区二区三区 | 日本淫视频 | 亚洲欧美高清 | 国产精品美女久久久久久久网站 | 亚洲国产精品一区二区三区 | 日韩成人 | 午夜影院免费观看视频 | 久久成人久久爱 | 国产精品一区二区三 | 成人美女免费网站视频 | 欧美人体一区二区三区 | 久久av一区二区三区亚洲 | 在线国产视频 | 国产精品自拍一区 | 精品亚洲区 | 欧美久久久久 | 国产日韩欧美亚洲 | 精品久久久久久久久久久久久久 | 中文字幕亚洲欧美精品一区四区 | 国产欧美在线一区二区 | 狠狠干av| 国产一区国产二区在线观看 | 精品九九 | av一区二区三区 | 午夜午夜精品一区二区三区文 | 国产一区二区三区在线 | av在线日韩| 精品久久久久久久 | 国产精品综合 | 欧美区视频 | 精品一区二区三区中文字幕 | 久久国产精品一区二区三区 | 亚洲精品乱码久久久久久金桔影视 | caoporn免费在线视频 | 日韩精品久久 | 三级av在线| 国产精品一区二区三区av | 国产片av | 亚洲欧美在线综合 | 日韩精品久久久久久 | 亚洲一区二区在线电影 | 国内精品一区二区 | 日韩在线视频一区 | av资源中文在线 | 91免费在线看 | 成人福利在线观看 | 欧美一级网站 | 亚洲欧美另类久久久精品2019 | 中文字幕在线一区 | 国产精品一区二区久久久 | 国产成人精品综合 | 久久99国产一区二区三区 | 最新中文字幕 | www天天干| 国产欧美精品一区二区 | 99精品电影| 亚洲人成网站999久久久综合 | 日日夜夜精品 | 亚洲夜幕久久日韩精品一区 | 国产一二区在线 | 天天天干天天天操 | 在线观看亚洲一区二区三区 | 国产黄色一级片 | 99re在线观看 | 老黄网站在线观看 | 久久精品123 | 日本欧美国产 | 一 级 黄 色 片免费网站 | 免费视频一区二区三区在线观看 | 成人欧美一区二区三区黑人孕妇 | av影片在线 | 在线观看av网站永久 | 成人一区二区电影 | 亚洲美女网站 | 午夜成人免费视频 | 国产综合精品视频 | 欧美高清视频在线观看 | 午夜寂寞福利视频 | 午夜操操 | 在线观看毛片网站 | 综合久久网 | 中文字幕乱码一区二区三区 | 999精品在线 | 久久精品| 国产毛片毛片 | 久久久精品欧美一区二区免费 | 国产在线区| 成人免费视频视频在线观看 免费 | 天堂在线一区二区 | 久久99精品久久久久久琪琪 | 欧美日日 | 99精品免费在线 | 黄视频入口 | 欧美日一区二区 | 日韩2区 | 中国电影黄色一级片免费观看 | 日本在线观看一区 | 亚洲三区在线观看 | 日韩在线欧美 | 精品国产一区二区国模嫣然 | 美女久久久 | 伊人手机在线视频 | 精品一二三区 | 国产成人一区二区三区 | 欧美综合一区二区 | 国产欧美日韩综合精品一区二区 | 中文字幕7777 | 国产不卡免费视频 | 久久精品亚洲精品国产欧美kt∨ | 欧美精品欧美极品欧美激情 | 亚洲一区视频在线 | 性开放xxxhd视频 | 天堂中文网官网 | 亚洲一区二区久久 | 成人超碰在线 | 国产成人网 | 国产在线乱 | 人成亚洲| 国产精品久久久久久久午夜片 | 久久成人精品视频 | 成人区一区二区三区 | 麻豆免费短视频 | 久久精品国产99国产精品 | 五月婷亚洲| 成人免费在线观看视频 | 国产剧情一区二区 | 欧美日韩一区二区电影 | 久久精品视频免费 | 国产成人精品高清久久 | 久久综合电影 | 亚洲三区在线观看 | 成人精品福利视频 | 91大神xh98hx在线播放 | 在线免费看a| 操久久| 欧美日韩一区二区三区 | 欧美精品在线一区 | 欧美啊v | 在线视频自拍 | 欧美激情精品久久久久久 | 日韩中文字幕一区 | 日本久久精品视频 | 国产成人免费视频网站高清观看视频 | 在线日韩视频 | 欧美精品在线一区 | 亚洲中午字幕 | 亚洲精品一区二三区不卡 | 欧美日韩一区二区视频在线观看 | 国产精品极品美女在线观看免费 | 欧美午夜三级视频 | 另类 综合 日韩 欧美 亚洲 | 91精品国产一区二区三区香蕉 | 天天色天天看 | 91一区二区在线 | 久久久精品欧美一区二区免费 | 日本一级中文字幕久久久久久 | 欧美成年黄网站色视频 | 亚洲日韩aⅴ在线视频 | 最新免费av网站 | 少妇性l交大片免费一 | 一区二区三区免费在线观看 | 亚洲精彩视频 | 成人久久久精品乱码一区二区三区 | 99精品视频一区二区三区 | 天堂久久爱资源站www | 国产二区视频 | 99免费视频 | 欧美黑人一级毛片 | av在线播放网址 | 91九色最新 | 成人在线h | 亚洲成人在线网站 | 国产精品无码久久久久 | 日本一本在线 | 国产综合在线视频 | 日韩av一区二区三区在线观看 | 成人av免费在线观看 | 91精品国产综合久久久久久丝袜 | 亚洲黄色一区二区 | 欧美一区二区三区视频 | 中文字幕免费看 | 成人精品一区二区 | 亚洲精品免费看 | 一级欧美日韩 | 99精品欧美一区二区三区 | 国产视频久久久久久久 | 久久国产精品99久久久久久老狼 | 欧美一区二区三区在线观看视频 | 狠狠av | 欧美一区二区三区xxxx监狱 | 在线成人亚洲 | 日韩精品在线一区 | 免费视频二区 | 日韩av资源站 | 一区二区日韩精品 | av毛片在线免费看 | 日本精品在线观看 | 一级日批片 | 免费av电影观看 | 亚洲视频在线免费观看 | 久久久久久久久久久九 | 色综合久久天天综合网 | 国产精品99 | 国产自产才c区 | 国产婷婷精品 | 亚洲欧美激情精品一区二区 | 精品在线不卡 | 在线欧美日韩 | 成人欧美一区二区三区黑人孕妇 | 婷婷国产在线观看 | 精品国产一区二区三区日日嗨 | 精品久久久久久久久久久久久久久久久久久 | 日韩精品一区二区三区在线 | 久久免费视频9 | 欧美精品在线观看 | 国产美女啪啪 | 狠狠操网站| 粉嫩av网站 | 精品在线一区二区三区 | 亚洲国产aⅴ成人精品无吗 国产精品永久在线观看 | 亚洲午夜电影 | 成人福利在线 | 中文字幕一区二区三区四区 | 久久久com| 四虎永久网址 | 成人免费视频网站 | 啵啵影院午夜男人免费视频 | 欧美激情视频一区二区三区在线播放 | 特黄级国产片 | 日韩在线精品 | 国产一区二区欧美 | 日日干夜夜操 | 精品三区 | 欧美久久久久久 | 超碰日韩在线 | 日韩一区久久 | 欧美成人精品在线观看 | 日韩高清一区 | 亚洲国产一区二区在线 | 日韩久久精品 | 国产亚洲精品久久久久久青梅 | 国产高清av在线一区二区三区 | 在线观看成人 | 午夜日韩 | 色综合天天综合网国产成人网 | 精品久久一区二区三区 | 国产精品久久久久久久久久99 | 成人av片在线观看 | 呦一呦二在线精品视频 | 亚洲国内精品 | 婷婷欧美 | 特黄视频 | 亚洲精品成人悠悠色影视 | 在线色网站 | 国产精品一区二区三区四区 | 欧美一区二区三区四区五区 | 亚洲精品久久久久久久久久久 | 日韩中文在线视频 | 亚洲精品国产a久久久久久 国产毛片毛片 | 一区不卡| 国产小视频网站 | 国产精品美女久久久久久免费 | 亚洲欧美日韩精品 | 荷兰欧美一级毛片 | 精品美女| 久久色av| 99热在线精品播放 | 91精品国产欧美一区二区成人 | 欧美一区二区视频 | 欧美日韩精品久久 | 国产v日产∨综合v精品视频 | 羞羞视频网站在线免费观看 | 国产精品久久免费视频 | 伦乱视频| 九九热这里都是精品 | 国产一级毛片国语一级 | 国产特级毛片 | 欧美视频在线观看 | 在线成人 | 国产在线二区 | 日韩精品一区二区三区在线观看 | 欧美日韩中文 | 亚洲一区二区三区四区五区中文 | 人妖天堂狠狠ts人妖天堂狠狠 | 伊人看片 | 一区二区三区免费在线 | 色www精品视频在线观看 | 国产乱码精品一区二区三区忘忧草 | 欧美精品1 | 国产99一区二区 | 亚洲中午字幕 | 日韩不卡一区二区三区 | 亚洲国产精品一区二区久久 | 国产欧美视频在线 | 国产激情视频在线观看 | 999久久国产| 99精品视频在线观看 | 91午夜精品一区二区三区 | 欧美激情欧美激情在线五月 | 一区二区中文字幕 | 在线成人| 国产综合一区二区 | 欧美三及片 | 精品在线播放 | 黄色a级 | 久久精品国产精品亚洲 | 北条麻妃99精品青青久久主播 | 欧美日韩亚洲国产 | 国产精品久久久久一区二区三区 | 99国产精品久久久 | 97成人精品视频在线观看 | 欧美xxxx做受欧美 | 91av免费 | 色婷婷在线视频观看 | 亚洲精品粉嫩美女一区 | 韩国av一区二区 | 在线观看成人高清 | 日本久久网 | 97精品国产| 亚洲av毛片一级二级在线 | 国产精品久久一区二区三区 | 色一色网站 | 国产精品免费久久 | jlzzjlzz亚洲日本少妇 | 中字精品| 免费a大片| 99热婷婷 | 狠狠操夜夜操 | 欧美一区成人 | 欧美a级成人淫片免费看 | 国产一区二区视频在线观看 | 精品视频一区二区三区四区 | 夜夜操导航 | 色综合久 | 国产区视频在线观看 | 中文字幕在线播放第一页 | 久久精品在线视频 | 色婷婷精品国产一区二区三区 | 亚洲免费在线看 | 91在线一区二区 | 精品视频网 | 99亚洲| 午夜在线| 亚洲区一区二 | 精品久久久久久久久久久久久久 | 国产精品一二三区 | 精品国产一区二区三区日日嗨 | 亚洲人成在线播放 | 欧美盗摄| 欧美日韩国产免费一区二区三区 | aaa在线观看 | 91中文字幕| 欧美精品区| 国产精品一区二区三区四区 | 亚洲精品一区二区三区 | 欧美一区二区大片 | 国产伦精品一区二区三区四区视频 | 精品成人av| 在线观看免费av网 | 国产ts视频 | 国产精品久久久久久久7电影 | 青青久视频| 伊人伊人 | 欧美激情一区二区三级高清视频 | 日本免费三片免费观看 | 欧美伦理电影一区二区 | 日韩城人免费 | 国产一区二区三区在线 | 91免费版在线看 | 天堂视频中文字幕 | 一区二区中文字幕 | 亚洲一区二区三区四区在线观看 | 久久亚洲国产精品 | 91麻豆产精品久久久久久 | 青青青久草 | 国内精品久久久久国产 | 国内精品一区二区三区 | 亚洲一区二区三区视频 | 毛片综合 | 91成人精品| 中文字幕在线观看av | 一本一道久久精品综合 | 久久国产综合 | 日韩精品观看 | 毛片在线视频 | 国产成人精品一区二区视频免费 | 久久777 | 在线一区二区三区 | www.色.com| 国产高清免费 | 成人在线视频网站 | 99精品电影| 国产精品毛片久久久久久久 | 亚洲免费成人 | 亚洲国产精品一区二区久久,亚洲午夜 | 日本一级毛片免费看 | 人人爽日日爽 | 中文字幕第一页在线 | 欧美日韩国产一级片 | 国产精品亚洲天堂 | 一级片黄色免费 | 波多野结衣一区二区三区高清 | 久久人操 | 两性午夜视频 | 欧美日韩一区二区在线播放 | 欧美视频免费在线 | 久久久久久久国产精品 | 免费观看国产精品 | 久久久高清 | 国产中文字幕在线 | 欧美日韩一区二区不卡 | 成人a视频在线观看 | 2018国产精品 | 亚洲免费精品 | 国产精品欧美日韩在线观看 | 亚洲视频在线一区 | 国产区在线 | 国产片av | 国产综合精品一区二区三区 | 99视频这里有精品 | 亚洲精品视频在线看 | 毛片免费观看视频 | 欧美成年人视频 | 四季久久免费一区二区三区四区 | 一区免费 | 天堂一区二区三区 | 91精品国产91久久久久久吃药 | 国产激情精品视频 | 杨门女将寡妇一级裸片看 | 欧美综合在线观看 | 成人在线视频免费 | 在线观看一区 | 国产精品免费视频观看 | 久久久久久国产 | 国产精品25p | 欧美猛交ⅹxxx乱大交视频 | 国产毛片视频 | 伊人久操 | 精品国产三级a在线观看 | 国产视频第一页 | 日韩欧美中文字幕在线视频 | 久久久久久久中文 | 高清一区二区三区 | 色播久久久 | 91免费版在线观看 | 毛片一区二区 | 午夜国产羞羞视频免费网站 | 日本中文字幕一区 | 成人美女免费网站视频 | 日韩一区不卡 | 欧美日韩成人在线播放 |