关闭

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

174人阅读 评论(0) 收藏 举报

一、建立要比较的对象的类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]);
        }
    }

}


0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:38823次
    • 积分:625
    • 等级:
    • 排名:千里之外
    • 原创:23篇
    • 转载:11篇
    • 译文:0篇
    • 评论:15条
    文章分类
    最新评论