List<User> userList = userDao.selectByUserId(user.getId());
List<Long> userIds = userList.stream().map(User::getId).collect(Collectors.toList());

换成现在常用的写法就是:

List<Long> userIds = new ArrayList<>();
for (User user : userList) {
      userIds.add(user.getId());
}

stream优点

无存储。stream不是一种数据结构,它只是某种数据源的一个视图,数据源可以是一个数组,Java容器或I/O channel等。
为函数式编程而生。对stream的任何修改都不会修改背后的数据源,比如对stream执行过滤操作并不会删除被过滤的元素,而是会产生一个不包含被过滤元素的新stream。
惰式执行。stream上的操作并不会立即执行,只有等到用户真正需要结果的时候才会执行。
可消费性。stream只能被“消费”一次,一旦遍历过就会失效,就像容器的迭代器那样,想要再次遍历必须重新生成。
stream().map()方法的使用示例:

再看几个例子:数组字母小写变大写
List<String> list= Arrays.asList("a", "b", "c", "d");

List<String> collect =list.stream().map(String::toUpperCase).collect(Collectors.toList());
System.out.println(collect); //[A, B, C, D]

数组所有元素,按某种规律计算:
List<Integer> num = Arrays.asList(1,2,3,4,5);
List<Integer> collect1 = num.stream().map(n -> n * 2).collect(Collectors.toList());
System.out.println(collect1); //[2, 4, 6, 8, 10]

转载于:https://www.cnblogs.com/ngy0217/p/11080840.html

最后修改:2022 年 02 月 02 日 02 : 55 PM
如果觉得我的文章对你有用,请随意赞赏