Treeset之定制排序

1.定制排序,即是自己写一个比较器.可命名为MyComparator.
2.在定义set的时候,后面的()里面要 创建构造器对象
TreeSet set = new TreeSet<>(new MyComparator());
3.自定义的MyComparator类要实现 Comparator接口.里面用到的person类和book类就是用的是中的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 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{
                    
                    // 参数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()

你可能感兴趣的:(Treeset之定制排序)