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

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

Java 并行數據處理和性能分析

瀏覽:101日期:2022-08-23 11:49:17

并行流

并行流是一個把元素分成多個塊的流,每個塊用不同的線程處理。可以自動分區,讓所有的處理器都忙起來。

假設要寫一個方法,接受一個數量n做參數,計算1-n的和。可以這樣實現:

public long sequentialSum(long n) { return Stream.iterate(1L, i -> i + 1).limit(n).reduce(0L, Long::sum); }

也許可以使用parallel方法,簡單地使用并行計算,提高程序性能:

public long sequentialSum(long n) { return Stream.iterate(1L, i -> i + 1).limit(n).parallel().reduce(0L, Long::sum); }

這樣,流可能在內部被分成多個塊,導致reduction操作可以在不同的塊上互不依賴地并行地各自工作。最后,reduction操作組合每個子流的并行reductions的返回值,返回的結果就是整個流的結果。見下面的示意圖

Java 并行數據處理和性能分析

實際上,調用parallel方法,流自身不會有任何變化。在內部,設置一個布爾類型的標記,標明你想在并行模式執行操作,接下來的操作都是并行的。

類似地,你也可以使用sequential方法,把并行流轉成串行的。你也許認為可以組合這兩個方法:

stream.parallel() .filter(...) .sequential() .map(...) .parallel() .reduce();

但是,最后一次調用parallel或者sequential才會全局地影響管道。上面的例子,管道將被并行地執行。

配置并行流使用的線程池

并行流內部使用ForkJoinPool。默認地,線程數量等于處理器數量(Runtime.getRuntime().availableProcessors())。但是,可以修改系統屬性java.util.concurrent.ForkJoinPool.common.parallelism,配置線程數量。

這是全局配置,所以,除非你認為對性能有幫助,否則不要修改。

測量流的性能

我們聲稱并行加法應該比串行的或者自己的迭代方法快。我們可以使用JMH測量一下。這是一個工具,使用基于注解的方法,可以為JVM程序增加

可靠的microbenchmarks。如果使用maven,可以這樣引入:

<dependency> <groupId>org.openjdk.jmh</groupId> <artifactId>jmh-core</artifactId> <version>1.21</version> </dependency> <dependency> <groupId>org.openjdk.jmh</groupId> <artifactId>jmh-generator-annprocess</artifactId> <version>1.21</version> </dependency>

第一個庫是核心實現,第二個包含一個注解處理器,幫助生成JAR文件,通過它可以方便地運行你的benchmark。maven配置里還應該有下面的plugin:

<plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-shade-plugin</artifactId><executions> <execution> <phase>package</phase> <goals> <goal>shade</goal> </goals> <configuration> <finalName>benchmarks</finalName> <transformers><transformer implementation='org.apache.maven.plugins.shade.resource.ManifestResourceTransformer'> <mainClass>org.openjdk.jmh.Main</mainClass></transformer> </transformers> </configuration> </execution></executions> </plugin>

程序代碼如下

import org.openjdk.jmh.annotations.Benchmark;import org.openjdk.jmh.annotations.BenchmarkMode;import org.openjdk.jmh.annotations.Fork;import org.openjdk.jmh.annotations.Level;import org.openjdk.jmh.annotations.Mode;import org.openjdk.jmh.annotations.OutputTimeUnit;import org.openjdk.jmh.annotations.Scope;import org.openjdk.jmh.annotations.State;import org.openjdk.jmh.annotations.TearDown;import java.util.concurrent.TimeUnit;import java.util.stream.Stream;//測量平均時間@BenchmarkMode(Mode.AverageTime)//以毫秒為單位,打印benchmark結果@OutputTimeUnit(TimeUnit.MILLISECONDS)//執行兩次,增加可靠性。堆空間是4Gb@Fork(value = 2, jvmArgs = {'-Xms4G', '-Xmx4G'})@State(Scope.Benchmark)public class ParallelStreamBenchmark { private static final long N = 10_000_000L; @Benchmark public long sequentialSum() { return Stream.iterate(1L, i -> i + 1).limit(N).reduce(0L, Long::sum); } //每次執行benchmark后,執行GC @TearDown(Level.Invocation) public void tearDown() { System.gc(); }}

使用大內存,和每次迭代以后試著GC都是為了盡量減少GC的影響。盡管如此,結果應該再加一些鹽。很多因素會影響執行時間,比如你的機器有多少核。

默認地,JMH一般先執行5次熱身迭代,這樣可以讓HotSpot優化代碼,然后再執行5次迭代用來計算最終的結果。你可以使用-w和-i命令行參數修改這些配置。

在我的機器上,使用JDK 1.8.0_121, Java HotSpot™ 64-Bit Server VM,執行結果是

Benchmark Mode Cnt Score Error Units

ParallelStreamBenchmark.sequentialSum avgt 10 83.565 ± 1.841 ms/op

