精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

3年工作經驗,工作中還不會使用多線程?阿里P6:別慌,我都總結好了

新聞 前端
掌握線程池是后端程序員的基本要求,相信大家求職面試過程中,幾乎都會被問到有關于線程池的問題。

 掌握線程池是后端程序員的基本要求,相信大家求職面試過程中,幾乎都會被問到有關于線程池的問題。我在網上搜集了幾道經典的線程池面試題,并以此為切入點,談談我對線程池的理解。如果有哪里理解不正確,非常希望大家指出,接下來大家一起分析學習吧。

經典面試題

  • 面試問題1:Java的線程池說一下,各個參數的作用,如何進行的?
  • 面試問題2:按線程池內部機制,當提交新任務時,有哪些異常要考慮。
  • 面試問題3:線程池都有哪幾種工作隊列?
  • 面試問題4:使用無界隊列的線程池會導致內存飆升嗎?
  • 面試問題5:說說幾種常見的線程池及使用場景?

線程池概念

線程池: 簡單理解,它就是一個管理線程的池子。

  • 它幫我們管理線程,避免增加創建線程和銷毀線程的資源損耗。因為線程其實也是一個對象,創建一個對象,需要經過類加載過程,銷毀一個對象,需要走GC垃圾回收流程,都是需要資源開銷的。
  • 提高響應速度。 如果任務到達了,相對于從線程池拿線程,重新去創建一條線程執行,速度肯定慢很多。
  • 重復利用。 線程用完,再放回池子,可以達到重復利用的效果,節省資源。

線程池的創建

線程池可以通過ThreadPoolExecutor來創建,我們來看一下它的構造函數:

  1. public ThreadPoolExecutor(int corePoolSize, int maximumPoolSize,long keepAliveTime,TimeUnit unit, 
  2.  BlockingQueue<Runnable> workQueue, 
  3.  ThreadFactory threadFactory, 
  4.  RejectedExecutionHandler handler)  
  5. 復制代碼 

幾個核心參數的作用:

  • corePoolSize: 線程池核心線程數最大值
  • maximumPoolSize: 線程池最大線程數大小
  • keepAliveTime: 線程池中非核心線程空閑的存活時間大小
  • unit: 線程空閑存活時間單位
  • workQueue: 存放任務的阻塞隊列
  • threadFactory: 用于設置創建線程的工廠,可以給創建的線程設置有意義的名字,可方便排查問題。
  • handler: 線城池的飽和策略事件,主要有四種類型。

任務執行

線程池執行流程,即對應execute()方法:

3年工作經驗,工作中還不會使用多線程?阿里P6:別慌,我都總結好了
  • 提交一個任務,線程池里存活的核心線程數小于線程數corePoolSize時,線程池會創建一個核心線程去處理提交的任務。
  • 如果線程池核心線程數已滿,即線程數已經等于corePoolSize,一個新提交的任務,會被放進任務隊列workQueue排隊等待執行。
  • 當線程池里面存活的線程數已經等于corePoolSize了,并且任務隊列workQueue也滿,判斷線程數是否達到maximumPoolSize,即最大線程數是否已滿,如果沒到達,創建一個非核心線程執行提交的任務。
  • 如果當前的線程數達到了maximumPoolSize,還有新的任務過來的話,直接采用拒絕策略處理。

四種拒絕策略

  • AbortPolicy(拋出一個異常,默認的)
  • DiscardPolicy(直接丟棄任務)
  • DiscardOldestPolicy(丟棄隊列里最老的任務,將當前這個任務繼續提交給線程池)
  • CallerRunsPolicy(交給線程池調用所在的線程進行處理)

為了形象描述線程池執行,我打個比喻:

  • 核心線程比作公司正式員工
  • 非核心線程比作外包員工
  • 阻塞隊列比作需求池
  • 提交任務比作提需求
3年工作經驗,工作中還不會使用多線程?阿里P6:別慌,我都總結好了
  • 當產品提個需求,正式員工(核心線程)先接需求(執行任務)
  • 如果正式員工都有需求在做,即核心線程數已滿),產品就把需求先放需求池(阻塞隊列)。
  • 如果需求池(阻塞隊列)也滿了,但是這時候產品繼續提需求,怎么辦呢?那就請外包(非核心線程)來做。
  • 如果所有員工(最大線程數也滿了)都有需求在做了,那就執行拒絕策略。
  • 如果外包員工把需求做完了,它經過一段(keepAliveTime)空閑時間,就離開公司了。

好的,到這里。面試問題1->Java的線程池說一下,各個參數的作用,如何進行的? 是否已經迎刃而解啦, 我覺得這個問題,回答:線程池構造函數的corePoolSize,maximumPoolSize等參數,并且能描述清楚線程池的執行流程 就差不多啦。

