赞
踩
名称 | 说明 |
---|---|
Stream filter(Predicate<? super T> predicate) | 用于对流中的数据进行过滤 |
Stream limit(long maxSize) | 获取前几个元素 |
Stream skip(long n) | 跳过前几个元素 |
Stream distinct() | 去除流中重复的元素。依赖(hashCode和equals方法) |
static Stream concat(Stream a,Stream b) | 合并a和b两个流为一个流 |
注意:
名称 | 说明 |
---|---|
void forEach(Consumer action) | 对此流的每个元素执行遍历操作 |
long count() | 返回此流中的元素数 |
List<String> list = new ArrayList<>(); Collections.addAll(list , "张文君","张文俊","周文君","周三","李达","张俊","张俊"); // Stream<T> filter(Predicate<? super T> predicate); list.stream().filter(s->s.startsWith("张")).forEach(s-> System.out.println(s)); long size = list.stream().filter(s ->s.length() == 3).count(); System.out.println(size); // list.stream().filter(s->s.startsWith("张")).limit(2).forEach(s-> System.out.println(s)); list.stream().filter(s->s.startsWith("张")).limit(2).forEach(System.out::println); //只去姓张的前两个元素 前后变量一样的话可以这样简化 list.stream().filter(s->s.startsWith("张")).skip(2).forEach(System.out::println); // map加工方法:第一个参数原材料 -> 第二个参数是加工后的结果 // 给集合元素的前面都加上一个: 黑马的: list.stream().map(s->"黑马的:"+s).forEach(s-> System.out.println(s)); //需求:把所有的名称 都加工成一个学生对象。 // list.stream().map(s-> new Student()).forEach(s-> System.out.println(s)); list.stream().map(Student::new).forEach(System.out::println); //合并流。 Stream<String> s1 = list.stream().filter(s -> s.startsWith("张")); Stream<String> s2 = Stream.of("java","mysql"); //public static <T> Stream<T> concat(Stream<? extends T> a, Stream<? extends T> b) Stream<String> s3 = Stream.concat(s1 , s2); s3.forEach(s -> System.out.println(s)); //s3.distinct().forEach(s -> System.out.println(s)); //去重复版本 Stream<String> s4 = list.stream().filter(s -> s.startsWith("张")); Stream<Integer> s5 = Stream.of(21,22); //如果s4,s5不是一种类型,那么左边要用他们两个共同的父类object来接 Stream<Object> s6 = Stream.concat(s4 , s5); s6.forEach(s -> System.out.println(s));
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。