5、JDK1.8新特性

5、JDK1.8新特性,第1张

5、JDK1.8新特性 5、JDK1.8新特性

什么是Stream?
Stream是元素的集合,这点让Stream看起来有些类似Iterator;
可以支持顺序和并行的对原Stream进行汇聚的 *** 作
我们可以把Stream当成一个高级版本的Iterator。原始版本的Iterator,用户只能一个一个的
遍历元素并对其执行某些 *** 作;高级版本的Stream,用户只要给出需要对其包含的元
素执行什么 *** 作,比如“过滤掉长度大于10的字符串”、“获取每个字符串的首字母”
等,具体这些 *** 作如何应用到每个元素上,就给Stream就好了!
Stream的常见 *** 作有:

  1. < R> Stream map(Functionmapper)
    返回由给定函数应用于此流的元素的结果组成的流。
  2. < R > Stream< R >flatMap(Function> mapper)
    返回由通过将提供的映射函数应用于每个元素而产
    生的映射流的内容来替换该流的每个元素的结果的
    流。
  3. Stream< T > filter(Predicate predicate) 返回由与此给定谓词匹配的此流的元素组成的流。
  4. void forEach(Consumer action) 对此流的每个元素执行 *** 作。
  5. Optional< T> findFirst() 返回描述此流的第一个元素的Optional如果流为空,
    则返回一个空的Optional 。
  6. Optional< T> reduce(BinaryOperator< T> accumulator)
    使用 associative累积函数对此流的元素执行
    reduction ,并返回描述减小值的 Optional (如果
    有)。
  7. Stream< T> peek(Consumer action) 返回由该流的元素组成的流,另外在从生成的流中
    消耗元素时对每个元素执行提供的 *** 作。
  8. 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) {

		Stream stream=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

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5138756.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-17
下一篇 2022-11-17

发表评论

登录后才能评论

评论列表(0条)

保存