在java的集合学习过程中,我们会接触到有关集合Colletion和Map的一些知识,在我们使用Set和Map 时候,有时候为了存储的数据时排好序的,我们通常会使用TreeSet 和TreeMap 来存储数据,这是因为在用TreeSet和TreeMap添加数据时,这两个类的底层都是红黑树,存储数据时,通过ComareTo() 和Comapre()方法来对数据进行比较,将其以一定的顺序插入的数中,再通过数的前序遍历,实现遍历获取后的数据是按一定顺序来的。那么ComapreTo() 和 Compare()方法有什么区别呢?
一:CompareTo()
CompareTo()是Comparable<T>接口中的一个抽象方法,所以,如果要能够使用该方法,必须继承Comparable<T>接口,同时重写 CompareTo()方法,一般我们所用到的八大数据类型的封装类都继承了Comparable<T>接口,并重写了CompareTo()方法,所以这些类都能够调用该方法来对数据进行比较
具体格式为 Object1.CompareTo(Object2) ;
返回值是一个int整型,当object1与Object2相等时返回0,小于时,返回一个负整数,大于时,返回一个正整数。
二:Compare(T o1,To2)
Compare(T o1,To2) 方法是Comparator <E>的 一个抽象方法,通常我们需要创建一个比较器类来继承Comparator <E>接口,并且实现Compare(T o1,To2)方法。但有时候我们对于创建的比较器类用的比较少,所以一般通过匿名内部类来实现该方法,
一般在创建TreeSet或者TreeMap对象的时候,TreeSet、TreeMap的构造方法中直接创建一个匿名内部类。
TreeMap<Student, String> tm = new TreeMap<Student, String>(
new Comparator<Student>() {
@Override
public int compare(Student s1, Student s2) {
// 主要条件
int num = s1.getAge() - s2.getAge();
// 次要条件
int num2 = num == 0 ? s1.getName().compareTo(
s2.getName()) : num;
return num2;
}
});
TreeSet<Student> ts = new TreeSet<Student>(new Comparator<Student>() {
@Override
public int compare(Student s1, Student s2) {
// 姓名长度
int num = s1.getName().length() - s2.getName().length();
// 姓名内容
int num2 = num == 0 ? s1.getName().compareTo(s2.getName())
: num;
// 年龄
int num3 = num2 == 0 ? s1.getAge() - s2.getAge() : num2;
return num3;
}
});