什么是Stream?
Stream是元素的集合,这点让Stream看起来有些类似Iterator;
可以支持顺序和并行的对原Stream进行汇聚的 *** 作;
我们可以把Stream当成一个高级版本的Iterator。原始版本的Iterator,用户只能一个一个的
遍历元素并对其执行某些 *** 作;高级版本的Stream,用户只要给出需要对其包含的元
素执行什么 *** 作,比如“过滤掉长度大于10的字符串”、“获取每个字符串的首字母”
等,具体这些 *** 作如何应用到每个元素上,就给Stream就好了!
Stream的常见 *** 作有:
- < R> Stream map(Function super T,? extends R>mapper)
返回由给定函数应用于此流的元素的结果组成的流。 - < R > Stream< R >flatMap(Function super T,? extendsStream extends R>> mapper)
返回由通过将提供的映射函数应用于每个元素而产
生的映射流的内容来替换该流的每个元素的结果的
流。 - Stream< T > filter(Predicate super T> predicate) 返回由与此给定谓词匹配的此流的元素组成的流。
- void forEach(Consumer super T> action) 对此流的每个元素执行 *** 作。
- Optional< T> findFirst() 返回描述此流的第一个元素的Optional如果流为空,
则返回一个空的Optional 。 - Optional< T> reduce(BinaryOperator< T> accumulator)
使用 associative累积函数对此流的元素执行
reduction ,并返回描述减小值的 Optional (如果
有)。 - Stream< T> peek(Consumer super T> action) 返回由该流的元素组成的流,另外在从生成的流中
消耗元素时对每个元素执行提供的 *** 作。 - Stream< T> sorted() 返回由此流的元素组成的流,根据自然顺序排序。
import java.lang.StackWalker.Option; import java.util.List; import java.util.Optional; import java.util.stream.Collectors; import java.util.stream.Stream; public class StreamDemo { public static void main(String[] args) { Streamstream=Stream.of("good","good","study","day","day","up"); //foreach方法 //stream.forEach((s)->System.out.println(s)); //filter(断言,过滤的作用) //stream.filter((s)->s.length()>=3).forEach(System.out::println); //distinct(去除重复) //stream.distinct().forEach(System.out::println); //map(映射)toUpperCase转大写 //stream.map(s->s.toUpperCase()).forEach(s->System.out.println(s)); //reduce(找最长的) Optional opt=stream.reduce((s1,s2)->s1.length()>=s2.length()?s1:s2); System.out.println(opt.get()); //collect List list=stream.collect(Collectors.toList()); list.forEach(s->System.out.println(s)); //::方法的引用 //引用静态方法 Integer::valueOf //引用对象的方法 list::add //引用构造方法 ArrayList::new } }
更多方法参考API
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)