jdk1.8list的stream流常用总结

1.过滤filter

//过滤filter:获取年龄大于22的用户
list.stream().filter(user -> user.getAge() > 22).collect(Collectors.toList());

2.去重

//去重:按照所有字段
list.stream().distinct().collect(Collectors.toList());
//去重:按照一个字段
list = list.stream().collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new TreeSet<>(Comparator.comparing(user -> user.getUserName()))), ArrayList::new));
//去重:按照多个字段
 list = list.stream().collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new TreeSet<>(Comparator.comparing(user -> user.getUserName()+";"+user.getAge()))), ArrayList::new));

3.排序

//排序:按照单个字段,默认升序
list = list.stream().sorted(Comparator.comparing(user -> user.getId())).collect(Collectors.toList());
//排序:按照多个字段,默认升序
list.stream().sorted(Comparator.comparing(User::getId).thenComparing(User::getAge)).collect(Collectors.toList());
//排序:按照多个字段,有升序,有降序
 list = list.stream().sorted(Comparator.comparing(User::getId).reversed().thenComparing(User::getAge)).collect(Collectors.toList());
//排序:
	list = list.stream().sorted(Comparator.comparing(node -> ((node == null || node.toString().split("_").length == 0 || StringUtil.isEmpty(node.toString().split("_")[1])) ? "0" : node.toString().split("_")[1])).thenComparing(node -> ((node == null || node.toString().split("_").length == 0 || StringUtil.isEmpty(node.toString().split("_")[0])) ? "0" : node.toString().split("_")[0]))).collect(Collectors.toList());
		

4.拼接

//拼接
String result = list.stream().map(User::getUserName).collect(Collectors.joining(","));

5.转map

//转为map
Map<String,List<User>> map = list.stream().collect(Collectors.groupingBy(User::getUserName));

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值