Java-如何使用TreeSet集合存储有序存储自定义类?

本文介绍了如何使用Java的TreeSet集合来存储自定义类,并保持有序。关键在于自定义类需要实现Comparable接口,重写compareTo方法,根据特定属性进行排序。示例中,创建了Person类并按年龄降序排序。
摘要由CSDN通过智能技术生成

TreeSet属于Set集合的子类,而Set集合属于Collection集合的子类,所以TreeSet是单值存储的。那么我们怎么使我们自己定义的类的数据进行顺序存储呢?

  1. 得在自定义类处创建一个Comparable接口
  2. 定义顺序存储的属性重写

我们首先创建一个Preson类,生成setter/getter、toString、equals和HashCode方法。

static class Preson implements Comparable<Preson>{
   
        //要比较的是Preson与Preson类
        private String name;
        private int age;

        /**
         * this 与 o 进行比较
         * 返回的数据是:
         *  1.  负数:this小
         *  2.  零:相同
         *  3.  正数:this大
         * @param o
         * @return
         */
        @Override
        public int compareTo(Preson o) {
   
            //比较年龄,进行排序
            //规定按照年龄升序
            if(this.age > o.age){
   
                return -1;
            }else if(this.age == o.age){
   
                //如果发现两个一样大,不存储第二个数据
                return 0;
            }
            return 1;
        }

        //生成构造方法
        public Preson() {
   
        }
        public Preson(String name, int age) {
   
            this.name = name;
            this.age = age;
        }

        //生成getter/setter
        public String getName() {
   
            return name;
        }

        public void setName(String name) {
   
            this.name = name;
        }

        public int getAge() {
   
            return age;
        }

        public void setAge(int age) {
   
            
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值