Comparable与Comparator之区别与使用

本文介绍Java中通过实现Comparable接口和Comparator接口来进行对象排序的方法。详细解释了如何自定义Person类的自然排序,并通过LastNameComparator与FirstNameComparator实现了按姓氏和名字进行排序。

Comparable接口强行对实现它的每个类的对象进行整体排序。此排序被称为该类的自然排序,类的 compareTo 方法被称为它的自然比较方法。实现此接口的对象列表(和数组)可以通过Collections.sort(和 Arrays.sort)进行自动排序。实现此接口的对象可以用作有序映射表中的键或有序集合中的元素,无需指定比较器。

Comparator比较函数强行对某些对象 collection 进行整体排序。可以将 Comparator 传递给 sort 方法(如 Collections.sort),从而允许在排序顺序上实现精确控制。还可以使用 Comparator 来控制某些数据结构(如 TreeSet 或 TreeMap)的顺序。

以下为一个人的排序实例:

package com.lyh.util.compar;
import java.util.Comparator;
//实现按FirstName进行排序
public class FirstNameComparator implements Comparator {
public FirstNameComparator() {
         // TODO Auto-generated constructor stub
}
public int compare(Object person, Object anotherPerson) {
         // TODO Auto-generated method stub
             String lastName1 = ((Person) person).getLastName().toUpperCase();
             String firstName1 = ((Person) person).getFirstName().toUpperCase();
             String lastName2 = ((Person) anotherPerson).getLastName().toUpperCase();
             String firstName2 = ((Person) anotherPerson).getFirstName().toUpperCase();
      
             if (firstName1.equals(firstName2)) {
                 return lastName1.compareTo(lastName2);
               } else {
                 return firstName1.compareTo(firstName2);
               }
}

}
//实现按LastName进行排序

package com.lyh.util.compar;

import java.util.Comparator;

public class LastNameComparator implements Comparator {

public int compare(Object person, Object anotherPerson) {
         String lastName1 = ((Person) person).getLastName().toUpperCase();
         String firstName1 = ((Person) person).getFirstName().toUpperCase();
         String lastName2 = ((Person) anotherPerson).getLastName().toUpperCase();
         String firstName2 = ((Person) anotherPerson).getFirstName()
           .toUpperCase();

         if (lastName1.equals(lastName2)) {
          return firstName1.compareTo(firstName2);
         } else {
          return lastName2.compareTo(lastName1);
         }
}

}

//Person类

package com.lyh.util.compar;

public class Person implements Comparable {
private String firstName;

private String lastName;

private int age;

public int getAge() {
         return age;
}

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

public String getFirstName() {
         return firstName;
}

public void setFirstName(String firstName) {
         this.firstName = firstName;
}

public String getLastName() {
         return lastName;
}

public void setLastName(String lastName) {
         this.lastName = lastName;
}

public int compareTo(Object anotherPerson) {
         // TODO Auto-generated method stub
         if (!(anotherPerson instanceof Person)) {
               throw new ClassCastException("A Person object expected.");
             }
             int anotherPersonAge = ((Person) anotherPerson).getAge();
             return this.age - anotherPersonAge;

}

}

//主函数
package com.lyh.util.compar;

import java.util.Arrays;

public class MainClass {
@SuppressWarnings("unchecked")
public static void main(String[] args) {
         // TODO Auto-generated method stub
         Person[] persons = new Person[4];
            persons[0] = new Person();
            persons[0].setFirstName("A");
            persons[0].setLastName("X");
            persons[0].setAge(56);

            persons[1] = new Person();
            persons[1].setFirstName("S");
            persons[1].setLastName("C");
            persons[1].setAge(8);

            persons[2] = new Person();
            persons[2].setFirstName("E");
            persons[2].setLastName("H");
            persons[2].setAge(16);

            persons[3] = new Person();
            persons[3].setFirstName("B");
            persons[3].setLastName("Q");
            persons[3].setAge(69);

            System.out.println("Natural Order");
            for (int i = 0; i < 4; i++) {
              Person person = persons[i];
              String lastName = person.getLastName();
              String firstName = person.getFirstName();
              int age = person.getAge();
              System.out.println(lastName + ", " + firstName + ". Age:" + age);
            }
            Arrays.sort(persons, new LastNameComparator());
            System.out.println();
            System.out.println("Sorted by last name");
            for (int i = 0; i < 4; i++) {
              Person person = persons[i];
              String lastName = person.getLastName();
              String firstName = person.getFirstName();
              int age = person.getAge();
              System.out.println(lastName + ", " + firstName + ". Age:" + age);
            }
            Arrays.sort(persons, new FirstNameComparator());
            System.out.println();
            System.out.println("Sorted by first name");
            for (int i = 0; i < 4; i++) {
              Person person = persons[i];
              String lastName = person.getLastName();
              String firstName = person.getFirstName();
              int age = person.getAge();
              System.out.println(lastName + ", " + firstName + ". Age:" + age);
            }
            Arrays.sort(persons);
            System.out.println();
            System.out.println("Sorted by age");
            for (int i = 0; i < 4; i++) {
              Person person = persons[i];
              String lastName = person.getLastName();
              String firstName = person.getFirstName();
              int age = person.getAge();
              System.out.println(lastName + ", " + firstName + ". Age:" + age);
            }
        }
}



 

---------------------- ASP.Net+Android+IOS开发.Net培训、期待与您交流! ----------------------
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值