//生成字符数组
List<String> list = Arrays.asList("a", "b", "c", "d");
//变大写
List<String> stringList = list.stream().map(String::toUpperCase).collect(Collectors.toList());
System.out.println(stringList);//[A, B, C, D]
//数组
List<Integer> num = Arrays.asList(1,2,3,4,5);
//2倍
List<Integer> num2 = num.stream().map(n -> n * 2).collect(Collectors.toList());
System.out.println(num2);//[2, 4, 6, 8, 10]
/**
* Student(Id, name)
* studentList[{1, zhangsan}, {2, lisi}]
*/
//获取学生数组中的每个学生id
List<String> studentIds = studentList.stream().map(Student::getStudentId).collect(Collectors.toList());
System.out.println(studentIds );//[1, 2]
正常的思路是遍历list取出每个需要的值,是没问题的,不过使用stream()效率更高
stream()优点
-
无存储。stream不是一种数据结构,它只是某种数据源的一个视图,数据源可以是一个数组,Java容器或I/O channel等。
-
为函数式编程而生。对stream的任何修改都不会修改背后的数据源,比如对stream执行过滤操作并不会删除被过滤的元素,而是会产生一个不包含被过滤元素的新stream。
-
惰式执行。stream上的操作并不会立即执行,只有等到用户真正需要结果的时候才会执行。
-
可消费性。stream只能被“消费”一次,一旦遍历过就会失效,就像容器的迭代器那样,想要再次遍历必须重新生成。