List 集合根据某个字段排序,去重

List 集合根据某个字段排序,去重

排序

List<FcalcTemp> fs = new ArrayList<>();
        fs.add(new FcalcTemp(new BigDecimal(0 + ""),0,2,1));
        fs.add(new FcalcTemp(new BigDecimal(0 + ""),0,2,2));
        fs.add(new FcalcTemp(new BigDecimal(0 + ""),0,1,3));
        fs.add(new FcalcTemp(new BigDecimal(0 + ""),0,1,4));
        fs.add(new FcalcTemp(new BigDecimal(0 + ""),0,2,5));

//1.
//        fs.sort((x,y) -> Integer.compare(x.getO(),y.getO()));

//2.
//        Collections.sort(fs, new Comparator<FcalcTemp>() {
//            @Override
//            public int compare(FcalcTemp o1, FcalcTemp o2) {
//                return o1.getO().compareTo(o2.getO());
//            }
//        });
        
        //3.
        // 添加 Comparator.reverseOrder() 为倒叙,可以继续加 thenComparing()
        fs.sort(Comparator.comparing(FcalcTemp::getO).thenComparing(FcalcTemp::getJ,Comparator.reverseOrder()));
        
		for (FcalcTemp f : fs) {
            System.out.println("f = " + f.getO() + "," + f.getJ());
        }

		// 一般集合正序
		List<String> orders = new ArrayList<>(map.keySet());
        Collections.sort(orders);

去重

            HashSet h = new HashSet(list);
            list.clear();
            list.addAll(h);
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值