Collections.frequency的使用

博客探讨了Java中Comparable接口的作用,它用于实现对象的排序。内容详细介绍了compareTo方法的用法,展示了如何在Person类中实现Comparable以进行数据比较。示例代码展示了使用TreeSet进行数据去重,强调了排序和分组的区别,并提供了使用Collections.frequency进行数据频率统计的方法。

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

Comparable接口
1:所有可以 “排序” 的类都实现了java.lang.Comparable接口,Comparable接口中只有一个方法。
2:public int compareTo(Object obj) ;
该方法:
返回 0 表示 this == obj
返回整数表示 this > obj
返回负数表示 this < obj
3:实现了 Comparable 接口的类通过实现 comparaTo 方法从而确定该类对象的排序方式。

// TreeSet 比较要实现Comparable
@Data
public class Person implements Serializable ,Comparable{

    private String family;
    
    private String data;
    
    private String label;

    public Person(String family, String data, String label) {
        this.family = family;
        this.data = data;
        this.label = label;
    }

    @Override
    public int compareTo(Object o) {
        int flag = 1;
        if(o instanceof Person){
            if(Objects.equals(this.getData(), ((Person) o).getData()))
                flag = 0;
        }
        return flag;
    }

        public static void main(String[] args) {
        List<Person> list = new ArrayList<>();
        list.add(new Person("张三", "13129524650", ""));
        list.add(new Person("张三", "13129524650", ""));
        list.add(new Person("张三", "13129524650", ""));
        list.add(new Person("张三", "13129524650", ""));
        list.add(new Person("张三", "13129524650", ""));
        list.add(new Person("张三", "13129524650", ""));
        list.add(new Person("张三", "13129524650", ""));
        list.add(new Person("张三", "13129524650", ""));
        list.add(new Person("张三", "13129524650", ""));
        list.add(new Person("张三", "13129524650", ""));
        list.add(new Person("张三", "13129524650", ""));
        list.add(new Person("李四", "13129524651", ""));
        list.add(new Person("王五", "13129524652", ""));
        list.add(new Person("李四", "13129524651", ""));
        list.add(new Person("王五", "13129524652", ""));

        Set<Person> dup = new TreeSet<>(list);
        System.out.println("测试数据条数:" + dup.size());
        List<Person> list1 = new ArrayList<>();
        dup.forEach((key) -> {
            int data = Collections.frequency(list, key);  // list中比较是否有相同的数据,相同则返回1
            Person test1 = new Person(key.getFamily(),key.getData(),String.valueOf(data));
            System.out.println(test1);
            list1.add(test1);
        });
        System.out.println(list1);
    }
}

一般需要做比较的逻辑都可以使用的上Comparator,最常用的场景就是排序和分组,排序常使用Arrays和Collections的sort
方法,而分组则可以使用上面提供的divider方法。
排序和分组的区别在于:
排序时,两个对象比较的结果有三种:大于,等于,小于。
分组时,两个对象比较的结果只有两种:等于(两个对象属于同一组),不等于(两个对象属于不同组)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值