Java 中 Set 的4中遍历方式

同系列文章
java 中 List 的5种遍历方式
Java 中 Set 的4中遍历方式
Java 中 Map 的5种遍历方式

Set 和 List 遍历方式基本一致,Set 没有fori 的遍历方式

主测试方法

    @Test
    public void test(){
        Set<Integer> set = new HashSet<>();
        int n = 1000_0000;
        for (int i = 0; i < n; i++) {
            set.add(i);
        }

        System.out.println("======== 1 iterator ==========");
        iteratorTest(set);
        System.out.println("======== 2 增强for ==========");
        forBoostTest(set);
        System.out.println("======== 3 forEach 最耗时 java8 ==========");
        forEachTest(set);
        System.out.println("======== 4 stream forEach 比较耗时和增强for差不多 java8 ==========");
        streamForEachTest(set);
    }

测试结果

======== 1 iterator ==========
set.iterator() for time=	68
set.iterator() while time=	66

======== 2 增强for ==========
set.for Boost time=	75

======== 3 forEach 最耗时 java8 ==========
set.forEach time=	118

======== 4 stream forEach 比较耗时和增强for差不多 java8 ==========
set.stream().forEach() time=	71

1、迭代器方法

    /**
     * 1 iterator
     * 迭代器
     * @param set
     */
    public static void iteratorTest(Set<Integer> set) {
        long before = System.currentTimeMillis();
        for (Iterator<Integer> iterator = set.iterator(); iterator.hasNext(); ) {
            iterator.next();
        }
        long after = System.currentTimeMillis();
        System.out.println("set.iterator() for time=\t"  + (after - before));

        before = System.currentTimeMillis();
        /**
         * while 循环写法
         */
        Iterator<Integer> iterator = set.iterator();
        while (iterator.hasNext()) {
            iterator.next();
        }
        after = System.currentTimeMillis();
        System.out.println("set.iterator() while time=\t"  + (after - before));
    }

2、增强for

    /**
     * 2
     * 增强for
     * @param set
     */
    public static void forBoostTest(Set<Integer> set) {
        long before = System.currentTimeMillis();
        for (int item : set) {
            // System.out.println(item);
        }
        long after = System.currentTimeMillis();
        System.out.println("set.for Boost time=\t"  + (after - before));
    }

3、set.forEach 注意:java8 才支持

    /**
     * 3 foreach
     * foreach 最慢不推荐 java8 lambda
     * @param set
     */
    public static void forEachTest(Set<Integer> set) {
        long before = System.currentTimeMillis();
        set.forEach(item -> {
            // System.out.println(item);
        });
        long after = System.currentTimeMillis();
        System.out.println("set.forEach time=\t"  + (after - before));
    }

4、set.stream().forEach 注意:java8 才支持

    /**
     * 4 stream foreach
     * stream foreach java8 特有
     * @param set
     */
    public static void streamForEachTest(Set<Integer> set) {
        long before = System.currentTimeMillis();
        set.stream().forEach(item -> {
            // System.out.println(item);
        });
        long after = System.currentTimeMillis();
        System.out.println("set.stream().forEach() time=\t"  + (after - before));
    }

你可能感兴趣的:(Java)