1. 程式人生 > >lambda表示式處理集合問題

lambda表示式處理集合問題

public class test {
    public static void main(String[] args) {
        List<String> list1 = new LinkedList<>();
        list1.add("1111");
        list1.add("1111");
        list1.add("2222");
        list1.add("3333");
        list1.add("4444");

        List<String> list2 = new LinkedList<>();
        list2.add("3333");
        list2.add("4444");
        list2.add("5555");
        list2.add("6666");
        list2.add("7777");

        // 交集
        List<String> intersection = list1.stream().filter(item -> list2.contains(item)).collect(toList());
        System.out.println("---得到交集 intersection---");
        intersection.parallelStream().forEach(System.out :: println);

        // 差集 (list1 - list2)
        List<String> reduce1 = list1.stream().filter(item -> !list2.contains(item)).collect(toList());
        System.out.println("---得到差集 reduce1 (list1 - list2)---");
        reduce1.parallelStream().forEach(System.out :: println);

        // 差集 (list2 - list1)
        List<String> reduce2 = list2.stream().filter(item -> !list1.contains(item)).collect(toList());
        System.out.println("---得到差集 reduce2 (list2 - list1)---");
        reduce2.parallelStream().forEach(System.out :: println);

        // 並集
        List<String> listAll = list1.parallelStream().collect(toList());
        List<String> listAll2 = list2.parallelStream().collect(toList());
        listAll.addAll(listAll2);
        System.out.println("---得到並集 listAll---");
        listAll.parallelStream().forEach(System.out :: println);

        // 去重並集
        List<String> listAllDistinct = listAll.stream().distinct().collect(toList());
        System.out.println("---得到去重並集 listAllDistinct---");
        listAllDistinct.parallelStream().forEach(System.out :: println);

        System.out.println("---原來的List1---");
        list1.parallelStream().forEach(System.out :: println);
        System.out.println("---原來的List2---");
        list2.parallelStream().forEach(System.out :: println);

        // 一般有filter 操作時,不用並行流parallelStream ,如果用的話可能會導致執行緒安全問題

    }
}