你應該期望,使用經典的for循環的迭代版本運行得更快,因為它在更低層(level)工作,而且,更重要的是,它不需要執行原始類型的裝箱和拆箱操作。我們測試一下這個方法:

@Benchmark public long iterativeSum() { long result = 0; for (long i = 1L; i <= N; i++) { result += i; } return result; }

執行結果是

Benchmark Mode Cnt Score Error Units

ParallelStreamBenchmark.iterativeSum avgt 10 6.877 ± 0.068 ms/op

證實了我們的期望:迭代版本比串行流快了10倍。讓我們使用并行流試一試:

Benchmark Mode Cnt Score Error Units

ParallelStreamBenchmark.parallelSum avgt 10 110.157 ± 1.882 ms/op

非常令人失望:并行版本的求和一點都沒有發揮多核的優勢,比串行版還要慢。為什么會這樣?有兩個問題混在一起:

迭代生成了裝箱對象,它們在做加法前,必須拆箱成數字

迭代很難劃分獨立的塊來并行地執行

第二點是特別有趣的,不是所有的流都是適合并行處理的。特別是,迭代的流就很難,這是因為,函數的輸入依賴上一個函數的結果。見下圖:

Java 并行數據處理和性能分析

這意味著,reduction過程并沒有像第一張圖里所表示的那樣執行。reduction開始的時候,還沒有整個數字列表,所以沒法分塊。把流標記為并行的,反而增加了在不同線程上執行的求和要被串行處理的負擔。

使用更專業的方法

LongStream.rangeClosed方法使用的是原始long類型,所以不用裝箱和拆箱。而且,它生產的數的范圍,可以很容易地分成不依賴的塊。比如,范圍1-20可以被分成1-5、6-10、11-15和16-20。

@Benchmark public long rangedSum() { return LongStream.rangeClosed(1, N).reduce(0L, Long::sum); }

輸出是

Benchmark Mode Cnt Score Error Units

ParallelStreamBenchmark.rangedSum avgt 10 7.660 ± 1.643 ms/op

可以看出來,比并行流快了很多,僅比經典的for循環慢了一點。LongStream支持并行:

@Benchmark public long parallelRangedSum() { return LongStream.rangeClosed(1, N).parallel().reduce(0L, Long::sum); }

輸出是

Benchmark Mode Cnt Score Error Units

ParallelStreamBenchmark.parallelRangedSum avgt 10 4.790 ± 5.142 ms/op

可以發現,并行生效了。甚至比for循環還快了1/3。

正確使用并行流

濫用并行流產生錯誤的主要原因是使用了改變共享狀態的算法。下面是一個通過改變共享的累加器來實現前n個自然數求和的例子:

public long sideEffectSum(long n) { Accumulator accumulator = new Accumulator(); LongStream.rangeClosed(1, n).forEach(accumulator::add); return accumulator.total; } public class Accumulator { public long total = 0; public void add(long value) { total += value; } }

這種代碼很常見,特別對熟悉命令式編程范式的開發者而言。當你迭代數字列表時,經常這樣做:初始化一個累加器,遍歷元素,使用累加器相加。

這代碼有什么錯?它是串行的,失去了并行性。讓我們試著使用并行流:

public long sideEffectParallelSum(long n) { Accumulator accumulator = new Accumulator(); LongStream.rangeClosed(1, n).parallel().forEach(accumulator::add); return accumulator.total; }

多執行幾次,你會發現,每次返回的結果都不一樣,而且都不是正確的50000005000000。這是因為多線程累加的時候,total += value并不是原子操作。那么怎樣才能寫出并行情況下,正確的代碼呢?

如果有懷疑,就做測試

注意裝箱問題。Java提供的原始類型流(IntStream、LongStream和DoubleStream)可以避免類似的問題,盡量使用他們

有些操作使用并行流性能更差。尤其是像limit和findFirst這種依賴元素順序的操作,使用并行是非常昂貴的。比如,findAny就比findFirst性能好,因為它跟順序無關。調用unordered方法,可以把一個有順序的流變成無順序的流。比如,如果你需要流的N個元素,而你對前M個感興趣,在一個無順序的流上調用limit比有順序的高效

如果數據量不大,不要選擇并行流

要考慮流的底層數據結構的可分解程度。比如,ArrayList比LinkedList分解起來更高效,因為不遍歷就可以分割。使用range工廠增加的原始類型流也很容易分割。可以通過實現自己的Spliterator分割流

流的特征,以及中間操作如何修改流的元素,會改變分解過程的性能。比如,一個SIZED流可以被分解成兩個相等的部分,并且每個部分可以高效得并行處理,但是,filter會過濾掉任何不滿足條件的元素,導致流的size成了未知的

考慮結束操作是廉價的還是昂貴的merge步驟(比如,Collector的combiner方法)。如果是昂貴的,組合并行結果的代價會比并行流帶來的好處還要高

