关于比较器

比较器的案例分享

上csdn已经很久了,可是还没有写过一篇博客,今天终于觉得有这个必要了……
今天分享一个知识点:使用比较器对一个集合中的对象按指定中的指定属性进行排序

  • 案例的需求:

定义一个人类,在测试类中创建多个人类对象储存到对象集合中,根据年龄对集合中的对象按照升序排序

  • 主要用到的知识点

集合的工具类 :Collections 专门对集合进行操作
集合工具类的两个方法
public addAll(Collection<? super T> c, T… elements) -->> 一次性往集合中添加多个元素
public static < T > void sort(List< T > list,Comparator<? super T> c) -->>比较器

  • 代码准备 人类
public class Human {
    private String name;
    private int age;
    private String sex;

    public Human() {
    }

    public Human(String name, int age, String sex) {
        this.name = name;
        this.age = age;
        this.sex = sex;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public String getSex() {
        return sex;
    }

    public void setSex(String sex) {
        this.sex = sex;
    }

    @Override
    public String toString() {
        return "Human{" +
                "name='" + name + '\'' +
                ", age=" + age +
                ", sex='" + sex + '\'' +
                '}';
    }
}

  • 测试类
public class Test01 {
    public static void main(String[] args) {
    //创建集合对象
        List<Human> list = new ArrayList<>();
        //向集合中一次性添加多个对象元素
        Collections.addAll(list,
                new Human("张三",23,"男"),
                new Human("李四",44,"女"),
                new Human("王五",35,"男"),
                new Human("赵六",18,"女"),
                new Human("钱七",76,"男")
                );
                //生成比较器,对数据进行比较
       Collections.sort(list, new Comparator<Human>() {
           @Override
           public int compare(Human o1, Human o2) {
               int age1 = o1.getAge();
               int age2 = o2.getAge();
               return age1 -age2;       //升序排序 如果想要降序排序 那么就是 age2 - age1
           }
       });
       //打印集合查看效果
        System.out.println(list);
        //运行结果
        //[Human{name='赵六', age=18, sex='女'},
        //Human{name='张三', age=23, sex='男'},
        //Human{name='王五', age=35, sex='男'},
        //Human{name='李四', age=44, sex='女'},
        //Human{name='钱七', age=76, sex='男'}]
        //排序成功
    }
}

  • 案例分析:

1.在测试中创建一个用来储存人类对象的集合对象,
2.使用public addAll(Collection<? super T> c, T… elements)一次性往集合中添加多个人类对象元素
3.使用public static < T > void sort(List< T > list,Comparator<? super T> c)方法,将集合对象放入sort方法的参数列表中,在参数列表中new出Comparator匿名对象,泛型为< Human >
自动重写返回值为一个int类型的compare方法,方法的构造函数传入两个对象,使用对象调用指定对象的属性进行比较,如果返回值是参数一对应的属性值减去参数二的属性值,那么就是升序排序,反之则是降序排序

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值