【JAVA基础】-- List

java8

1.按顺序排列

List<Entity> list = new ArrayList();
//按时间顺序
list.stream().sorted(Comparator.comparing(Entity::getCreateTime)).collect(Collectors.toList());
//按时间逆序
list.stream().sorted(Comparator.comparing(Entity::getCreateTime).reversed()).collect(Collectors.toList());
//按id从小到大
List<User> sortUser = list.stream().sorted((u1, u2) -> u1.getId().compareTo(u2.getId())).collect(Collectors.toList());
按id从大到小
List<User> sortUser = list.stream().sorted((u1, u2) -> u2.getId().compareTo(u1.getId())).collect(Collectors.toList());

 

List<Integer> integerList = Arrays.asList(4, 5, 2, 3, 7, 9);
List<Integer> collect = integerList.stream()
        .map(i -> i * i).distinct()
        .collect(Collectors.toList());
Collections.sort(collect);  //升序
//collect.sort(Comparator.reverseOrder()); //倒序
collect.forEach(System.out::println);
// 如果两个苹果的重量一样重,怎么办?那就再找一个条件进行排序呗
inventory.sort(comparing(Apple::getWeight).reversed().thenComparing(Apple::getColor))

2.list分组去重

分组:

classEntities.stream().collect(Collectors.groupingBy(ClassEntity::getGrade));

去重(根据年级和专业,当年级和专业都相同的情况下看做是重复数据):

List<ClassEntity> distinctClass = classEntities.stream().collect(Collectors.collectingAndThen(Collectors.toCollection(() -> new TreeSet<>(Comparator.comparing(o -> o.getProfessionId() + ";" + o.getGrade()))), ArrayList::new));


通过hashSet去重(如将classNames去重):该种去重是bean完全相同的时候算重复数据

List<String> classNameList = new ArrayList(new HashSet(classNames));

补:java8 快速实现List转map 、分组、过滤等操作

       java找出2个集合相同和不同的元素(以及去除List中的重复元素)

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值