JAVA小白的崛起之路(十一)Stream

阅读: 评论:0

JAVA小白的崛起之路(十一)Stream

JAVA小白的崛起之路(十一)Stream

JAVA小白的崛起之路(十一)Stream

Stream的操作三个步骤

1、创建Stream
一个数据源(如:集合、数组),获取一个流
2、中间操作
一个中间操作链,对数据源的数据进行处理
3、终止操作
一个终止操作,执行中间操作链,并产生结果

Stream
集合|数组->数据源,侧重与数据的存储
Stream对数据的计算,是对数据操作的元素序列

特点:
1.Stream不能存储数据
2.stream操作不影响数据源,得到一个新的stream
3.stream一次性的流,已经使用过后的流不能再次使用了,每次使用返回一个新的流
4.惰性加载|延迟执行

/*** StreamAPI三个操作步骤: 
* 1、创建Stream 
* 2、中间操作 
* 3、终止操作 
*/ 
public class TestStreamAPI1 { // 创建Streampublic void test1() { // 1、可以通过Conllection系列集合提供的顺序流stream()或并行流 parallelStream() List<String> list = new ArrayList<>(); Stream<String> stream1 = list.stream(); stream1 = list.parallelStream(); // 2、通过Arrays中的静态方法stream()获取数据流 Integer ints[] = new Integer[10]; Stream<Integer> stream2 = Arrays.stream(ints); // 3、通过Stream类中的静态方法of() Stream<String> stream3 = Stream.of("aa", "bb", "cc");String str[] = new String[10]; Stream<String> stream4 = Stream.of(str);}
}
中间操作:

​ 筛选和切片

​ **filter:**接收Lambda,从流中排除某些元素

Stream<Employee> stream = list.stream();//2.中间 操作
Stream<Employee> s = stream.filter(e->{System.out.println("-----------------过滤1----------------------");Age()<=35;});

​ **limit:**截断流,使其元素不超过给定数量

emps.stream()
.filter((e) -> e.getSalary() > 5000) //lambda表达式
.limit(2)        
.forEach(System.out::println); 

​ **skip:**跳过元素,返回一个扔掉了前n个元素的流,若流中元素不足n个,则返回一个空流。

 emps.stream()        .filter((e) -> e.getSalary() > 5000)        .skip(2)        .forEach(System.out::println); 

​ **distinct:**筛选,通过流所生产元素的hashCode()和equals()去除重复元素

 emps.stream()        .filter((e) -> e.getSalary() > 5000)        .distinct()        .forEach(System.out::println); 

sorted(Comparable)-自然排序

List<String> list = Arrays.asList("cc", "aa", "bb", "ee", "dd");list.stream()        .sorted()        .forEach(System.out::println); 

sorted(Comparator)-定制排序

emps.stream() //重写比较器  .sorted((e1, e2) -> { Age().Age())) {Name()Name());}else { Age()Age()); } }).forEach(System.out::println);
终止操作

allMatch-检查是否匹配所有元素

boolean  flag = list.stream().allMatch(e-&Age()>=30);

anyMatch-检查是否至少匹配一个元素

 boolean b3 = emps.stream()        .noneMatch((e) -> e.getStatus().equals(Status.OTHER));    

findFirst-返回第一个元素

Optional<Employee> op1 = emps.stream()        .sorted((e1, e2) -> Salary(), e2.getSalary()))        				.findFirst();  

findAny-返回当前流中的任意元素

count-返回流中元素的总个数

max-返回流中最大值

min-返回流中最小值

收集

List-把流中所有元素收集到List中

List<String> list = emps.stream()    
.map(Employee::getName)    
.List());list.forEach(System.out::println);

// Set-把流中所有元素收集到Set中,删除重复项

Set<String> set = emps.stream()    .map(Employee::getName)    .Set()); 
set.forEach(System.out::println);

Map-把流中所有元素收集到Map中,当出现相同的key时会抛异常

Map<String, Integer> map = emps.stream()   .Map(Employee::getName, Employee::getAge)); 
System.out.println(map);

flatMap() 流中的每一个数据当做参数,进行操作 ,得到的结果必须 是 一个流,最终会结合成一个流返回

public class StreamDemo03 {static List<Employee> list = Arrays.asList(new Employee(1001,"胡歌",35),new Employee(1002,"彭于晏",30),new Employee(1003,"金城武",32),new Employee(1004,"宋承宪",31),new Employee(1004,"谢霆锋",38));public static void main(String[] args) {testMap();Stream<String> s = Stream.of("aaa","bbb","ccc");//map/*  Stream<Stream<Character>>  ss = s.map(StreamDemo03::testCharacter);  // {{a,a,a},{b,b,b},{c,c,c}}ss.forEach(sss->sss.forEach(System.out::println));*///flatMapStream<Character> haha= s.flatMap(StreamDemo03::testCharacter);  //{a,a,a,b,b,b,c,c,c}haha.forEach(System.out::println);}//map 得到所有的员工信息打印public static void testMap(){list.stream().map(e-&Name()).forEach(System.out::println);}//public static Stream<Character> testCharacter(String str){List<Character> ls = new ArrayList<>();for(Character CharArray()){ls.add(ch);}return ls.stream();}
}

注意:
1、Stream自己不会存储元素·
2、Stream不会改变源对象。相反,会返回一个持有结果的新Stream。
3、Stream操作是延迟执行的,这意味着他们会等到需要结果的时候才执行。

本文发布于:2024-02-01 17:12:11,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/170677873038190.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:之路   JAVA   Stream
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23