使用Arrays对数组进行排序(一)

原创 2012年03月21日 16:54:48

一、建立要比较的对象的类Person

package comparable.demo;

public class Person {

    int age;
    String name;

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

    public String toString() {
        return "name:" + name + ",age:" + age;
    }

}

二、实现Comparator接口,建立两种比较方式

package comparable.demo;

import java.util.Comparator;

public class CompparatorA implements Comparator<Object> {

    @Override
    public int compare(Object o1, Object o2) {
        // TODO Auto-generated method stub
        Person p1 = (Person) o1;
        Person p2 = (Person) o2;
        return p1.name.compareTo(p2.name);
    }

}


package comparable.demo;

import java.util.Comparator;

public class ComparatorB implements Comparator<Object> {

    @Override
    public int compare(Object o1, Object o2) {
        // TODO Auto-generated method stub
        Person p1 = (Person) o1;
        Person p2 = (Person) o2;
        return p1.age > p2.age ? 1 : p1.age == p2.age ? 0 : -1;
    }

}

三、测试

package comparable.demo;

import java.util.Arrays;

public class ComparatorTest {

    public static void main(String[] args) {
        Person[] p = new Person[] { new Person("A", 10), new Person("B", 11),
                new Person("C", 12), new Person("D", 14), new Person("E", 13), };
        System.out.println("按姓名排序");
        Arrays.sort(p, new CompparatorA());
        for (int i = 0; i < p.length; i++) {
            System.out.println(p[i]);
        }

//        System.out.println("-------------------");
        System.out.println("按年龄排序");

        Arrays.sort(p, new ComparatorB());
        for (int i = 0; i < p.length; i++) {
            System.out.println(p[i]);
        }
    }

}


相关文章推荐

使用Java Arrays类进行数组排序

Java Arrays类进行数组排序 static void sort(int[] a) public static void sort(T[] a,Comparator c)...

Arrays.sort()使用两种方式(Comparable和Comparator接口)对对象或者引用进行排序

自定义的类要按照一定的方式进行排序,比如一个Person类要按照年龄进行从小到大排序,比如一个Student类要按照成绩进行由高到低排序。这里我们采用两种方式,一种是使用Comparable接口:让待...
  • Yaphat
  • Yaphat
  • 2016年11月14日 09:39
  • 391

JAVA中Arrays.sort()使用两种方式(Comparable和Comparator接口)对对象或者引用进行排序

一、描述 自定义的类要按照一定的方式进行排序,比如一个Person类要按照年龄进行从小到大排序,比如一个Student类要按照成绩进行由高到低排序。 这里我们采用两种方式,一种是使用Compara...

使用shell排序,插入排序,选择排序,冒泡排序,以及java的Arrays中自带的排序进行对比

有兴趣的可以看看java自带的Arrays.sort()中的源码。其中是根据数据量的多少进行的快排或者是归并排序等。 博主并非大牛,所以该文不具有权威性,感兴趣的可以看看。 全部代码如下,可以去掉...

数组对象的Arrays排序两种方式

例如一个学生对象,初始化了10个Student对象,Student对象有name和sno两个属性,在数组里存放了10个Student对象,但是他们的排序是无序的,我想在数组内按照sno去排序。Arra...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:使用Arrays对数组进行排序(一)
举报原因:
原因补充:

(最多只允许输入30个字)