下面的表格,總結一些流在可分解性方面的并行友好性

源 可分解性 ArrayList 優秀 LinkedList 差 IntStream.range 優秀 Stream.iterate 差 HashSet 好 TreeSet 好

fork/join框架

fork/join框架用來遞歸地把可并行的任務分解成小任務,然后組合每個子任務的結果,以生成總的結果。它實現了ExecutorService接口,這樣所有的子任務都在一個線程池(ForkJoinPool)內工作。

RecursiveTask

要向ForkJoinPool提交任務,你不得不增加RecursiveTask的子類-R是并行任務(以及每個子任務)的返回類型,或者

增加RecursiveAction的子類-當沒有返回值的時候。要定義RecursiveTask,需要實現它唯一的抽象方法:

protected abstract R compute();

該方法定義分割任務和不能繼續被分割時處理一個子任務的算法的邏輯。該方法的實現,經常像下面的偽代碼:

if (任務足夠小,不再被分) { 順序執行任務} else { 把任務分成兩個子任務 遞歸地調用本方法,盡量分割每個子任務 等待所有子任務的完成 組合每個子任務的結果}

可以發現,這是分治算法的并行實現。我們繼續求和的例子,演示怎么使用fork/join框架。首先需要擴展RecursiveTask類:

import java.util.concurrent.RecursiveTask;/** * Created by leishu on 18-12-11. */public class ForkJoinSumCalculator extends RecursiveTask<Long> { //分割任務的閾值 public static final long THRESHOLD = 10_000; //要被求和的數組 private final long[] numbers; private final int start; private final int end; public ForkJoinSumCalculator(long[] numbers) { this(numbers, 0, numbers.length); } //生成子任務的私有構造器 private ForkJoinSumCalculator(long[] numbers, int start, int end) { this.numbers = numbers; this.start = start; this.end = end; } @Override protected Long compute() { //子任務的大小 int length = end - start; if (length <= THRESHOLD) { return computeSequentially();//小于閾值,不分割 } //增加第一個子任務 ForkJoinSumCalculator leftTask = new ForkJoinSumCalculator(numbers, start, start + length / 2); //異步執行,新的子任務使用ForkJoinPool的另一個線程 leftTask.fork(); ForkJoinSumCalculator rightTask = new ForkJoinSumCalculator(numbers, start + length / 2, end); //同步執行第二個子任務,允許遞歸 Long rightResult = rightTask.compute(); //讀取第一個子任務的結果,如果沒完成就等待 Long leftResult = leftTask.join(); //組合 return leftResult + rightResult; } //順序執行 private long computeSequentially() { long sum = 0; for (int i = start; i < end; i++) { sum += numbers[i]; } return sum; }}

Java 并行數據處理和性能分析

使用fork/join的最佳實踐

調用任務的join方法,會阻塞調用者,直到返回結果。所以,要在兩個子任務都啟動以后在調用它

不要在RecursiveTask內使用ForkJoinPool的invoke方法

子任務的fork方法是用來做調度的。在兩個子任務上直接調用它似乎是很自然的,但是,在其中一個上調用compute效率更高,因為這樣能重用相同的線程

偷工作

任務被分給ForkJoinPool里的線程。每個線程有一個保存任務的雙端鏈表,順序地執行鏈表中的任務。如果由于某種原因(比如I/O),一個線程完成了分配給他的全部任務,它會隨機地從其他線程選擇一個隊列,從隊列的尾部偷一個任務。這個過程會持續,直到所有的隊列都空了為止。所以,要有大量的小任務,而不是幾個大任務,這樣可以更好地平衡線程的負荷。

Java 并行數據處理和性能分析

Spliterator

Spliterator是Java 8 提供的新接口,意思是“splitable iterator”,用來并行地迭代源中的元素。也許你不用開發自己的Spliterator,但是,理解了它,也就明白了并行流是如何工作的。Java 8已經在Collections框架內提供了Spliterator的默認實現。Collection接口有一個default方法spliterator(),它就返回一個Spliterator對象。我們先看看Spliterator接口的定義:

public interface Spliterator<T> { //用來按順序消費Spliterator的元素,如果還有元素就返回true boolean tryAdvance(Consumer<? super T> action); //把一些元素分到一個新的Spliterator,以允許他們并行處理 Spliterator<T> trySplit(); //剩余的可被遍歷的元素數量估值 long estimateSize(); int characteristics();}

tryAdvance方法的行為類似于迭代器,用來按順序消費Spliterator的元素,如果還有元素就返回true。trySplit方法

用來把一些元素分到一個新的Spliterator,以允許他們并行處理。

分割過程

把一個流分割成多個部分是一個遞歸過程,如下圖所示。首先,在第一個Spliterator上調用trySplit生成一個新的。然后,在這兩個Spliterator上調用trySplit,這樣產生四個。一直進行下去,直到該方法返回null,標志著不能再被分割。最后,當所有的trySplit都返回null時,遞歸過程結束。

Java 并行數據處理和性能分析

分割過程也會受到Spliterator的特征(由characteristics方法聲明)的影響。

Spliterator特征

characteristics方法返回一個整數,用來更好地控制和優化Spliterator的用法。

Characteristic 描述 ORDERED 元素是有順序的(比如List),所以Spliterator使用該順序做遍歷和分區 DISTINCT 對于每對遍歷的元素x和y,x.equals(y)返回false SORTED 遍歷的元素遵循預定義的排序順序 SIZED 源的size是已知的(比如set),所以estimatedSize()返回的值是精確的 NON-NULL 元素不會為空 IMMUTABLE 源是不可變的,說明遍歷的時候,元素不會被增加、修改和刪除 CONCURRENT 源是并發安全的,并發修改的時候,不用任何同步 SUBSIZED Spliterator和接下來產生的Spliterator都是SIZED

實現自己的Spliterator

我們開發一個簡單的方法,用來計算字符串中的單詞數。

public int countWordsIteratively(String s) { int counter = 0; boolean lastSpace = true; for (char c : s.toCharArray()) { if (Character.isWhitespace(c)) {lastSpace = true; } else {if (lastSpace) counter++;lastSpace = false; } } return counter; }

要計算的字符串是但丁的“地域”的第一句

public static final String SENTENCE =' Nel mezzo del cammin di nostra vita ' + 'mi ritrovai in una selva oscura' + ' che la dritta via era smarrita '; System.out.println('Found ' + countWordsIteratively(SENTENCE) + ' words');

注意,兩個單詞間的空格數是隨機的。執行結果

Found 19 words

使用函數式實現

首先需要把字符串轉換成一個流。原始類型int、long和double才有原始的的流,所以,我們使用Stream:

Stream<Character> stream = IntStream.range(0, SENTENCE.length())

.mapToObj(SENTENCE::charAt);

可以使用reduction計算單詞數量。當reduce的時候,你不得不攜帶由兩個變量組成的狀態:整數型的總數和布爾型的字符是否是空格。因為Java沒有tuples,你得增加一個新類-WordCounter-封裝狀態:

class WordCounter { private final int counter; private final boolean lastSpace; public WordCounter(int counter, boolean lastSpace) { this.counter = counter; this.lastSpace = lastSpace; }//遍歷,累加 public WordCounter accumulate(Character c) { if (Character.isWhitespace(c)) {return lastSpace ? this : new WordCounter(counter, true); } else {//如果上一個字符是空格,而當前的不是,就加1return lastSpace ? new WordCounter(counter + 1, false) : this; } } //組合,求和 public WordCounter combine(WordCounter wordCounter) { return new WordCounter(counter + wordCounter.counter, wordCounter.lastSpace); } public int getCounter() { return counter; } }

下面是遍歷一個新字符時,WordCounter的狀態圖

Java 并行數據處理和性能分析

然后,我們就可以使用流的reduce方法了

private int countWords(Stream<Character> stream) { WordCounter wordCounter = stream.reduce(new WordCounter(0, true),WordCounter::accumulate,WordCounter::combine); return wordCounter.getCounter(); }

我們做一下測試

Stream<Character> stream = IntStream.range(0, SENTENCE.length()).mapToObj(SENTENCE::charAt); System.out.println('Found ' + countWords(stream) + ' words');

執行結果是正確的。

并行的實現

我們修改一下代碼

System.out.println('Found ' + countWords(stream.parallel()) + ' words');

執行結果不是找到19個單詞了。因為源字符串在隨意的位置被分割,一個字符被多次分割。要解決這個問題,就需要實現自己的Spliterator。

class WordCounterSpliterator implements Spliterator<Character> { private final String string; private int currentChar = 0; private WordCounterSpliterator(String string) { this.string = string; } @Override public boolean tryAdvance(Consumer<? super Character> action) { //消費當前字符 action.accept(string.charAt(currentChar++)); //如果還有字符可被消費,返回true return currentChar < string.length(); } @Override public Spliterator<Character> trySplit() { int currentSize = string.length() - currentChar; //小于閾值,不再分割 if (currentSize < 10) {return null; } //候選的分割位置是字符串的一半長度 for (int splitPos = currentSize / 2 + currentChar; splitPos < string.length(); splitPos++) {//如果是空格,才分割if (Character.isWhitespace(string.charAt(splitPos))) { Spliterator<Character> spliterator = new WordCounterSpliterator(string.substring(currentChar, splitPos)); //當前位置修改為分割位置 currentChar = splitPos; return spliterator;} } return null; } @Override public long estimateSize() { return string.length() - currentChar; } @Override public int characteristics() { return ORDERED + SIZED + SUBSIZED + NONNULL + IMMUTABLE; } }

然后,我們做測試

Spliterator<Character> spliterator = new WordCounterSpliterator(SENTENCE); Stream<Character> stream = StreamSupport.stream(spliterator, true); System.out.println('Found ' + countWords(stream) + ' words');

這回沒問題了。

以上這篇Java 并行數據處理和性能分析就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
主站蜘蛛池模板: 亚洲男人av | 91福利在线播放 | 欧美日韩国产一区二区 | 91精品中文字幕一区二区三区 | 精品一区二区不卡 | 成视频年人免费看黄网站 | 国产成人在线免费观看 | 日日久| 精品成人佐山爱一区二区 | 一区二区三区视频免费 | 波多野结衣先锋影音 | 欧美日韩在线第一页 | 91亚洲国产成人久久精品网站 | 大黄网站在线观看 | 欧美一级视频 | 五月天婷婷精品 | 亚洲h视频| 国内精品久久久久久影视8 91一区二区在线观看 | 大桥未久亚洲精品久久久强制中出 | 国产精品毛片久久久久久久 | 成人欧美一区二区三区白人 | 久久99精品久久久 | 中文字国产精久久无 | 免费的黄色毛片 | 国产精品久久久久久吹潮 | 日本久久视频 | 色噜噜一区二区 | 中文字幕亚洲欧美日韩在线不卡 | 91短视频版在线观看www免费 | 国产网站在线 | 日韩一区二区不卡 | 欧美日韩高清在线一区 | 91成人区| 精品九九 | 亚洲日韩aⅴ在线视频 | 成人日韩 | 狠狠狠色丁香婷婷综合久久五月 | 色天天综合久久久久综合片 | 日韩 国产 在线 | 亚洲一区在线日韩在线深爱 | 欧美成在线视频 | 一二三四在线视频观看社区 | 国产精品1区2区3区 国产在线观看一区 | 狠狠综合久久 | 日韩在线www | 久久免费的视频 | 欧美一级片免费在线观看 | 有码在线| 欧美精品1区2区3区 精品国产欧美一区二区 | 国产视频亚洲精品 | 日本一本在线 | 国产综合精品一区二区三区 | 久久手机在线视频 | 日韩99 | 久久色av | 亚洲精品一区在线观看 | 日韩欧美综合在线 | 九九热在线观看 | 国产婷婷综合 | 国产一区二区黑人欧美xxxx | 午夜成人免费电影 | 亚洲一区二区三区四区五区午夜 | 欧美一区二区三区免费 | 人人草人人 | 日韩理伦片在线观看视频播放 | 亚洲大奶网 | 亚洲精品免费观看 | 99免费精品 | 久草精品视频在线播放 | 99国产精品久久久久久久 | 精品视频在线播放 | 久久蜜桃av一区二区天堂 | 黄色大片免费网址 | 精品国产一区二区三区在线观看 | 色网在线观看 | 大香萑 | 一级毛片在线播放 | 老师的朋友2 | 精品久久久久久久久久久久 | 国内精品一区二区三区视频 | 国产精品一区二区无线 | 中文字幕久久精品 | 久久天堂网 | 欧洲亚洲视频 | 久免费视频 | 福利网站在线观看 | 天天拍拍天天干 | 国产精品一区二区不卡 | 久久伊人青青草 | 久久综合色视频 | 成人欧美一区二区三区白人 | 欧美成人一区二区三区片免费 | 少妇精品视频在线观看 | 国产欧美一二三区在线粉嫩 | 亚洲国产精品一区二区第一页 | 搡女人真爽免费午夜网站 | 日韩不卡一区二区 | 中文成人在线 | 久久综合一区二区 | 久久午夜电影院 | 精品久久精品 | 91久久夜色精品国产九色 | 狠狠操精品视频 | 超碰激情| 亚洲免费观看视频 | 日韩综合网 | 天天干天天看天天操 | 久久精品国产亚洲一区二区三区 | 国产乱码精品一区二区三区中文 | 成人一区二区三区久久精品嫩草 | 热久久这里只有精品 | 亚洲欧美综合乱码精品成人网 | 国产视频久久久久 | 国产欧美日韩在线 | 日韩专区一区二区三区 | 亚洲欧洲一区二区 | www一区| 国产成人精品一区二区三区在线 | jizz中国zz女人18高潮 | 亚洲精选一区二区 | 国产午夜精品在线 | 理伦影院 | 国产视频一二区 | 色综合色综合 | 色欧美日韩 | 成人影院www在线观看 | 国产精品香蕉在线观看 | 国产精品久久久久久久久久久免费看 | 九九热这里都是精品 | 在线看亚洲 | 久久久一| 日韩av免费在线播放 | 久色视频在线观看 | 亚洲欧美激情视频 | 久久精视频 | 成人综合社区 | 成人久久18免费网站图片 | 亚洲乱码国产乱码精品精的特点 | 综合亚洲精品 | 欧美黄色片| 国产精品久久久久久久久久妇女 | 午夜精品 | 日本免费视频 | 中文字幕一区在线观看 | 国产在线小视频 | 欧美猛交ⅹxxx乱大交视频 | www久久九| 久久久精品视频免费观看 | 男女视频在线观看 | 亚洲高清视频在线 | 91精品一区二区三区久久久久久 | 亚洲精品99| 亚洲日本欧美日韩高观看 | 亚洲在线| 亚洲综合婷婷 | 国产成人天天爽高清视频 | 男人天堂视频网 | 青青久草| 欧日韩免费 | 日本一区二区三区四区 | 日本精品一区二 | 久久久网 | av解说在线精品 | 欧美日韩国产一区二区 | 91观看| 欧美亚洲视频 | 国产精品久久久久久久久久久新郎 | 国产一区二区 | 免费国产视频在线观看 | 一区二区国产在线 | 亚洲自拍偷拍av | 成人免费视频网站在线看 | 视频在线一区二区 | 激情欧美一区二区三区 | 欧美一区二区三区久久精品 | 日韩一区在线观看视频 | 精品国产91乱码一区二区三区 | 久久午夜电影 | 日韩亚洲视频 | 国产一区日韩在线 | 亚洲动漫在线观看 | 久久99深爱久久99精品 | 91免费看 | 久久中文字幕一区 | 国产视频一视频二 | 香蕉久久久久久 | 午夜国产在线 | 成人精品一区二区三区中文字幕 | 99热精品在线 | 欧美一级在线观看 | 日韩精品小视频 | 久久一二| 免费的av网站 | 91亚洲高清 | www.色综合 | 黄色av网站免费 | av女人的天堂| 亚洲精品国精品久久99热 | 在线看亚洲| 欧美第一区 | 天天插狠狠插 | 欧美国产精品一区 | 中文字幕一区二区三区精彩视频 | 欧美第8页| 国产在线观看 | 日韩一区二区在线播放 | 三级视频在线观看 | 亚洲精品一区在线观看 | 日韩精品在线一区 | 视频精品一区二区三区 | 亚洲成人中文字幕 | 在线观看一级片 | 久久精品99| 欧美国产日韩一区二区 | 少妇无套高潮一二三区 | 91人人澡人人爽 | 精品欧美乱码久久久久久 | 99在线视频播放 | 免费成人高清 | 久久久久亚洲美女啪啪 | 韩国久久精品 | 日韩综合网| 伊人网在线视频观看 | 亚洲精品国产综合区久久久久久久 | 欧美盗摄| 国产午夜视频 | 日韩欧美一级片 | 中文字幕在线看第二 | 91视频88av| 荡女妇边被c边呻吟视频 | 精品乱子伦一区二区三区 | 亚洲网站在线观看 | 亚洲伊人中文字幕 | 亚洲精品免费观看 | 久久久久久国产 | 成人午夜在线观看 | 亚洲天天操 | 97精品国产97久久久久久免费 | 国产综合视频在线播放 | 欧美国产精品久久久 | 亚洲日本乱码在线观看 | 日韩国产欧美在线观看 | 一级黄色影片在线观看 | 国产一区二区久久久 | 亚洲人成网亚洲欧洲无码 | 久草免费在线视频 | 在线观看免费的网站www | 超级碰在线 | 亚洲欧美电影 | 亚洲精品视频一区 | 免费一级在线观看 | 丁香婷婷久久久综合精品国产 | 欧美日本亚洲 | 午夜精品久久久久久 | 99久久国产综合精品女不卡 | 久草在线观看福利视频 | av手机在线电影 | 亚洲成人精品久久 | 久久久久一区二区三区 | 亚洲伊人久久网 | 亚洲国产成人久久 | 国产精品久久久久久久久久 | 天久久| √新版天堂资源在线资源 | 亚洲成人免费在线 | 日韩国产欧美一区 | 最近韩国日本免费观看mv免费版 | 亚洲伦理在线 | 九九99热| 亚洲欧美精品一区二区三区 | 亚洲精品一区二区三区精华液 | 国产成人精品亚洲777人妖 | 国产免费一区二区三区网站免费 | 九热精品 | 欧美亚洲日本 | 免费国产黄网站在线观看视频 | 免费国产视频在线观看 | 亚洲一区二区久久 | 99久久综合精品五月天 | 国产精品亚洲成人 | 一区二区三区在线 | 日韩国产精品一区二区三区 | 亚洲精选国产 | 久久久99精品免费观看 | 国产1区 | 精品久久久久久亚洲综合网站 | 久草网在线视频 | 国产精品福利网站 | 久久五月视频 | 久久精品免费 | 国产专区在线 | 国产在线网站 | 精品在线一区二区三区 | 成人国产精品 | 国产一区二| 日韩欧美在线观看一区二区三区 | 欧洲成人午夜免费大片 | 一区二区三区久久久久久 | 成人作爱视频 | 日韩av福利 | 国产成人免费在线观看 | 国产精品成人3p一区二区三区 | www.欧美日韩 | 国产视频一区二区 | 98精品国产高清在线xxxx天堂 | 这里只有精品视频 | 精品亚洲国产成av人片传媒 | 亚洲日日操 | 成人在线视频播放 | 国产在线在线 | 日韩电影一区 | 成人在线亚洲 | 中文字幕在线网址 | 欧美日韩中文在线观看 | 伊人av成人| 国产精品色婷婷亚洲综合看 | 国产午夜久久 | 久久精彩视频 | 国产精品免费一区二区三区四区 | 亚州中文字幕 | 国产单男 | www.国产| 伊人在线 | 成人精品在线视频 | 欧美一级二级三级 | 日韩综合网 | 国产ts余喵喵和直男多体位 | 欧美精品亚洲 | 亚洲久久久 | 久久精品欧美一区二区三区不卡 | 国产午夜精品一区二区三区 | 亚洲欧洲一区二区 | 91人人澡人人爽 | 久久久精彩视频 | 国产成人精品午夜 | 色欧美综合 | 日韩精品一区二区三区中文字幕 | 免费看的黄色网 | 国产精品亚洲视频 | 久久久大| 成人在线免费 | 国产在线一区二区 | 国产亚洲一区二区三区 | 日韩精品一区二区三区 | 超碰人人插 | 黄色成人在线 | 国产网站视频 | 亚洲福利二区 | 国产a√| 国产高清视频一区二区 | 一级特黄网站 | 日日夜夜天天干干 | 色精品视频 | 麻豆乱码国产一区二区三区 | 一区二区中文 | 福利网站在线观看 | 欧美激情网站 | 亚洲视频中文字幕 | 国产高清不卡 | 亚洲成人免费 | 中文字幕av黄色 | 国产日韩一区二区三区 | 国产高清久久 | 久久久久久黄 | 久久中文字幕一区二区三区 | 日韩欧美一区二区三区免费观看 | 成人在线免费小视频 | 高清三区 | 亚洲久久 | 久草成人 | 日韩精品在线观看免费 | 在线观看精品91福利 | 日韩精品久久久久 | 高清国产午夜精品久久久久久 | 国产视频综合在线 | 久草新视频在线观看 | 国产男女做爰免费网站 | www.久久| 日本一区二区三区免费观看 | 一区二区不卡视频 | 欧美日韩成人免费 | 日韩激情二区 | 男女啪啪免费网站 | 欧美黄色一区 | 91免费视频| 亚洲国产精品福利 | 中文字幕一区在线观看视频 | 亚洲欧美在线视频 | 99精品国产高清在线观看 | 亚洲成人福利 | 日韩精品久久久久久 | 综合久久99| 欧美另类久久 | 国产高清一二三区 | 欧美日韩美女 | 亚洲男人天堂网 | 视频一区二区三区在线播放 | 精品久久久久久久久久久久久久久 | 在线天堂视频 | 欧美男人的天堂 | 国产在线中文字幕 | 国产精品日本欧美一区二区三区 | 日韩高清中文字幕 | 久草色视频在线观看 | 精品毛片| 久久福利 | 午夜不卡一区二区 | 黄色国产大片 | 国产精品福利午夜在线观看 | 亚洲91精品| 成人午夜影院 | 狠狠搞狠狠干 | 国产精品久久久久久久久久免费 | 做a视频免费观看 | 精品免费视频 | 亚洲精品一二三区 | 激情婷婷综合 | 一区二区三区视频免费 | 亚洲一区中文字幕 | √天堂在线 | 久久一道本 | 成人免费观看49www在线观看 | 久久精品无码一区二区日韩av | 99久久日韩精品视频免费在线观看 | 日本欧美久久久久免费播放网 | 夫妻午夜影院 | 国产精品久久久久久久一区探花 | 夜夜艹| 日本理论片好看理论片 | 精品成人网 | 日韩欧美在线看 | 久久九| 国产成人免费在线 | 99精品热视频 | 国产真实乱全部视频 | 一区二区三区视频在线观看 | 国产免费一区二区三区网站免费 | 久久久xxx | 男女视频免费看 | 欧美精品99| 中文字幕一区二区三区乱码图片 | 小草av | 久久国产精品免费一区二区三区 | 国产福利在线视频 | 久久这里只有精品首页 | 日韩在线观看视频一区二区 | 免费在线观看毛片网站 | 亚洲国产免费看 | 龙珠z普通话国语版在线观看 | 亚洲一区二区三区福利 | 女人夜夜春 | 久久99精品久久久久久琪琪 | 天天草天天干 | 久热精品视频 | 日韩中文视频 | 亚洲国产精品麻豆 | 免费观看av毛片 | 在线欧美色| 中文字幕第90页 | 久久久久久九九 | 亚洲毛片在线观看 | 国产精品久久久久久久一区探花 | 日韩成人免费电影 | 国产女人高潮视频在线观看 | 亚洲一区二区三区在线播放 | 久久精品国产亚洲一区二区三区 | 午夜视频在线观看网站 | 国产精品久久久久久久久久久久久久 | 青青久久av北条麻妃海外网 | 亚洲国产高清在线 | 日本三级2018 | 一级在线| av在线播放网站 | 亚洲第一视频 | 国产精品美女在线观看 | av一区在线| 在线国产一区 | 蜜臀影院| 成人免费视频网址 | 欧美日韩视频在线 | 国产亚洲精品精品国产亚洲综合 | 国产日韩精品一区二区 | 日一日干一干 | 99视频免费在线观看 | 国产成人精品一区二区在线 | 日韩欧美大片在线观看 | 天天草av | 国产黄色免费网站 | 久久久亚洲一区二区三区 | 亚洲精品日本 | 国产www在线 | 国偷自产一区二区免费视频 | 中文字幕久久精品 | 国产精品精品 | 亚洲美女网址 | 涩涩导航 | 一本一道久久久a久久久精品91 | 国产真实精品久久二三区 | 小草av| 日本三级全黄 | 日本久久艹| 亚洲一区精品在线 | 日日射av | 国产日韩欧美一区二区在线观看 | 亚洲精品成人 | 国产高清视频一区二区 | 午夜影院a | 久久福利 | 一区二区三区免费 | 国产成人av网站 | 国产欧美日韩精品一区 | 成人免费视频7777777 | 日韩欧美精品区 | 久久国产精品免费一区二区三区 | 亚洲午夜精品久久久久久app | 欧美在线视频网站 | 日韩影院在线 | 精品成人 | 欧美一区二区三区免费电影 | 午夜精品久久久久久久久久久久久 | 亚洲精品电影网在线观看 | 欧美综合一区 | 欧美视频一二三区 | 国产农村妇女精品 | 欧美一区永久视频免费观看 | 亚洲成人精品一区 | 国产一区二区三区四 | 国产精品久久久久无码av | 国产成在线观看免费视频 | 亚洲精选一区二区 | 国产精品99久久久久久大便 | 成人一区二区三区久久精品嫩草 | 一道本一二三区 | 精品福利在线 | 亚洲中午字幕 | 国产特级毛片aaaaaa毛片 | 黄色一级在线观看 | 久草毛片 | 国产1级片 | 嫩草网站入口 | 国产精品一区二区三 | 成人在线观看免费 | 日韩一级大片 | 国产精品日韩一区二区 | 精品国产乱码久久久久久1区2区 | 黄色一级片视频播放 | 亚洲香蕉精品 | 日韩精品久久久久久 | 老司机精品福利视频 | 久久国产成人 | 国产视频大全 | 国产成人在线视频 | 91在线观看视频 | 99视频免费 | 国产在线精品一区二区三区 | 日本在线一二 | 成人av在线网 | 男人的天堂久久 | 日日骚视频 | 国产亚洲欧美在线 | 国产精品99久久久久久久vr | 99精品欧美一区二区三区综合在线 | 亚洲人成电影网 | 日韩在线观看一区 | 91精品一区二区三区久久久久久 | 国产精品久久久久婷婷二区次 | 国产一区二区三区在线免费 | 天天操夜夜干 | 欧美日韩一区二区电影 | 中国妞xxx | 一级日韩片 | 天天干天天搞天天射 | 三区在线视频 | 午夜精品久久久久久久久久久久 | 久久成人精品视频 | 一区二区成人在线 | 欧美xxxx做受欧美 | www.国产视频 | 国产成人一区二区三区 | 一区二区三区不卡视频 | 久久99精品久久久 | 久草观看 | 久久亚洲一区二区三区四区 | 国产婷婷精品av在线 | 国产精品三级在线 | 国产免费看 | 国产精品国产三级国产aⅴ无密码 | 一级片av | 日韩大片免费播放 | 亚洲精品乱码久久久久久蜜桃不爽 | 久久久高清 | 国产欧美综合一区二区三区 | 曰本人一级毛片免费完整视频 | 亚洲精品视频一区 | 天天射影院 | 97国产超碰 | 黄色一级免费电影 | 成人午夜视频在线观看 | 中文字幕在线欧美 | 国产精品久久久久久一区二区三区 | 中文字幕视频在线 | 久久精品 | 色视频网站在线观看一=区 日韩一二三区 | 露娜同人18av黄漫网站 | 在线国产区 | 天天爽视频 | 精品久久久久久久久久久久 | 久久亚洲一区二区三区四区 | 国产一区二区在线看 | 国产乱肥老妇国产一区二 | 在线电影亚洲 | julia中文字幕久久一区二区 | 一区福利视频 | 少妇精品视频在线观看 | 久久久久国产精品免费免费搜索 |