1. 程式人生 > 其它 >Java8 新特性 Stream Api 之集合遍歷

Java8 新特性 Stream Api 之集合遍歷

前言

隨著java版本的不斷更新迭代,java開發也可以變得甜甜的,最新版本都到java11了,但是後面版本也是不在提供商用支援,需要收費,但是java8 依然是持續免費更新使用的,後面版本也更新很快眼花繚亂,所以穩定使用還是用 java8 把既可以體驗到新功能,又不需要,煩惱升級帶來的bug

新特性

比較新的的特性就是流Stream ,和lambda表示式

圖上面就是一些常用的方法,延遲方法,就是對資料作處理中間方法,終結方法就是最後符合好處理的資料結束方法

延遲方法和lambda表示式的延遲載入的原理一樣,它可以進行鏈式程式設計如list.().filter().map().limit(),可以一直點下去最後一步由方法為count

或者foreach載入資料

stream集合遍歷forEach

遍歷list直接list.stream().forEach進行遍歷

        List<String> a=new ArrayList<>();
        a.add("judy");
        a.add("Tom");
        //lambda表示式
        a.stream().forEach(s -> System.out.println(s));
        
        a.stream().forEach(s -> {
            System.out.println(s);
            System.out.println(2);
        });

集合複雜物件遍歷

        Student student = new Student();
        student.setAddress("上海市黃浦區陸家浜路");
        student.setName("judy");
        student.setAge(26);
        List<Student> students = new ArrayList<>();
        students.add(student);

        //lambda表示式
        students.stream().forEach(student1 -> System.out.println(student1.name));
        
        students.stream().forEach(student1 -> {
            System.out.println(student1.name);
            System.out.println(student1.age);
            System.out.println(student1.address);
        });

stream條件過濾filter

使用list.stream().filter()進行過濾條件,為true 條件成立才會執行下面語句

        List<String> a = new ArrayList<>();
        a.add("judy");
        a.add("Tom");
        a.add("   ");
        //lambda表示式  是judy才打印
        a.stream().filter(s -> s.equals("judy")).forEach(s -> System.out.println(s));
        // 不是空才打印
        a.stream().filter(s -> !s.isEmpty()).forEach(s -> System.out.println(s));

複雜物件多條件判斷過濾

        Student student = new Student();
        student.setAddress("上海市黃浦區陸家浜路");
        student.setName("judy");
        student.setAge(26);
        List<Student> students = new ArrayList<>();
        students.add(student);

        //lambda表示式  學生年紀大於28才打印
        students.stream().filter(student1 -> student1.getAge()>28).forEach(student1 -> System.out.println(student1.name));

        //多個條件過濾,同時成立 學生姓名是以張開頭,並且長度等於3 ,lambda表示式 列印
        students.stream().filter(s->s.getName().startsWith("張")).filter(s-> s.getName().length() == 3).forEach(System.out::println);

        students.stream().forEach(student1 -> {
            System.out.println(student1.name);
            System.out.println(student1.age);
            System.out.println(student1.address);
        });

stream元素對映map

stream流中的元素對映到另一個流中,這個是在後期經常用到的,比如方法所接收的返回值是A,但是接收的卻是B

  1. 將String型別的流轉換為Integer 型別
  Stream<String> stringStream = Stream.of("1", "2", "3", "4", "5", "6");
  stringStream.map(str->Integer.parseInt(str)).forEach(System.out::println);
  1. 集合型別轉換
    在做許可權處理要求許可權不能重複,所以list集合轉換為set集合
      List<String> a = new ArrayList<>();
        a.add("judy");
        a.add("Tom");
        a.add("   ");
        a.stream().map(s -> s).collect(Collectors.toSet()).forEach(s -> System.out.printf(s));

方法需要返回的是List ,但是這裡只有List,此時就要想到stream().map

    public  List<String> queryNamesByIds(List<Long> ids){
        List<Category> categories = this.categoryMapper.selectByIdList(ids);
       return  categories.stream().map(category -> category.getName()).collect(Collectors.toList());
    }

List<Object>轉化為List<Cart>,其中List<Object>中的Object為Cart的json物件

        //查詢購物車資料(將List<Object>變成List<Cart>)
        return carts.stream().map(o -> JsonUtils.parse(o.toString(),Cart.class)).collect(Collectors.toList());

stream兩個流合併成一個流contract

       Stream<String> streamA = Stream.of("張無忌","張翠山");
        Stream<String> streamB = Stream.of("美羊羊","喜羊羊");
        //寫法1
        //Stream.concat(streamA, streamB).forEach(System.out::println);
        
        //寫法2
       Stream<String> result=  Stream.concat(streamA, streamB);
       result.forEach(name-> System.out.println(name));

參考文章