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

本文介绍了在Java中如何对List集合进行排序和去重。示例代码展示了使用Lambda表达式、匿名内部类以及Comparator进行排序的方法,并通过HashSet实现去重。示例集合包含FcalcTemp对象,排序依据是对象的特定字段o和j。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值