当前位置: 首页 > 面试题库 >

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

章德惠
2023-03-14
本文向大家介绍TreeMap和TreeSet在排序时如何比较元素?Collections工具类中的sort()方法如何比较元素?相关面试题,主要包含被问及TreeMap和TreeSet在排序时如何比较元素?Collections工具类中的sort()方法如何比较元素?时的应答技巧和注意事项,需要的朋友参考一下

考察点:Tree

 

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

代码示例:

public class
Student 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]
     }
 }

 

 类似资料:
  • 我编写了下面的代码来从ArrayList中获取重复的元素。我的aerospikePIDs列表没有任何重复的值,但是当我执行下面的代码时,它仍然在读取if条件。

  • 问题内容: 我一直在阅读编程书,作者展示了一个类似的示例: 所以,我想知道为什么为什么等于假?如何比较这两个元组? 顺便说一句,这本书没有解释。 问题答案: 比较元组的位置:将第一元组的第一项与第二元组的第一项进行比较;如果它们不相等(即第一个大于或小于第二个),则这是比较的结果,否则将考虑第二个,然后是第三个,依此类推。 请参阅常见序列操作: 相同类型的序列也支持比较。特别是,通过比较相应的元素

  • 问题内容: 我有这样的XML消息: 我想将被测试方法产生的这种类型的消息与预期的消息进行比较,但我不在乎。因此,我希望以上消息被认为等于: 我正在使用XMLUnit的最新版本。 我在想答案是创建一个习惯。如果有准备好要使用的东西,我只是不想重新发明轮子。 欢迎使用XMLUnit以外的库的建议。 问题答案: 自从回答了这个问题以来,XMLUnit发生了很多变化。 现在,您可以在使用时轻松忽略节​​点

  • 本文向大家介绍JAVA中Collections工具类sort()排序方法,包括了JAVA中Collections工具类sort()排序方法的使用技巧和注意事项,需要的朋友参考一下 本问介绍了Collections工具类两种sort()方法,具体如下: 一、Collections工具类两种sort()方法 格式一: public static <T extends Comparable<? supe

  • 这是我目前所掌握的: video.cpp文件: video.h文件: 我真的不知道如何正确实现气泡排序。我在youtube上查阅了多个不同的视频和stackoverflow上的帖子,但我似乎无法弄清楚如何在我的类中对一个特定的参数进行排序。 我的教授给了我们这些关于在我们班内排序的指示: 在对视频进行排序时,您需要能够确定两个视频对象应该如何排序。最简单的方法是编写成员函数来处理类视频中的比较。例