java treeset怎么自定义排序

46次阅读
没有评论

共计 936 个字符,预计需要花费 3 分钟才能阅读完成。

要自定义排序,可以通过实现 Comparator 接口来实现。Comparator 接口有一个 compare 方法,可以根据自定义的排序规则来比较两个对象的大小。

以下是一个示例,自定义了一个 Person 类,并在 TreeSet 中按照年龄进行排序:

import java.util.Comparator;
import java.util.TreeSet;

class Person {private String name;
    private int age;

    public Person(String name, int age) {this.name = name;
        this.age = age;
    }

    public String getName() {return name;
    }

    public int getAge() {return age;
    }
}

class AgeComparator implements Comparator<Person> {@Override
    public int compare(Person p1, Person p2) {return p1.getAge() - p2.getAge();
    }
}

public class Main {public static void main(String[] args) {TreeSet<Person> set = new TreeSet<>(new AgeComparator());
        set.add(new Person("Alice", 25));
        set.add(new Person("Bob", 30));
        set.add(new Person("Charlie", 20));

        for (Person person : set) {System.out.println(person.getName() + " - " + person.getAge());
        }
    }
}

输出结果为:

Charlie - 20
Alice - 25
Bob - 30

在这个示例中,AgeComparator 类实现了 Comparator 接口,并重写了 compare 方法,根据 Person 对象的 age 属性进行比较。然后在创建 TreeSet 对象时,将 AgeComparator 对象作为参数传入,这样 TreeSet 会根据 AgeComparator 定义的排序规则来进行排序。

丸趣 TV 网 – 提供最优质的资源集合!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2024-01-29发表,共计936字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)