zoukankan      html  css  js  c++  java
  • Java8-Stream-No.12

    
    import java.util.ArrayList;
    import java.util.Arrays;
    import java.util.List;
    import java.util.UUID;
    import java.util.concurrent.ForkJoinPool;
    import java.util.concurrent.TimeUnit;
    
    public class Streams12 {
    
        public static void main(String[] args) {
            List<String> strings = Arrays.asList("a1", "a2", "b1", "c2", "c1");
    
    //        test1();
    //        test2(strings);
            test3(strings);
    //        test4();
        }
    
        private static void test4() {
            List<String> values = new ArrayList<>(100);
            for (int i = 0; i < 100; i++) {
                UUID uuid = UUID.randomUUID();
                values.add(uuid.toString());
            }
    
            // sequential
    
            long t0 = System.nanoTime();
    
            long count = values
                .parallelStream()
                .sorted((s1, s2) -> {
                    System.out.format("sort:    %s <> %s [%s]
    ", s1, s2, Thread.currentThread().getName());
                    return s1.compareTo(s2);
                })
                .count();
            System.out.println(count);
    
            long t1 = System.nanoTime();
    
            long millis = TimeUnit.NANOSECONDS.toMillis(t1 - t0);
            System.out.println(String.format("parallel sort took: %d ms", millis));
        }
    
        private static void test3(List<String> strings) {
            strings
                .parallelStream()
                .filter(s -> {
                    System.out.format("filter:  %s [%s]
    ", s, Thread.currentThread().getName());
                    return true;
                })
                .map(s -> {
                    System.out.format("map:     %s [%s]
    ", s, Thread.currentThread().getName());
                    return s.toUpperCase();
                })
                .sorted((s1, s2) -> {
                    System.out.format("sort:    %s <> %s [%s]
    ", s1, s2, Thread.currentThread().getName());
                    return s1.compareTo(s2);
                })
                .forEach(s -> System.out.format("forEach: %s [%s]
    ", s, Thread.currentThread().getName()));
        }
    
        private static void test2(List<String> strings) {
            strings
                .parallelStream()
                .filter(s -> {
                    System.out.format("filter:  %s [%s]
    ", s, Thread.currentThread().getName());
                    return true;
                })
                .map(s -> {
                    System.out.format("map:     %s [%s]
    ", s, Thread.currentThread().getName());
                    return s.toUpperCase();
                })
                .forEach(s -> System.out.format("forEach: %s [%s]
    ", s, Thread.currentThread().getName()));
        }
    
        private static void test1() {
            // -Djava.util.concurrent.ForkJoinPool.common.parallelism=5
    
            ForkJoinPool commonPool = ForkJoinPool.commonPool();
            System.out.println(commonPool.getParallelism());
        }
    }
    
  • 相关阅读:
    解决mac os x下 tomcat启动报 java.net.BindException: Permission denied <null>:80 错误
    Mac下MySQL卸载方法 转载
    利用JS函数制作时钟运行程序
    HTML页面弹出窗口调整代码总结
    JavaScript代码放在HTML代码不同位置的差别
    二十五种网页加速方法和seo优化技巧
    web前端之Html和Css应用中的细节问题
    利用css制作横向和纵向时间轴
    利用html5看雪花飘落的效果
    利用jQuery实现鼠标滑过整行变色
  • 原文地址:https://www.cnblogs.com/bilaisheng/p/10210926.html
Copyright © 2011-2022 走看看