TreeMap和TreeSet在排序时如何比较元素?Collections工具类中的sort方法如何比较元素?

TreeMap和TreeSet在排序时如何比较元素?Collections工具类中的sort方法如何比较元素?,第1张

TreeMap和TreeSet在排序时如何比较元素?Collections工具类中的sort方法如何比较元素?

考察点:Tree

 

TreeSet要求存放的对象所属的类必须实现Comparable接口,该接口提供了比较元素的compareTo()方法,当插入元素时会回调该方法比较元素的大小。TreeMap要求存放的键值对映射的键必须实现Comparable接口从而根据键对元素进行排序。Collections工具类的sort方法有两种重载的形式,第一种要求传入的待排序容器中存放的对象比较实现Comparable接口以实现元素的比较;第二种不强制性的要求容器中的元素必须可比较,但是要求传入第二个参数,参数是Comparator接口的子类型(需要重写compare方法实现元素的比较),相当于一个临时定义的排序规则,其实就是通过接口注入比较元素大小的算法,也是对回调模式的应用(Java中对函数式编程的支持)。

代码示例:

public classStudent implements Comparable<Student> {     private Stringname;        // 姓名     private int age; // 年龄     public Student(String name, int age) {         this.name = name;         this.age = age;     }     @Override     public String toString() {         return "Student [name=" +name + ", age=" + age + "]";     }     @Override     public int compareTo(Student o) {         return this.age - o.age; // 比较年龄(年龄的升序)     } } import java.util.Set; import java.util.TreeSet; class Test01 {     public static void main(String[] args) {         Set<Student> set = new TreeSet<>();     // Java 7     } } import java.util.Set; import java.util.TreeSet; class Test01 {     public static void main(String[] args) {         Set<Student> set = new TreeSet<>();     // Java 7的钻石语法(构造器后面的尖括号中不需要写类型)         set.add(new Student("HaoLUO", 33));         set.add(new Student("XJWANG", 32));         set.add(new Student("BruceLEE", 60));         set.add(new Student("BobYANG", 22));for(Student stu : set) {  System.out.println(stu);         } //   set.add(new Student("HaoLUO", 33));         set.add(new Student("XJWANG", 32));         set.add(new Student("BruceLEE", 60));         set.add(new Student("BobYANG", 22));         for(Student stu : set) {  System.out.println(stu);         } //      输出结果:  //      Student [name=Bob YANG, age=22] //      Student [name=XJ WANG, age=32] //      Student [name=Hao LUO, age=33] //      Student [name=Bruce LEE, age=60]     } } //      Student [name=Bob YANG, age=22] //      Student [name=XJ WANG, age=32] //      Student [name=Hao LUO, age=33] //      Student [name=Bruce LEE, age=60]     } }

 

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/4889130.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-11-11
下一篇 2022-11-12

发表评论

登录后才能评论

评论列表(0条)

保存