2000字范文,分享全网优秀范文,学习好帮手!
2000字范文 > java流式api Java 8 中流式API性能基准测试

java流式api Java 8 中流式API性能基准测试

时间:2021-09-17 09:58:09

相关推荐

java流式api Java 8 中流式API性能基准测试

测试代码

package hello.test;

import org.openjdk.jmh.annotations.*;

import org.openjdk.jmh.runner.Runner;

import org.openjdk.jmh.runner.RunnerException;

import org.openjdk.jmh.runner.options.Options;

import org.openjdk.jmh.runner.options.OptionsBuilder;

import java.util.Arrays;

import java.util.concurrent.TimeUnit;

@BenchmarkMode(Mode.Throughput)

@OutputTimeUnit(TimeUnit.MILLISECONDS)

@State(Scope.Thread)

public class BenchmarkTest {

public static final String[] BRAND_ARRAY = {"iphone", "huawei", "xiaomi", "samsung", "vivo", "bbk", "oppo", "meizu", "sony", "xperia", "htc", "oneplus", "smartisan", "lenovo", "gionee", "nubia", "letv", "vertu"};

private static final String bidRequestModel = "oneplus";

@Benchmark

public static String findBidrequstBrandByStream() {

final String lowBidRequestModel = bidRequestModel.toLowerCase();

return Arrays.stream(BRAND_ARRAY).filter(x -> lowBidRequestModel.contains(x)).findAny().get();

}

@Benchmark

public static String findBidrequstBrandByParallelStream() {

final String lowBidRequestModel = bidRequestModel.toLowerCase();

return Arrays.stream(BRAND_ARRAY).parallel().filter(x -> lowBidRequestModel.contains(x)).findAny().get();

}

@Benchmark

public static String findBidrequstBrandByArray() {

final String lowBidRequestModel = bidRequestModel.toLowerCase();

for (String e : BRAND_ARRAY) {

if (lowBidRequestModel.contains(e)) {

return e;

}

}

return "";

}

public static void main(String[] args) throws RunnerException {

Options opt = new OptionsBuilder()

.include(BenchmarkTest.class.getSimpleName())

.forks(1)

.warmupIterations(5)

.measurementIterations(5)

.build();

new Runner(opt).run();

}

}

结果

Benchmark Mode Cnt Score Error Units

BenchmarkTest.findBidrequstBrandByArray thrpt 5 11206.177 ± 1438.816 ops/ms

BenchmarkTest.findBidrequstBrandByParallelStream thrpt 5 206.097 ± 95.776 ops/ms

BenchmarkTest.findBidrequstBrandByStream thrpt 5 4838.695 ± 368.454 ops/ms

总结

对性能敏感的程序, 建议还是用回传统的for循环

并行流并不一定会比顺序流快

java 8 的流式api, 一般情况下比不上传统的 for 循环

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。