線程池異常處理

在使用線程池處理任務的時候,任務代碼可能拋出RuntimeException,拋出異常后,線程池可能捕獲它,也可能創建一個新的線程來代替異常的線程,我們可能無法感知任務出現了異常,因此我們需要考慮線程池異常情況。

當提交新任務時,異常如何處理?

我們先來看一段代碼:

  1.  ExecutorService threadPool = Executors.newFixedThreadPool(5); 
  2.  for (int i = 0; i < 5; i++) { 
  3.  threadPool.submit(() -> { 
  4.  System.out.println("current thread name" + Thread.currentThread().getName()); 
  5.  Object object = null
  6.  System.out.print("result## "+object.toString()); 
  7.  }); 
  8.  } 
  9. 復制代碼 

顯然,這段代碼會有異常,我們再來看看執行結果

3年工作經驗,工作中還不會使用多線程?阿里P6:別慌,我都總結好了

雖然沒有結果輸出,但是沒有拋出異常,所以我們無法感知任務出現了異常,所以需要添加try/catch。 如下圖:

3年工作經驗,工作中還不會使用多線程?阿里P6:別慌,我都總結好了

OK,線程的異常處理,我們可以直接try...catch捕獲。線程池exec.submit(runnable)的執行流程

通過debug上面有異常的submit方法(建議大家也去debug看一下,圖上的每個方法內部是我打斷點的地方),處理有異常submit方法的主要執行流程圖:

