zoukankan      html  css  js  c++  java
  • Java基础之实现对象可比较

    一般,Java中通过接口实现两个对象的比较,比较常用就是Comparable接口和Comparator接口。首先类要实现接口,并且使用泛型规定要进行比较的对象所属的类,然后类实现了接口后,还需要实现接口定义的比较方法,在这些方法中传入需要比较大小的另一个对象,通过选定的成员变量与之比较,如果大于则返回1,小于返回-1,相等返回0。

    Comparable实现

    public class People implements Comparable<People>{    
        private String name;  
        private int age;
    
        public People(String name, int age) {
            super();
            this.name = name;
            this.age = age;
        }
        
        public int getAge() {
            return age;
        }  
        
    
        public void setAge(int age) {
            this.age = age;
        }
    
        public String getName() {
            return name;
        }
    
        public void setName(String name) {
            this.name = name;
        }
        
        @Override
        public int compareTo(People o) {
            // 按年龄从小到大排序
            if(this.age > o.getAge()) {
                return 1;
            } else if (this.age < o.getAge()) {
                return -1;
            }
            // 相等情况
            return 0;
        }
    }
    

    排序测试:

    import java.util.ArrayList;
    import java.util.Collections;
    public class Test {    
        public static void main(String[] args) {
            People p1 = new People("fei", 35);
            People p2 = new People("qiang", 22);
            People p3 = new People("sheng", 24);
            ArrayList<People> list = new ArrayList<People>();
            list.add(p1);
            list.add(p2);
            list.add(p3);
            Collections.sort(list);
            for(People p:list) {
                System.out.println("name:"+p.getName()+", age:"+p.getAge()+"。");
            }
        }
    }
    结果:
    name:qiang, age:22。
    name:sheng, age:24。
    name:fei, age:35。
    

    Comparator实现

    import java.util.Comparator;
    public class PeopleComparator implements Comparator<People>{
        @Override
        public int compare(People o1, People o2) {
            // 从大到小排序
           if(o1.getAge() > o2.getAge()) {
               return -1;
           } else if (o1.getAge() < o2.getAge()) {
               return 1;
           }
            return 0;
        }
    }
    
    

    排序测试:

    public class Test {    
        public static void main(String[] args) {
            People p1 = new People("fei", 35);
            People p2 = new People("qiang", 22);
            People p3 = new People("sheng", 24);
            ArrayList<People> list = new ArrayList<People>();
            list.add(p1);
            list.add(p2);
            list.add(p3);
            // 指定一个比较器
            list.sort(new PeopleComparator());
            for(People p:list) {
                System.out.println("name:"+p.getName()+", age:"+p.getAge()+"。");
            }
        }
    }
    结果:
    name:fei, age:35。
    name:sheng, age:24。
    name:qiang, age:22。
    

    两种方式比较

    1:Comparable是在类内部定义的方法实现的排序,Compartor是在类外部实现的排序。
    2: 一个类实现了Comparable接口则表明这个类的对象之间是可以互相比较的,这个类对象组成的集合就可以直接使用sort方法排序。
    3:Comparator可以看成一种算法的实现,讲算法和数据分离,可以定义多个比较器实现比如升序、降序等。

  • 相关阅读:
    UESTC_王之迷宫 2015 UESTC Training for Search Algorithm & String<Problem A>
    UESTC_The Most Wonderful Competition CDOJ 56
    UESTC_神秘绑架案 CDOJ 881
    MFC 自定义消息的一般过程
    MFC 如何添加自定义消息
    MFC子窗口向父窗口发送消息
    MFC子窗口和父窗口
    单链表
    C++ STL基本容器的使用
    C++ Primer 3rd 读书笔记
  • 原文地址:https://www.cnblogs.com/feiqiangsheng/p/11142494.html
Copyright © 2011-2022 走看看