jkd8 Stream的使用

流的特性

无存储。stream不是一种数据结构,它只是某种数据源的一个视图,数据源可以是一个数组,Java容器或I/O channel等。
为函数式编程而生。对stream的任何修改都不会修改背后的数据源,比如对stream执行过滤操作并不会删除被过滤的元素,而是会产生一个不包含被过滤元素的新stream。
惰式执行。stream上的操作并不会立即执行,只有等到用户真正需要结果的时候才会执行。(中间操作为惰式执行,只有调用结束操作时才开始执行)
可消费性。stream只能被“消费”一次,一旦遍历过就会失效,就像容器的迭代器那样,想要再次遍历必须重新生成。
 

 

1.Stream的获取

 //数组
 String[] arr=new String[]{"abc","bcd","cde"};
 Stream<String> arrStream= Arrays.stream(arr);

 //集合
 List<String> strList = Arrays.asList("abc","bcd","cde");
 Stream<String> listStream=strList.stream();

 //数值
 Stream<String> stream=Stream.of("abc","bcd","cde");

2.添加List数据

    List<User> list=new ArrayList<User>();
    list.add(new User("张三",15));
    list.add(new User("李四",13));
    list.add(new User("王小五",18));
    list.add(new User("张六",17));
    list.add(new User("刘小七",14));
    list.add(new User("刘小七",14));

3.forEach方法迭代数据

list.stream().forEach((user)->System.out.println(user.getName()+user.getAge()));

 

4.sorted方法排序

reversed()---倒序

list.stream().sorted(Comparator.comparing(User::getAge).reversed()).forEach((user)->System.out.println(user.getName()+user.getAge()));

 

5.limit方法截断

获取前面3个元素

list.stream().limit(3).forEach(user -> System.out.println(user.getName()+user.getAge()));

6.skip():与limit互斥,使用该方法跳过元素

跳过前面3个元素

list.stream().skip(3).forEach((user)-> System.out.println(user.getName()+user.getAge()));

7.stream转list

List<User>  resList=list.stream().limit(3).collect(Collectors.toList());

8.distinct():使用该方法去重,注意:必须重写对应泛型的hashCode()和equals()方法

list.stream().distinct().forEach(user -> System.out.println(user.getName()+user.getAge()));

9.max,min,sum,avg,count

IntSummaryStatistics num=list.stream().mapToInt(user->user.getAge()).summaryStatistics(); System.out.println(num.getMax());
System.out.println(num.getAverage());
System.out.println(num.getCount());


Integer max=list.stream().max((a,b)->a.getAge()-b.getAge()).get().getAge();

10.map():接收一个方法作为参数,该函数会被应用到每个元素上,并将其映射成一个新的元素

List<String> nameList=list.stream().map(user -> user.getName()).collect(Collectors.toList());
发布了68 篇原创文章 · 获赞 93 · 访问量 8489

猜你喜欢

转载自blog.csdn.net/qq_34707456/article/details/103902434
今日推荐