3年工作經驗,工作中還不會使用多線程?阿里P6:別慌,我都總結好了
 
  1. //構造feature對象 
  2. /** 
  3. * @throws RejectedExecutionException {@inheritDoc} 
  4. * @throws NullPointerException {@inheritDoc} 
  5. */ 
  6. public Future<?> submit(Runnable task) { 
  7. if (task == nullthrow new NullPointerException(); 
  8. RunnableFuture<Void> ftask = newTaskFor(task, null); 
  9. execute(ftask); 
  10. return ftask; 
  11. protected <T> RunnableFuture<T> newTaskFor(Runnable runnable, T value) { 
  12. return new FutureTask<T>(runnable, value); 
  13. public FutureTask(Runnable runnable, V result) { 
  14. this.callable = Executors.callable(runnable, result); 
  15. this.state = NEW; // ensure visibility of callable 
  16. public static <T> Callable<T> callable(Runnable task, T result) { 
  17. if (task == null
  18. throw new NullPointerException(); 
  19. return new RunnableAdapter<T>(task, result); 
  20. //線程池執行 
  21. public void execute(Runnable command) { 
  22. if (command == null
  23. throw new NullPointerException(); 
  24. int c = ctl.get(); 
  25. if (workerCountOf(c) < corePoolSize) { 
  26. if (addWorker(command, true)) 
  27. return
  28. c = ctl.get(); 
  29. if (isRunning(c) && workQueue.offer(command)) { 
  30. int recheck = ctl.get(); 
  31. if (! isRunning(recheck) && remove(command)) 
  32. reject(command); 
  33. else if (workerCountOf(recheck) == 0
  34. addWorker(nullfalse); 
  35. else if (!addWorker(command, false)) 
  36. reject(command); 
  37. //捕獲異常 
  38. public void run() { 
  39. if (state != NEW || 
  40. !UNSAFE.compareAndSwapObject(this, runnerOffset, 
  41. null, Thread.currentThread())) 
  42. return
  43. try { 
  44. Callable<V> c = callable; 
  45. if (c != null && state == NEW) { 
  46. V result; 
  47. boolean ran; 
  48. try { 
  49. result = c.call(); 
  50. ran = true
  51. catch (Throwable ex) { 
  52. result = null
  53. ran = false
  54. setException(ex); 
  55. if (ran) 
  56. set(result); 
  57. finally { 
  58. // runner must be non-null until state is settled to 
  59. // prevent concurrent calls to run() 
  60. runner = null
  61. // state must be re-read after nulling runner to prevent 
  62. // leaked interrupts 
  63. int s = state; 
  64. if (s >= INTERRUPTING) 
  65. handlePossibleCancellationInterrupt(s); 
  66. 制代碼 

通過以上分析,submit執行的任務,可以通過Future對象的get方法接收拋出的異常,再進行處理。 我們再通過一個demo,看一下Future對象的get方法處理異常的姿勢,如下圖:

3年工作經驗,工作中還不會使用多線程?阿里P6:別慌,我都總結好了

其他兩種處理線程池異常方案

除了以上1.在任務代碼try/catch捕獲異常,2.通過Future對象的get方法接收拋出的異常,再處理兩種方案外,還有以上兩種方案:

3.為工作者線程設置UncaughtExceptionHandler,在uncaughtException方法中處理異常

我們直接看這樣實現的正確姿勢:

  1. ExecutorService threadPool = Executors.newFixedThreadPool(1, r -> { 
  2.  Thread t = new Thread(r); 
  3.  t.setUncaughtExceptionHandler( 
  4.  (t1, e) -> { 
  5.  System.out.println(t1.getName() + "線程拋出的異常"+e); 
  6.  }); 
  7.  return t; 
  8.  }); 
  9.  threadPool.execute(()->{ 
  10.  Object object = null
  11.  System.out.print("result## " + object.toString()); 
  12.  }); 
  13. 復制代碼 

運行結果:

3年工作經驗,工作中還不會使用多線程?阿里P6:別慌,我都總結好了

4.重寫ThreadPoolExecutor的afterExecute方法,處理傳遞的異常引用

這是jdk文檔的一個demo:

  1. class ExtendedExecutor extends ThreadPoolExecutor { 
  2.  // 這可是jdk文檔里面給的例子。。 
  3.  protected void afterExecute(Runnable r, Throwable t) { 
  4.  super.afterExecute(r, t); 
  5.  if (t == null && r instanceof Future<?>) { 
  6.  try { 
  7.  Object result = ((Future<?>) r).get(); 
  8.  } catch (CancellationException ce) { 
  9.  t = ce; 
  10.  } catch (ExecutionException ee) { 
  11.  t = ee.getCause(); 
  12.  } catch (InterruptedException ie) { 
  13.  Thread.currentThread().interrupt(); // ignore/reset 
  14.  } 
  15.  } 
  16.  if (t != null
  17.  System.out.println(t); 
  18.  } 
  19. }} 
  20. 復制代碼 

因此,被問到線程池異常處理,如何回答?

3年工作經驗,工作中還不會使用多線程?阿里P6:別慌,我都總結好了

。線程池的工作隊列

線程池都有哪幾種工作隊列?

  • ArrayBlockingQueue
  • LinkedBlockingQueue
  • DelayQueue
  • PriorityBlockingQueue
  • SynchronousQueue

ArrayBlockingQueue

ArrayBlockingQueue(有界隊列)是一個用數組實現的有界阻塞隊列,按FIFO排序量。

LinkedBlockingQueue

LinkedBlockingQueue(可設置容量隊列)基于鏈表結構的阻塞隊列,按FIFO排序任務,容量可以選擇進行設置,不設置的話,將是一個無邊界的阻塞隊列,最大長度為Integer.MAX_VALUE,吞吐量通常要高于ArrayBlockingQuene;newFixedThreadPool線程池使用了這個隊列

DelayQueue

DelayQueue(延遲隊列)是一個任務定時周期的延遲執行的隊列。根據指定的執行時間從小到大排序,否則根據插入到隊列的先后排序。newScheduledThreadPool線程池使用了這個隊列。

PriorityBlockingQueue

PriorityBlockingQueue(優先級隊列)是具有優先級的無界阻塞隊列;

SynchronousQueue

SynchronousQueue(同步隊列)一個不存儲元素的阻塞隊列,每個插入操作必須等到另一個線程調用移除操作,否則插入操作一直處于阻塞狀態,吞吐量通常要高于LinkedBlockingQuene,newCachedThreadPool線程池使用了這個隊列。

針對面試題:線程池都有哪幾種工作隊列? 我覺得,回答以上幾種ArrayBlockingQueue,LinkedBlockingQueue,SynchronousQueue等,說出它們的特點,并結合使用到對應隊列的常用線程池(如newFixedThreadPool線程池使用LinkedBlockingQueue),進行展開闡述, 就可以啦。

幾種常用的線程池

  • newFixedThreadPool (固定數目線程的線程池)
  • newCachedThreadPool(可緩存線程的線程池)
  • newSingleThreadExecutor(單線程的線程池)
  • newScheduledThreadPool(定時及周期執行的線程池)

newFixedThreadPool

  1.  public static ExecutorService newFixedThreadPool(int nThreads, ThreadFactory threadFactory) { 
  2.  return new ThreadPoolExecutor(nThreads, nThreads, 
  3.  0L, TimeUnit.MILLISECONDS, 
  4.  new LinkedBlockingQueue<Runnable>(), 
  5.  threadFactory); 
  6.  } 
  7. 復制代碼 

線程池特點:

  • 核心線程數和最大線程數大小一樣
  • 沒有所謂的非空閑時間,即keepAliveTime為0
  • 阻塞隊列為無界隊列LinkedBlockingQueue

工作機制:

3年工作經驗,工作中還不會使用多線程?阿里P6:別慌,我都總結好了
  • 提交任務
  • 如果線程數少于核心線程,創建核心線程執行任務
  • 如果線程數等于核心線程,把任務添加到LinkedBlockingQueue阻塞隊列
  • 如果線程執行完任務,去阻塞隊列取任務,繼續執行。

實例代碼

  1. ExecutorService executor = Executors.newFixedThreadPool(10); 
  2.  for (int i = 0; i < Integer.MAX_VALUE; i++) { 
  3.  executor.execute(()->{ 
  4.  try { 
  5.  Thread.sleep(10000); 
  6.  } catch (InterruptedException e) { 
  7.  //do nothing 
  8.  } 
  9.  }); 
  10. 復制代碼 

IDE指定JVM參數:-Xmx8m -Xms8m :

3年工作經驗,工作中還不會使用多線程?阿里P6:別慌,我都總結好了

run以上代碼,會拋出OOM:

3年工作經驗,工作中還不會使用多線程?阿里P6:別慌,我都總結好了

因此,面試題:使用無界隊列的線程池會導致內存飆升嗎?

答案 :會的,newFixedThreadPool使用了無界的阻塞隊列LinkedBlockingQueue,如果線程獲取一個任務后,任務的執行時間比較長(比如,上面demo設置了10秒),會導致隊列的任務越積越多,導致機器內存使用不停飆升, 最終導致OOM。

使用場景

FixedThreadPool 適用于處理CPU密集型的任務,確保CPU在長期被工作線程使用的情況下,盡可能的少的分配線程,即適用執行長期的任務。

newCachedThreadPool

  1. public static ExecutorService newCachedThreadPool(ThreadFactory threadFactory) { 
  2.  return new ThreadPoolExecutor(0, Integer.MAX_VALUE, 
  3.  60L, TimeUnit.SECONDS, 
  4.  new SynchronousQueue<Runnable>(), 
  5.  threadFactory); 
  6.  } 
  7. 復制代碼 

線程池特點:

  • 核心線程數為0
  • 最大線程數為Integer.MAX_VALUE
  • 阻塞隊列是SynchronousQueue
  • 非核心線程空閑存活時間為60秒

當提交任務的速度大于處理任務的速度時,每次提交一個任務,就必然會創建一個線程。極端情況下會創建過多的線程,耗盡 CPU 和內存資源。由于空閑 60 秒的線程會被終止,長時間保持空閑的 CachedThreadPool 不會占用任何資源。

工作機制

3年工作經驗,工作中還不會使用多線程?阿里P6:別慌,我都總結好了
  • 提交任務
  • 因為沒有核心線程,所以任務直接加到SynchronousQueue隊列。
  • 判斷是否有空閑線程,如果有,就去取出任務執行。
  • 如果沒有空閑線程,就新建一個線程執行。
  • 執行完任務的線程,還可以存活60秒,如果在這期間,接到任務,可以繼續活下去;否則,被銷毀。

實例代碼

  1.  ExecutorService executor = Executors.newCachedThreadPool(); 
  2.  for (int i = 0; i < 5; i++) { 
  3.  executor.execute(() -> { 
  4.  System.out.println(Thread.currentThread().getName()+"正在執行"); 
  5.  }); 
  6.  } 
  7. 復制代碼 

運行結果:

3年工作經驗,工作中還不會使用多線程?阿里P6:別慌,我都總結好了

使用場景

用于并發執行大量短期的小任務。

newSingleThreadExecutor

  1. public static ExecutorService newSingleThreadExecutor(ThreadFactory threadFactory) { 
  2. return new FinalizableDelegatedExecutorService 
  3. (new ThreadPoolExecutor(11
  4. 0L, TimeUnit.MILLISECONDS, 
  5. new LinkedBlockingQueue<Runnable>(), 
  6. threadFactory)); 
  7. 制代碼 

線程池特點

  • 核心線程數為1
  • 最大線程數也為1
  • 阻塞隊列是LinkedBlockingQueue
  • keepAliveTime為0

工作機制

3年工作經驗,工作中還不會使用多線程?阿里P6:別慌,我都總結好了
  • 提交任務
  • 線程池是否有一條線程在,如果沒有,新建線程執行任務
  • 如果有,講任務加到阻塞隊列
  • 當前的唯一線程,從隊列取任務,執行完一個,再繼續取,一個人(一條線程)夜以繼日地干活。

實例代碼

  1. ExecutorService executor = Executors.newSingleThreadExecutor(); 
  2.  for (int i = 0; i < 5; i++) { 
  3.  executor.execute(() -> { 
  4.  System.out.println(Thread.currentThread().getName()+"正在執行"); 
  5.  }); 
  6.  } 
  7. 復制代碼 

運行結果:

3年工作經驗,工作中還不會使用多線程?阿里P6:別慌,我都總結好了

使用場景

適用于串行執行任務的場景,一個任務一個任務地執行。

newScheduledThreadPool

  1.  public ScheduledThreadPoolExecutor(int corePoolSize) { 
  2.  super(corePoolSize, Integer.MAX_VALUE, 0, NANOSECONDS, 
  3.  new DelayedWorkQueue()); 
  4.  } 
  5. 復制代碼 

線程池特點

  • 最大線程數為Integer.MAX_VALUE
  • 阻塞隊列是DelayedWorkQueue
  • keepAliveTime為0
  • scheduleAtFixedRate() :按某種速率周期執行
  • scheduleWithFixedDelay():在某個延遲后執行

工作機制

  • 添加一個任務
  • 線程池中的線程從 DelayQueue 中取任務
  • 線程從 DelayQueue 中獲取 time 大于等于當前時間的task
  • 執行完后修改這個 task 的 time 為下次被執行的時間
  • 這個 task 放回DelayQueue隊列中

實例代碼

  1.  /** 
  2.  創建一個給定初始延遲的間隔性的任務,之后的下次執行時間是上一次任務從執行到結束所需要的時間+* 給定的間隔時間 
  3.  */ 
  4.  ScheduledExecutorService scheduledExecutorService = Executors.newScheduledThreadPool(1); 
  5.  scheduledExecutorService.scheduleWithFixedDelay(()->{ 
  6.  System.out.println("current Time" + System.currentTimeMillis()); 
  7.  System.out.println(Thread.currentThread().getName()+"正在執行"); 
  8.  }, 13, TimeUnit.SECONDS); 
  9. 復制代碼 

運行結果:

3年工作經驗,工作中還不會使用多線程?阿里P6:別慌,我都總結好了
  1. /** 
  2.  創建一個給定初始延遲的間隔性的任務,之后的每次任務執行時間為 初始延遲 + N * delay(間隔)  
  3.  */ 
  4.  ScheduledExecutorService scheduledExecutorService = Executors.newScheduledThreadPool(1); 
  5.  scheduledExecutorService.scheduleAtFixedRate(()->{ 
  6.  System.out.println("current Time" + System.currentTimeMillis()); 
  7.  System.out.println(Thread.currentThread().getName()+"正在執行"); 
  8.  }, 13, TimeUnit.SECONDS);; 
  9. 復制代碼 

使用場景

周期性執行任務的場景,需要限制線程數量的場景

回到面試題:說說幾種常見的線程池及使用場景?

回答這四種經典線程池 :newFixedThreadPool,newSingleThreadExecutor,newCachedThreadPool,newScheduledThreadPool,分線程池特點,工作機制,使用場景分開描述,再分析可能存在的問題,比如newFixedThreadPool內存飆升問題 即可

線程池狀態

線程池有這幾個狀態:RUNNING,SHUTDOWN,STOP,TIDYING,TERMINATED。

  1. //線程池狀態 
  2.  private static final int RUNNING = -1 << COUNT_BITS; 
  3.  private static final int SHUTDOWN = 0 << COUNT_BITS; 
  4.  private static final int STOP = 1 << COUNT_BITS; 
  5.  private static final int TIDYING = 2 << COUNT_BITS; 
  6.  private static final int TERMINATED = 3 << COUNT_BITS; 
  7. 復制代碼 

線程池各個狀態切換圖:

3年工作經驗,工作中還不會使用多線程?阿里P6:別慌,我都總結好了

RUNNING

  • 該狀態的線程池會接收新任務,并處理阻塞隊列中的任務;
  • 調用線程池的shutdown()方法,可以切換到SHUTDOWN狀態;
  • 調用線程池的shutdownNow()方法,可以切換到STOP狀態;

SHUTDOWN

  • 該狀態的線程池不會接收新任務,但會處理阻塞隊列中的任務;
  • 隊列為空,并且線程池中執行的任務也為空,進入TIDYING狀態;

STOP

  • 該狀態的線程不會接收新任務,也不會處理阻塞隊列中的任務,而且會中斷正在運行的任務;
  • 線程池中執行的任務為空,進入TIDYING狀態;

TIDYING

  • 該狀態表明所有的任務已經運行終止,記錄的任務數量為0。
  • terminated()執行完畢,進入TERMINATED狀態

TERMINATED

  • 該狀態表示線程池徹底終止
責任編輯:張燕妮 來源: 今日頭條
相關推薦

2018-01-15 15:22:15

Java開發經驗面試

2016-03-14 11:58:10

面試工作經驗程序員

2017-12-12 18:10:30

程序員工作經驗技能

2018-05-29 19:39:26

IT經驗技術

2015-10-26 09:12:59

SOHO設計師經驗總結

2018-03-13 08:48:26

java程序員技能

2017-12-26 15:30:06

Java程序員技能

2011-06-27 14:56:49

SEO

2009-06-23 08:18:21

工作經驗IT人才

2009-06-05 12:51:34

遭軟裁員工作經驗

2019-04-24 13:28:17

大數據大數據開發可視化

2009-06-04 13:29:36

面試主考官工作經驗

2011-10-17 13:06:00

2018-07-09 10:55:14

視頻系統經驗

2013-06-28 11:08:07

運維DBASA

2018-08-13 09:46:04

職場專業度阿里巴巴

2021-02-26 13:50:37

Java并發代碼

2023-04-07 08:46:41

Stream流map()Java8

2021-07-15 08:12:31

體系感面試邏輯思維

2024-12-17 08:20:50

點贊
收藏

51CTO技術棧公眾號

日韩天天综合| 麻豆精品av| 亚洲精品视频免费观看| aa成人免费视频| 欧美日韩国产中文字幕 | 国产九色精品| 亚洲第一网站在线观看| 色综合久久一区二区三区| 日韩欧美国产小视频| 色欲色香天天天综合网www| 国产在线小视频| 国产自产v一区二区三区c| 韩国日本不卡在线| 青青青视频在线播放| av成人男女| 欧美亚一区二区| 无码粉嫩虎白一线天在线观看| 国产小视频在线观看| 风间由美性色一区二区三区| 国产精品日韩在线一区| 好吊操这里只有精品| 国产精品福利在线观看播放| 亚洲精品小视频| 国产乱国产乱老熟300部视频| 成人影院网站| 亚洲高清三级视频| 国产卡一卡二在线| 懂色av中文在线| 99精品视频在线观看| 91久久久在线| 在线视频免费观看一区| 在线亚洲欧美| 欧美精品九九久久| 91精品一区二区三区蜜桃| 国产乱码精品一区二区三区四区| 精品成a人在线观看| 黄色a级三级三级三级| 成人在线网站| 色999日韩国产欧美一区二区| 无码 制服 丝袜 国产 另类| av软件在线观看| 中文字幕中文字幕一区二区| 日本一区精品| 成人精品一区二区三区免费 | 欧美日韩国产综合在线| 无码国产精品一区二区色情男同 | 久久久久久久波多野高潮日日| 国内精品久久久久久| 欧美精品乱码视频一二专区| 中文字幕亚洲综合久久五月天色无吗'' | 亚洲国产精品久久久男人的天堂| 中文字幕日韩精品无码内射| 成人video亚洲精品| 亚洲欧美影音先锋| 最近中文字幕免费mv| 免费观看久久久久| 亚洲日本中文字幕区| 波多野结衣激情| 在线中文字幕电影| 亚洲最新在线观看| 国产日韩亚洲欧美在线| 韩国成人二区| 色综合久久六月婷婷中文字幕| 国产精品少妇在线视频| 日韩免费福利视频| 欧美色视频一区| 久久久久久久高清| 一区二区网站| 日韩av在线看| 娇妻被老王脔到高潮失禁视频| 国产一区日韩| 久久精品国产v日韩v亚洲| 青草影院在线观看| 很黄很黄激情成人| 欧美孕妇孕交黑巨大网站| 6080午夜伦理| 另类欧美日韩国产在线| 91gao视频| 亚洲精品成人电影| 久久久久亚洲综合| 在线视频欧美一区| 波多野结衣乳巨码无在线观看| 亚洲va国产天堂va久久en| 99爱视频在线| 亚洲精品tv| 精品日韩99亚洲| 国产肥白大熟妇bbbb视频| 小说区亚洲自拍另类图片专区 | 日本一区二区视频| 在线三级中文| 日本高清成人免费播放| 91蝌蚪视频在线| 欧美美女在线直播| 日韩中文字幕精品视频| 五月天婷婷网站| 日韩成人精品视频| 99精品99久久久久久宅男| 四虎电影院在线观看| 1区2区3区欧美| 国产精品一区二区免费在线观看| 成人av集中营| 亚洲国产日韩一区| 艳妇荡乳欲伦69影片| 亚洲人成久久| 91亚洲精品久久久| 韩国中文免费在线视频| 亚洲综合图片区| 中文字幕一区二区三区四区在线视频| 精品入口麻豆88视频| 亚洲女人天堂色在线7777| 91杏吧porn蝌蚪| 久久久精品午夜少妇| 国产精品久久久久av福利动漫| 97视频在线观看网站| 精品成人国产在线观看男人呻吟| 亚洲第一狼人区| 婷婷精品在线| 欧美激情成人在线视频| 亚洲资源在线播放| 久久精品水蜜桃av综合天堂| 成人一级生活片| 亚洲欧洲二区| 最近中文字幕日韩精品| 国产成人精品网| 国产精品18久久久久久久久| 亚洲欧美日韩精品综合在线观看| 蜜桃视频动漫在线播放| 日韩欧美亚洲国产另类| 日本一级特级毛片视频| 日韩电影在线观看网站| 欧美高清性xxxxhdvideosex| av影视在线| 欧美大片一区二区| 劲爆欧美第一页| 国产一区二区精品久久91| 性欧美精品一区二区三区在线播放| 台湾佬中文娱乐网欧美电影| 欧美xingq一区二区| 国产乱国产乱老熟300| 老鸭窝一区二区久久精品| 日韩精品欧美专区| 亚洲天堂手机| 亚洲精品天天看| 成人免费毛片视频| 国产视频911| 久久久精品在线视频| 免费观看久久av| 国产成人精品日本亚洲专区61| 四虎影院在线播放| 色婷婷av一区二区三区软件| 公侵犯人妻一区二区三区| 国产精品日本欧美一区二区三区| 精品日本一区二区| 在线观看特色大片免费视频| 日韩精品视频中文在线观看| av大片在线免费观看| 91丨九色丨国产丨porny| 女人天堂av手机在线| 西野翔中文久久精品字幕| 欧洲成人在线观看| 国产高清在线看| 欧美日韩高清不卡| 538精品在线视频| 丁香六月综合激情| 亚洲国产精品久久久久婷蜜芽| 狠狠综合久久av一区二区蜜桃| 国产精品高精视频免费| 日本视频在线播放| 日韩精品一区二区三区中文精品| 久久精品这里有| 久久综合色之久久综合| 91视频免费版污| 亚洲综合婷婷| 国产综合动作在线观看| 羞羞影院欧美| 美日韩在线视频| 婷婷婷国产在线视频| 欧美图片一区二区三区| 波多野结衣爱爱视频| 91视频com| 亚洲欧美aaa| 激情91久久| 日韩免费毛片| 亚洲精品不卡在线观看| 欧美专区在线视频| 麻豆传媒在线观看| 亚洲精品www久久久| 中文无码av一区二区三区| 亚洲九九爱视频| 日本丰满少妇裸体自慰| 久久99精品国产麻豆婷婷洗澡| 屁屁影院ccyy国产第一页| 妖精视频一区二区三区| 91久久精品国产91久久| 国产在线精彩视频| 日韩视频亚洲视频| 午夜性色福利影院| 69堂成人精品免费视频| 国产无套丰满白嫩对白| 亚洲女与黑人做爰| 国产jjizz一区二区三区视频| 国产成人在线看| 最新中文字幕免费视频| 亚洲啪啪91| 日韩视频 中文字幕| 精品国产91| 精品欧美一区二区在线观看视频| 国产精品777777在线播放| 欧洲精品久久久| japanese色国产在线看视频| 亚洲天堂av女优| 人妻va精品va欧美va| 欧美片网站yy| 免费黄色片视频| 亚洲成av人在线观看| 最新av电影网站| 国产午夜亚洲精品不卡| 最近中文字幕无免费| 国产麻豆一精品一av一免费| 男女啪啪网站视频| 国产欧美一区二区三区国产幕精品| 一区二区三区日韩视频| 日本a级不卡| 日韩女优中文字幕| 神马影视一区二区| 久久久久久亚洲精品不卡4k岛国| 欧美高清hd| 91嫩草在线视频| 日韩欧美三区| 91精品国产自产在线观看永久| 欧美男体视频| 欧美亚洲免费电影| 午夜影院一区| 91精品国产91久久久久福利| 国产极品人妖在线观看| 欧美大片在线免费观看| h片在线免费| 欧美成人免费观看| 亚洲www色| 欧美尺度大的性做爰视频| 黄色在线视频网站| 久久中文久久字幕| 国产黄色小视频在线| 操人视频在线观看欧美| 国产在线观看av| 欧美不卡视频一区发布| 制服丝袜中文字幕在线| 久久99亚洲热视| 波多野结衣在线高清| 1769国产精品| 欧美舌奴丨vk视频| 国产成人久久精品| 欧美日韩五区| 国产在线久久久| 麻豆精品久久| 国产精品视频一区二区三区经| 国产精品久av福利在线观看| 国产一区二区在线网站| 香蕉视频一区| 色综合久久久久久久久五月| 日韩成人免费| 国产 欧美 日本| 一区二区三区高清视频在线观看| 国产极品美女高潮无套久久久| 日韩成人午夜电影| 57pao国产成永久免费视频| 国产一区二区三区香蕉| 女性生殖扒开酷刑vk| 91麻豆国产福利在线观看| 日韩一级av毛片| 亚洲欧洲精品成人久久奇米网| 免费在线观看一级片| 亚洲高清久久久| 国产一级片av| 91麻豆精品久久久久蜜臀| 国模私拍视频在线| 亚洲免费高清视频| 在线激情小视频| 欧美人交a欧美精品| 欧美男男tv网站在线播放| 国产精品久久在线观看| 4438全国亚洲精品观看视频| 久久伊人一区二区| 无码一区二区三区视频| 欧美深夜福利视频| 美女视频黄 久久| 韩国三级视频在线观看| 国产三级精品三级| 欧美日韩成人免费观看| 色婷婷久久一区二区三区麻豆| 国产欧美综合视频| 亚洲精品自拍视频| 菠萝菠萝蜜在线视频免费观看| 51ⅴ精品国产91久久久久久| 婷婷激情成人| 欧美精品一区二区三区在线看午夜| 天堂网在线观看国产精品| 国产午夜伦鲁鲁| 国产剧情一区二区| 婷婷色一区二区三区| 亚洲自拍偷拍图区| 一区二区三区免费在线视频| 亚洲国产欧美久久| av毛片在线免费| 国产精品黄色av| 欧美一级全黄| 成人国产在线看| 毛片av一区二区| 成年人在线观看av| 一区二区三区四区精品在线视频| 99re热视频| 日韩精品在线观| 牛牛电影国产一区二区| 成人福利在线观看| 精品久久久亚洲| 日本毛片在线免费观看| 成人天堂资源www在线| 91久久久久久久久久久久久久| 色天使色偷偷av一区二区| 天天干天天插天天操| 欧美理论电影在线播放| 亚洲精品成人一区| 午夜精品福利一区二区| 午夜亚洲伦理| 国产精品伦子伦| 亚洲国产精品久久人人爱| 精品毛片一区二区三区| 久久天天躁狠狠躁老女人| 国产私拍福利精品视频二区| 欧美精品亚洲精品| 亚洲欧美视频一区二区三区| 成年人的黄色片| 精品高清一区二区三区| 刘亦菲久久免费一区二区| 九色精品免费永久在线| 精品一区二区三区免费看| 一区视频二区视频| 精品一区二区免费视频| 天天做夜夜爱爱爱| 欧美色综合网站| 色哟哟免费在线观看| 国产在线一区二区三区| 国产精品久久久乱弄| 国产探花在线观看视频| 亚洲欧美日本韩国| 精品黑人一区二区三区国语馆| 免费91在线视频| 日本在线成人| 91黄色在线看| 97精品视频在线观看自产线路二| 日本视频免费在线| 日韩电影中文 亚洲精品乱码| 男人av在线播放| 欧洲精品亚洲精品| 免费观看一级特黄欧美大片| 91视频最新网址| 欧美一区二区三区电影| 性直播体位视频在线观看| 国产福利久久精品| 日韩视频在线一区二区三区| 国产ts丝袜人妖系列视频| 色猫猫国产区一区二在线视频| www日韩tube| 91亚洲va在线va天堂va国| 在线电影一区| 亚洲天堂视频一区| 欧美日韩国产免费| 人人澡人人添人人爽一区二区| 国内视频一区| 日韩高清电影一区| 国产一二三四区| 日韩av在线免费看| 99精品国自产在线| 伊人再见免费在线观看高清版| 成人涩涩免费视频| 自拍偷拍18p| 久久综合伊人77777蜜臀| 看全色黄大色大片免费久久久| 成年人网站大全| 亚洲欧洲精品一区二区精品久久久 | av免费在线免费| 国内一区二区在线视频观看| 日本在线不卡一区| 校园春色 亚洲| 亚洲欧洲xxxx| 日韩一区二区三区精品视频第3页| 欧美日韩在线一| 成人欧美一区二区三区视频网页| 老牛影视av牛牛影视av| 国产精品久久久久久久久久新婚 | 91在线精品入口| 97视频免费看| 婷婷精品进入| 亚洲午夜福利在线观看| 91精品一区二区三区在线观看| 国产污视频在线播放| 日本黄色播放器| 久久免费看少妇高潮| 国产高清视频免费观看| 国产精品678|