1.定制排序,即是自己写一个比较器.可命名为MyComparator.
2.在定义set的时候,后面的()里面要 创建构造器对象
TreeSet<Person> set = new TreeSet<>(new MyComparator());
3.自定义的MyComparator类要实现 Comparator接口.里面用到的person类和book类就是用的是<Treeset之自然排序>中的person和book类, 还要重写 compare方法,传进来两个Person对象.自然排序看懂之后,定制排序就很简单.
无非就是在定义set的时候创建一个构造器作为参数.
自定义构造类实现Comparator接口.
重写compare方法.
4.重写compare方法的时候,方法的两个参数前面的代表this对象,则是要添加到set集合的对象,第二个参数是代表接口的对象.
package com.qf.demo7;
import java.util.Comparator;
import java.util.TreeSet;
import com.qf.demo6.Book;
import com.qf.demo6.Person;
/**
* 自然排序
* 集合泛型类 中 实现 Comparable , 重写 compareTo
* TreeSet构造方法不需要添加参数
* 定制排序
* 单独创建一个比较器的类 实现Comparator 重写 compare
* TreeSet构造方法必须添加 参数 comparator 对象
*
*
* @author Administrator
*
*/
public class Test {
public static void main(String[] args) {
TreeSet<Person> set = new TreeSet<>(new MyComparator());
set.add(new Person("xiaoming", 5, new Book("renzaijiogtu", 4)));
set.add(new Person("xiaoming", 1, new Book("renzaijiogtu", 4)));
set.add(new Person("xiaoming", 5, new Book("renzaijiogtu", 4)));
System.out.println(set);
}
}
// 比较器
class MyComparator implements Comparator<Person>{
// 参数1 相当于 调用者 参数2 相当于 参数
@Override // this--o1 o --> o2
public int compare(Person o1, Person o2) {
if(o1.getAge()>o2.getAge()){
return -1;
}else if(o1.getAge()<o2.getAge()){
return 1;
}else{
//这里和自然排序的一样
}
return 0;
}
}